2016-06-24 10:43:32 +02:00
package jira
import (
"fmt"
2018-06-08 18:00:22 +02:00
2018-04-03 14:29:29 +09:00
"github.com/google/go-querystring/query"
2016-06-24 10:43:32 +02:00
)
// SprintService handles sprints in JIRA Agile API.
2016-07-17 11:17:29 +02:00
// See https://docs.atlassian.com/jira-software/REST/cloud/
2016-06-24 10:43:32 +02:00
type SprintService struct {
client * Client
}
2016-07-17 11:17:29 +02:00
// IssuesWrapper represents a wrapper struct for moving issues to sprint
2016-06-24 10:43:32 +02:00
type IssuesWrapper struct {
Issues [ ] string ` json:"issues" `
}
2016-07-29 19:43:34 +02:00
// IssuesInSprintResult represents a wrapper struct for search result
2016-07-26 16:18:58 -04:00
type IssuesInSprintResult struct {
Issues [ ] Issue ` json:"issues" `
}
2016-07-17 11:17:29 +02:00
// MoveIssuesToSprint moves issues to a sprint, for a given sprint Id.
// Issues can only be moved to open or active sprints.
// The maximum number of issues that can be moved in one operation is 50.
2016-06-24 10:43:32 +02:00
//
2016-07-17 11:17:29 +02:00
// JIRA API docs: https://docs.atlassian.com/jira-software/REST/cloud/#agile/1.0/sprint-moveIssuesToSprint
func ( s * SprintService ) MoveIssuesToSprint ( sprintID int , issueIDs [ ] string ) ( * Response , error ) {
2016-06-24 10:43:32 +02:00
apiEndpoint := fmt . Sprintf ( "rest/agile/1.0/sprint/%d/issue" , sprintID )
payload := IssuesWrapper { Issues : issueIDs }
req , err := s . client . NewRequest ( "POST" , apiEndpoint , payload )
if err != nil {
return nil , err
}
resp , err := s . client . Do ( req , nil )
2017-11-03 15:22:32 -07:00
if err != nil {
err = NewJiraError ( resp , err )
}
2016-06-24 10:43:32 +02:00
return resp , err
}
2016-07-26 16:18:58 -04:00
2016-07-29 19:43:34 +02:00
// GetIssuesForSprint returns all issues in a sprint, for a given sprint Id.
// This only includes issues that the user has permission to view.
// By default, the returned issues are ordered by rank.
2016-07-26 16:18:58 -04:00
//
2016-07-29 19:43:34 +02:00
// JIRA API Docs: https://docs.atlassian.com/jira-software/REST/cloud/#agile/1.0/sprint-getIssuesForSprint
func ( s * SprintService ) GetIssuesForSprint ( sprintID int ) ( [ ] Issue , * Response , error ) {
2016-07-26 16:18:58 -04:00
apiEndpoint := fmt . Sprintf ( "rest/agile/1.0/sprint/%d/issue" , sprintID )
req , err := s . client . NewRequest ( "GET" , apiEndpoint , nil )
if err != nil {
return nil , nil , err
}
result := new ( IssuesInSprintResult )
resp , err := s . client . Do ( req , result )
2017-11-03 15:22:32 -07:00
if err != nil {
err = NewJiraError ( resp , err )
}
2016-07-26 16:18:58 -04:00
return result . Issues , resp , err
}
2018-04-03 14:29:29 +09:00
2018-06-08 18:00:22 +02:00
// GetIssue returns a full representation of the issue for the given issue key.
2018-04-03 14:29:29 +09:00
// JIRA will attempt to identify the issue by the issueIdOrKey path parameter.
// This can be an issue id, or an issue key.
// If the issue cannot be found via an exact match, JIRA will also look for the issue in a case-insensitive way, or by looking to see if the issue was moved.
//
// The given options will be appended to the query string
//
// JIRA API docs: https://docs.atlassian.com/jira-software/REST/7.3.1/#agile/1.0/issue-getIssue
//
// TODO: create agile service for holding all agile apis' implementation
func ( s * SprintService ) GetIssue ( issueID string , options * GetQueryOptions ) ( * Issue , * Response , error ) {
apiEndpoint := fmt . Sprintf ( "rest/agile/1.0/issue/%s" , issueID )
req , err := s . client . NewRequest ( "GET" , apiEndpoint , nil )
if err != nil {
return nil , nil , err
}
if options != nil {
q , err := query . Values ( options )
if err != nil {
return nil , nil , err
}
req . URL . RawQuery = q . Encode ( )
}
issue := new ( Issue )
resp , err := s . client . Do ( req , issue )
if err != nil {
jerr := NewJiraError ( resp , err )
return nil , resp , jerr
}
return issue , resp , nil
}