我正在尝试编写一个shell脚本,它使用JIRA自动化我的工作流程。我的目标是:
jira_flow start $KEY
脚本的步骤如下:
因此,我需要一种方法来获得问题的摘要。
首先,我尝试使用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
有什么建议吗?
答案 0 :(得分:3)
使用jq
解析json并提取必填字段:
$ curl -s "https://jira.atlassian.com/rest/api/2/issue/JRASERVER-66213" | jq ".fields.summary"
"Ship with Java Option PrintConcurrentLocks by Default"
对于您的情况,只需输入正确的网址即可。
第二种方法没有用,因为过滤字段的参数是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"
}
}
答案 1 :(得分:0)
如果您没有/想要jq,那么您可以使用P
和o
标记进行grep。
curl -s "https://jira.atlassian.com/rest/api/2/issue/JRASERVER-66213" | grep -Po '"summary":.*?[^\\]"
“summary”:“默认情况下使用Java选项PrintConcurrentLocks发送”
答案 2 :(得分:-1)
使用此:
curl -s https://<JiraServer>.jira.com/rest/api/2/search?jql="< JQL >+"&fields=id,key,summary,description,issuetype";