如何通过REST API检索JIRA票证的摘要?

时间:2017-10-26 06:28:04

标签: curl jira jira-rest-api jql

我正在尝试编写一个shell脚本,它使用JIRA自动化我的工作流程。我的目标是:

jira_flow start $KEY

脚本的步骤如下:

  • 将当前项目部署到sonarqube
  • 根据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

有什么建议吗?

3 个答案:

答案 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,那么您可以使用Po标记进行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";