2016-05-29 19:42:38 +03:00
|
|
|
package jira
|
|
|
|
|
|
|
|
import (
|
2016-06-01 15:13:11 +03:00
|
|
|
"fmt"
|
2016-05-29 19:42:38 +03:00
|
|
|
)
|
|
|
|
|
2016-06-03 23:25:18 +02:00
|
|
|
// ProjectService handles projects for the JIRA instance / API.
|
|
|
|
//
|
|
|
|
// JIRA API docs: https://docs.atlassian.com/jira/REST/latest/#api/2/project
|
2016-05-29 19:42:38 +03:00
|
|
|
type ProjectService struct {
|
|
|
|
client *Client
|
|
|
|
}
|
|
|
|
|
2016-06-03 23:25:18 +02:00
|
|
|
// ProjectList represent a list of Projects
|
2016-05-29 19:42:38 +03:00
|
|
|
type ProjectList []struct {
|
2016-06-03 23:14:27 +02:00
|
|
|
Expand string `json:"expand"`
|
|
|
|
Self string `json:"self"`
|
|
|
|
ID string `json:"id"`
|
|
|
|
Key string `json:"key"`
|
|
|
|
Name string `json:"name"`
|
|
|
|
AvatarUrls AvatarUrls `json:"avatarUrls"`
|
|
|
|
ProjectTypeKey string `json:"projectTypeKey"`
|
|
|
|
ProjectCategory ProjectCategory `json:"projectCategory,omitempty"`
|
2016-05-29 19:42:38 +03:00
|
|
|
}
|
|
|
|
|
2016-06-03 23:25:18 +02:00
|
|
|
// ProjectCategory represents a single project category
|
2016-06-03 23:14:27 +02:00
|
|
|
type ProjectCategory struct {
|
2016-06-01 15:13:11 +03:00
|
|
|
Self string `json:"self"`
|
|
|
|
ID string `json:"id"`
|
2016-06-03 23:14:27 +02:00
|
|
|
Name string `json:"name"`
|
2016-06-01 15:13:11 +03:00
|
|
|
Description string `json:"description"`
|
2016-06-03 23:14:27 +02:00
|
|
|
}
|
|
|
|
|
2016-06-03 23:25:18 +02:00
|
|
|
// Project represents a JIRA Project.
|
|
|
|
type Project struct {
|
|
|
|
Expand string `json:"expand,omitempty"`
|
|
|
|
Self string `json:"self,omitempty"`
|
|
|
|
ID string `json:"id,omitempty"`
|
|
|
|
Key string `json:"key,omitempty"`
|
|
|
|
Description string `json:"description,omitempty"`
|
|
|
|
Lead User `json:"lead,omitempty"`
|
|
|
|
Components []ProjectComponent `json:"components,omitempty"`
|
|
|
|
IssueTypes []IssueType `json:"issueTypes,omitempty"`
|
|
|
|
URL string `json:"url,omitempty"`
|
|
|
|
Email string `json:"email,omitempty"`
|
|
|
|
AssigneeType string `json:"assigneeType,omitempty"`
|
|
|
|
Versions []interface{} `json:"versions,omitempty"`
|
|
|
|
Name string `json:"name,omitempty"`
|
2016-06-01 15:13:11 +03:00
|
|
|
Roles struct {
|
2016-06-03 23:25:18 +02:00
|
|
|
Developers string `json:"Developers,omitempty"`
|
|
|
|
} `json:"roles,omitempty"`
|
|
|
|
AvatarUrls AvatarUrls `json:"avatarUrls,omitempty"`
|
|
|
|
ProjectCategory ProjectCategory `json:"projectCategory,omitempty"`
|
2016-06-03 23:14:27 +02:00
|
|
|
}
|
|
|
|
|
2016-06-03 23:25:18 +02:00
|
|
|
// ProjectComponent represents a single component of a project
|
2016-06-03 23:14:27 +02:00
|
|
|
type ProjectComponent struct {
|
|
|
|
Self string `json:"self"`
|
|
|
|
ID string `json:"id"`
|
|
|
|
Name string `json:"name"`
|
|
|
|
Description string `json:"description"`
|
|
|
|
Lead User `json:"lead"`
|
|
|
|
AssigneeType string `json:"assigneeType"`
|
|
|
|
Assignee User `json:"assignee"`
|
|
|
|
RealAssigneeType string `json:"realAssigneeType"`
|
|
|
|
RealAssignee User `json:"realAssignee"`
|
|
|
|
IsAssigneeTypeValid bool `json:"isAssigneeTypeValid"`
|
|
|
|
Project string `json:"project"`
|
|
|
|
ProjectID int `json:"projectId"`
|
2016-06-01 15:13:11 +03:00
|
|
|
}
|
|
|
|
|
2016-06-03 23:16:21 +02:00
|
|
|
// GetList gets all projects form JIRA
|
2016-06-01 15:13:11 +03:00
|
|
|
//
|
|
|
|
// JIRA API docs: https://docs.atlassian.com/jira/REST/latest/#api/2/project-getAllProjects
|
2016-06-15 17:09:13 +02:00
|
|
|
func (s *ProjectService) GetList() (*ProjectList, *Response, error) {
|
2016-05-29 19:42:38 +03:00
|
|
|
apiEndpoint := "rest/api/2/project"
|
|
|
|
req, err := s.client.NewRequest("GET", apiEndpoint, nil)
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
projectList := new(ProjectList)
|
|
|
|
resp, err := s.client.Do(req, projectList)
|
|
|
|
if err != nil {
|
|
|
|
return nil, resp, err
|
|
|
|
}
|
|
|
|
return projectList, resp, nil
|
|
|
|
}
|
2016-06-01 15:13:11 +03:00
|
|
|
|
|
|
|
// Get returns a full representation of the project for the given issue key.
|
|
|
|
// JIRA will attempt to identify the project by the projectIdOrKey path parameter.
|
|
|
|
// This can be an project id, or an project key.
|
|
|
|
//
|
|
|
|
// JIRA API docs: https://docs.atlassian.com/jira/REST/latest/#api/2/project-getProject
|
2016-06-15 17:09:13 +02:00
|
|
|
func (s *ProjectService) Get(projectID string) (*Project, *Response, error) {
|
2016-06-01 15:13:11 +03:00
|
|
|
apiEndpoint := fmt.Sprintf("/rest/api/2/project/%s", projectID)
|
|
|
|
req, err := s.client.NewRequest("GET", apiEndpoint, nil)
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
2016-06-03 23:25:18 +02:00
|
|
|
project := new(Project)
|
2016-06-01 15:13:11 +03:00
|
|
|
resp, err := s.client.Do(req, project)
|
|
|
|
if err != nil {
|
|
|
|
return nil, resp, err
|
|
|
|
}
|
|
|
|
return project, resp, nil
|
|
|
|
}
|