0

我已经使用ACE BitBucket 站点上的说明设置了我的 Atlassian Connect 应用程序,并且我一直像往常一样使用 ngrok 隧道将我的应用程序手动部署到开发实例。该应用程序运行良好,所有页面都正确显示,并且应用程序本身执行了它应该做的事情(在开发模式下)

现在,我正在尝试将 Heroku 用于我的生产部署,并且应用程序构建和部署都很好,在heroku logs --tail. 我可以清楚地看到atlassian-connect.json描述符被部署到 Heroku 上的适当 URL。

但是,当我尝试使用 Heroku 上已部署描述符的 URL 以在我的一个测试 Jira 实例中安装我的应用程序时,我在 Jira 中收到以下错误:

The app host returned HTTP response code 503 when we tried to contact it during installation. Please try again later or contact the app vendor.

这些是我从 Heroku 获得的日志,在任何地方都没有抛出明显的错误:

2020-04-03T04:51:11.256336+00:00 heroku[router]: at=info method=GET path="/atlassian-connect.json" host=example-app.herokuapp.com request_id=4676badf-c37f-4440-b017-1b1ec5f00023 fwd="18.234.32.227" dyno=web.1 connect=1ms service=4ms status=200 bytes=1354 protocol=https

2020-04-03T04:51:11.255764+00:00 app[web.1]: ::ffff:10.5.179.3 - - [03/Apr/2020:04:51:11 +0000] "GET /atlassian-connect.json HTTP/1.1" 200 905 "-" "Apache-HttpClient/4.5.12 (Java/1.8.0_242)"

最后,这是我的atlassian-connect.json文件:

{
    "key": "example-app",
    "name": "Example App",
    "baseUrl": "{{localBaseUrl}}",
    "authentication": {
        "type": "jwt"
    },
    "lifecycle": {
        "installed": "installed"
    },
    "scopes": [
        "READ"
    ],
    "modules": {
        "jiraProjectPages": [
            {
                "key": "example-app-page-jira",
                "location": "system.top.navigation.bar",
                "name": {
                    "value": "Example app"
                },
                "url": "/example-app",
                "iconUrl": "{{localBaseUrl}}/images/example.svg",
                "conditions": [{
                    "condition": "user_is_logged_in"
                }]
            },
            {
                "key": "example-app-2-page-jira",
                "location": "system.top.navigation.bar",
                "name": {
                    "value": "Example app 2"
                },
                "url": "/example-app-2",
                "iconUrl": "{{localBaseUrl}}/images/example2.svg",
                "conditions": [{
                    "condition": "user_is_logged_in"
                }]
            }
        ]
    }
}

这是我到目前为止所尝试的:

  • /installed为in定义路由index.js,给出状态码 200,如下所示:
app.get('/installed', (req, res) => {
        res.send('success');
    });
  • 更新pgsequelize
  • 将描述符作为私有应用程序上传到 Atlassian Marketplace 并从那里安装

似乎没有任何效果;有谁知道是什么导致了这个错误?

4

1 回答 1

0

原来这个问题是我认为我已经处理过的,但实际上没有。

问题最终是/installed终点;正如您在描述符中看到的那样,我已将生命周期端点定义为"installed"而不是"/installed",因此从未收到响应。

更改该行以"/installed"修复所有内容。

于 2020-04-04T22:28:03.407 回答