08069dc465
* add migrations * fix package dependency * fix lints * implements migrations except pull requests * add releases * migrating releases * fix bug * fix lint * fix migrate releases * fix tests * add rollback * pull request migtations * fix import * fix go module vendor * add tests for upload to gitea * more migrate options * fix swagger-check * fix misspell * add options on migration UI * fix log error * improve UI options on migrating * add support for username password when migrating from github * fix tests * remove comments and fix migrate limitation * improve error handles * migrate API will also support migrate milestones/labels/issues/pulls/releases * fix tests and remove unused codes * add DownloaderFactory and docs about how to create a new Downloader * fix misspell * fix migration docs * Add hints about migrate options on migration page * fix tests
80 lines
2.5 KiB
Go
Vendored
80 lines
2.5 KiB
Go
Vendored
// Copyright 2017 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
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
)
|
|
|
|
// ReviewersRequest specifies users and teams for a pull request review request.
|
|
type ReviewersRequest struct {
|
|
Reviewers []string `json:"reviewers,omitempty"`
|
|
TeamReviewers []string `json:"team_reviewers,omitempty"`
|
|
}
|
|
|
|
// Reviewers represents reviewers of a pull request.
|
|
type Reviewers struct {
|
|
Users []*User `json:"users,omitempty"`
|
|
Teams []*Team `json:"teams,omitempty"`
|
|
}
|
|
|
|
// RequestReviewers creates a review request for the provided reviewers for the specified pull request.
|
|
//
|
|
// GitHub API docs: https://developer.github.com/v3/pulls/review_requests/#create-a-review-request
|
|
func (s *PullRequestsService) RequestReviewers(ctx context.Context, owner, repo string, number int, reviewers ReviewersRequest) (*PullRequest, *Response, error) {
|
|
u := fmt.Sprintf("repos/%s/%s/pulls/%d/requested_reviewers", owner, repo, number)
|
|
req, err := s.client.NewRequest("POST", u, &reviewers)
|
|
if err != nil {
|
|
return nil, nil, err
|
|
}
|
|
|
|
r := new(PullRequest)
|
|
resp, err := s.client.Do(ctx, req, r)
|
|
if err != nil {
|
|
return nil, resp, err
|
|
}
|
|
|
|
return r, resp, nil
|
|
}
|
|
|
|
// ListReviewers lists reviewers whose reviews have been requested on the specified pull request.
|
|
//
|
|
// GitHub API docs: https://developer.github.com/v3/pulls/review_requests/#list-review-requests
|
|
func (s *PullRequestsService) ListReviewers(ctx context.Context, owner, repo string, number int, opt *ListOptions) (*Reviewers, *Response, error) {
|
|
u := fmt.Sprintf("repos/%v/%v/pulls/%d/requested_reviewers", 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
|
|
}
|
|
|
|
reviewers := new(Reviewers)
|
|
resp, err := s.client.Do(ctx, req, reviewers)
|
|
if err != nil {
|
|
return nil, resp, err
|
|
}
|
|
|
|
return reviewers, resp, nil
|
|
}
|
|
|
|
// RemoveReviewers removes the review request for the provided reviewers for the specified pull request.
|
|
//
|
|
// GitHub API docs: https://developer.github.com/v3/pulls/review_requests/#delete-a-review-request
|
|
func (s *PullRequestsService) RemoveReviewers(ctx context.Context, owner, repo string, number int, reviewers ReviewersRequest) (*Response, error) {
|
|
u := fmt.Sprintf("repos/%s/%s/pulls/%d/requested_reviewers", owner, repo, number)
|
|
req, err := s.client.NewRequest("DELETE", u, &reviewers)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return s.client.Do(ctx, req, nil)
|
|
}
|