2017-02-07 22:33:23 +01:00
|
|
|
// Copyright 2013 The go-github AUTHORS. All rights reserved.
|
|
|
|
//
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package github
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
)
|
2017-02-07 22:33:23 +01:00
|
|
|
|
|
|
|
// Label represents a GitHub label on an Issue
|
|
|
|
type Label struct {
|
2017-04-11 17:10:46 +02:00
|
|
|
ID *int `json:"id,omitempty"`
|
2017-02-07 22:33:23 +01:00
|
|
|
URL *string `json:"url,omitempty"`
|
|
|
|
Name *string `json:"name,omitempty"`
|
|
|
|
Color *string `json:"color,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
func (l Label) String() string {
|
2017-07-06 16:28:13 +02:00
|
|
|
return Stringify(l)
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// ListLabels lists all labels for a repository.
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
// GitHub API docs: https://developer.github.com/v3/issues/labels/#list-all-labels-for-this-repository
|
|
|
|
func (s *IssuesService) ListLabels(ctx context.Context, owner string, repo string, opt *ListOptions) ([]*Label, *Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
u := fmt.Sprintf("repos/%v/%v/labels", owner, repo)
|
|
|
|
u, err := addOptions(u, opt)
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
req, err := s.client.NewRequest("GET", u, nil)
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
var labels []*Label
|
|
|
|
resp, err := s.client.Do(ctx, req, &labels)
|
2017-02-07 22:33:23 +01:00
|
|
|
if err != nil {
|
|
|
|
return nil, resp, err
|
|
|
|
}
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
return labels, resp, nil
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// GetLabel gets a single label.
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
// GitHub API docs: https://developer.github.com/v3/issues/labels/#get-a-single-label
|
|
|
|
func (s *IssuesService) GetLabel(ctx context.Context, owner string, repo string, name string) (*Label, *Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
u := fmt.Sprintf("repos/%v/%v/labels/%v", owner, repo, name)
|
|
|
|
req, err := s.client.NewRequest("GET", u, nil)
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
label := new(Label)
|
2017-04-11 17:10:46 +02:00
|
|
|
resp, err := s.client.Do(ctx, req, label)
|
2017-02-07 22:33:23 +01:00
|
|
|
if err != nil {
|
|
|
|
return nil, resp, err
|
|
|
|
}
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
return label, resp, nil
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// CreateLabel creates a new label on the specified repository.
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
// GitHub API docs: https://developer.github.com/v3/issues/labels/#create-a-label
|
|
|
|
func (s *IssuesService) CreateLabel(ctx context.Context, owner string, repo string, label *Label) (*Label, *Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
u := fmt.Sprintf("repos/%v/%v/labels", owner, repo)
|
|
|
|
req, err := s.client.NewRequest("POST", u, label)
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
l := new(Label)
|
2017-04-11 17:10:46 +02:00
|
|
|
resp, err := s.client.Do(ctx, req, l)
|
2017-02-07 22:33:23 +01:00
|
|
|
if err != nil {
|
|
|
|
return nil, resp, err
|
|
|
|
}
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
return l, resp, nil
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// EditLabel edits a label.
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
// GitHub API docs: https://developer.github.com/v3/issues/labels/#update-a-label
|
|
|
|
func (s *IssuesService) EditLabel(ctx context.Context, owner string, repo string, name string, label *Label) (*Label, *Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
u := fmt.Sprintf("repos/%v/%v/labels/%v", owner, repo, name)
|
|
|
|
req, err := s.client.NewRequest("PATCH", u, label)
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
l := new(Label)
|
2017-04-11 17:10:46 +02:00
|
|
|
resp, err := s.client.Do(ctx, req, l)
|
2017-02-07 22:33:23 +01:00
|
|
|
if err != nil {
|
|
|
|
return nil, resp, err
|
|
|
|
}
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
return l, resp, nil
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// DeleteLabel deletes a label.
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
// GitHub API docs: https://developer.github.com/v3/issues/labels/#delete-a-label
|
|
|
|
func (s *IssuesService) DeleteLabel(ctx context.Context, owner string, repo string, name string) (*Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
u := fmt.Sprintf("repos/%v/%v/labels/%v", owner, repo, name)
|
|
|
|
req, err := s.client.NewRequest("DELETE", u, nil)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2017-04-11 17:10:46 +02:00
|
|
|
return s.client.Do(ctx, req, nil)
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// ListLabelsByIssue lists all labels for an issue.
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
// GitHub API docs: https://developer.github.com/v3/issues/labels/#list-labels-on-an-issue
|
|
|
|
func (s *IssuesService) ListLabelsByIssue(ctx context.Context, owner string, repo string, number int, opt *ListOptions) ([]*Label, *Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
u := fmt.Sprintf("repos/%v/%v/issues/%d/labels", owner, repo, number)
|
|
|
|
u, err := addOptions(u, opt)
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
req, err := s.client.NewRequest("GET", u, nil)
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
var labels []*Label
|
|
|
|
resp, err := s.client.Do(ctx, req, &labels)
|
2017-02-07 22:33:23 +01:00
|
|
|
if err != nil {
|
|
|
|
return nil, resp, err
|
|
|
|
}
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
return labels, resp, nil
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// AddLabelsToIssue adds labels to an issue.
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
// GitHub API docs: https://developer.github.com/v3/issues/labels/#add-labels-to-an-issue
|
|
|
|
func (s *IssuesService) AddLabelsToIssue(ctx context.Context, owner string, repo string, number int, labels []string) ([]*Label, *Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
u := fmt.Sprintf("repos/%v/%v/issues/%d/labels", owner, repo, number)
|
|
|
|
req, err := s.client.NewRequest("POST", u, labels)
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
var l []*Label
|
|
|
|
resp, err := s.client.Do(ctx, req, &l)
|
2017-02-07 22:33:23 +01:00
|
|
|
if err != nil {
|
|
|
|
return nil, resp, err
|
|
|
|
}
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
return l, resp, nil
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// RemoveLabelForIssue removes a label for an issue.
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
// GitHub API docs: https://developer.github.com/v3/issues/labels/#remove-a-label-from-an-issue
|
|
|
|
func (s *IssuesService) RemoveLabelForIssue(ctx context.Context, owner string, repo string, number int, label string) (*Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
u := fmt.Sprintf("repos/%v/%v/issues/%d/labels/%v", owner, repo, number, label)
|
|
|
|
req, err := s.client.NewRequest("DELETE", u, nil)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2017-04-11 17:10:46 +02:00
|
|
|
return s.client.Do(ctx, req, nil)
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// ReplaceLabelsForIssue replaces all labels for an issue.
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
// GitHub API docs: https://developer.github.com/v3/issues/labels/#replace-all-labels-for-an-issue
|
|
|
|
func (s *IssuesService) ReplaceLabelsForIssue(ctx context.Context, owner string, repo string, number int, labels []string) ([]*Label, *Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
u := fmt.Sprintf("repos/%v/%v/issues/%d/labels", owner, repo, number)
|
|
|
|
req, err := s.client.NewRequest("PUT", u, labels)
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
var l []*Label
|
|
|
|
resp, err := s.client.Do(ctx, req, &l)
|
2017-02-07 22:33:23 +01:00
|
|
|
if err != nil {
|
|
|
|
return nil, resp, err
|
|
|
|
}
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
return l, resp, nil
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// RemoveLabelsForIssue removes all labels for an issue.
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
// GitHub API docs: https://developer.github.com/v3/issues/labels/#remove-all-labels-from-an-issue
|
|
|
|
func (s *IssuesService) RemoveLabelsForIssue(ctx context.Context, owner string, repo string, number int) (*Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
u := fmt.Sprintf("repos/%v/%v/issues/%d/labels", owner, repo, number)
|
|
|
|
req, err := s.client.NewRequest("DELETE", u, nil)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2017-04-11 17:10:46 +02:00
|
|
|
return s.client.Do(ctx, req, nil)
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// ListLabelsForMilestone lists labels for every issue in a milestone.
|
|
|
|
//
|
2017-04-11 17:10:46 +02:00
|
|
|
// GitHub API docs: https://developer.github.com/v3/issues/labels/#get-labels-for-every-issue-in-a-milestone
|
|
|
|
func (s *IssuesService) ListLabelsForMilestone(ctx context.Context, owner string, repo string, number int, opt *ListOptions) ([]*Label, *Response, error) {
|
2017-02-07 22:33:23 +01:00
|
|
|
u := fmt.Sprintf("repos/%v/%v/milestones/%d/labels", owner, repo, number)
|
|
|
|
u, err := addOptions(u, opt)
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
req, err := s.client.NewRequest("GET", u, nil)
|
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
var labels []*Label
|
|
|
|
resp, err := s.client.Do(ctx, req, &labels)
|
2017-02-07 22:33:23 +01:00
|
|
|
if err != nil {
|
|
|
|
return nil, resp, err
|
|
|
|
}
|
|
|
|
|
2017-04-11 17:10:46 +02:00
|
|
|
return labels, resp, nil
|
2017-02-07 22:33:23 +01:00
|
|
|
}
|