我已经按照at the ACE BitBucket site,的说明设置了Atlassian Connect应用程序,并且像往常一样,我一直在使用ngrok隧道手动将我的应用程序部署到开发实例中。该应用程序运行正常,所有页面均正确显示,并且该应用程序本身执行了预期的操作(在开发模式下)
现在,我正在尝试将Heroku用于我的生产部署,该应用程序的构建和部署就很好,并且heroku logs --tail
中没有显示错误。我可以清楚地看到atlassian-connect.json
描述符已部署到Heroku上的相应URL。
但是,当我尝试使用URL到Heroku上已部署的描述符以在一个测试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
中为index.js
定义一条路由,并提供状态代码200,如下所示:app.get('/installed', (req, res) => {
res.send('success');
});
pg
和sequelize
程序包似乎没有任何作用;有谁知道导致此错误的原因?
发现问题是我思考我要处理的,但实际上没有。
问题是最后的/installed
端点;正如您在描述符中看到的那样,我已将生命周期终结点定义为"installed"
而不是"/installed"
,因此从未收到响应。
将该行更改为"/installed"
修复了所有问题。