我正在尝试编写一个shell脚本,它可以自动使用JIRA进行工作流程。我的目标是:
jira_flow start $KEY
脚本的步骤如下:
- 将当前项目部署到声纳库贝
- 根据 Jira 事务密钥和摘要创建新分支
因此,我需要一种方法来获取问题的摘要。
首先,我尝试使用issue
API和grep
。
curl http://jira.local:8081/rest/api/2/issue/$KEY |
json_pp |
grep sumarry
# produces:
"summary" : "linked issue summary 1"
"summary" : "linked issue summary 2"
"summary" : "sub-task summary 1"
"summary" : "sub-task summary 2"
"summary" : "sub-task summary 3"
"summary" : "issue summary"
这种方法给了我很多结果,因为它还可以打印链接工单和子任务的摘要。
我的第二次尝试是使用 search
API 并限制要检索的字段。这种方法失败了,因为我无法通过key
搜索问题。
curl http://jira.local:8081/rest/api/2/search?jql=key=$KEY
# returns:
no matches found: http://jira.local/rest/api/2/search?jql=key=$KEY
有什么建议吗?
使用 jq
解析 json 并提取必填字段:
$ curl -s "https://jira.atlassian.com/rest/api/2/issue/JRASERVER-66213" | jq ".fields.summary"
"Ship with Java Option PrintConcurrentLocks by Default"
对于您的情况,只需输入正确的URL。您的第二种方法不起作用,因为过滤字段的参数field
:
curl -s "https://jira.atlassian.com/rest/api/2/issue/JRASERVER-66213?fields=summary" | jq "."
{
"expand": "renderedFields,names,schema,operations,editmeta,changelog,versionedRepresentations",
"id": "874745",
"self": "https://jira.atlassian.com/rest/api/2/issue/874745",
"key": "JRASERVER-66213",
"fields": {
"summary": "Ship with Java Option PrintConcurrentLocks by Default"
}
}
如果你没有/想要 jq,那么你可以使用 P
和 o
标志进行 grep。
curl -s "https://jira.atlassian.com/rest/api/2/issue/JRASERVER-66213" | grep -Po '"summary":.*?[^\]"
"summary":"默认情况下随 Java 选项一起提供 PrintConcurrentLocks"
使用这个:
curl -s https://<JiraServer>.jira.com/rest/api/2/search?jql="< JQL >+"&fields=id,key,summary,description,issuetype";