* 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
		
			
				
	
	
		
			234 lines
		
	
	
		
			7.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			234 lines
		
	
	
		
			7.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // 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
 | |
| 
 | |
| import (
 | |
| 	"bytes"
 | |
| 	"context"
 | |
| 	"fmt"
 | |
| 	"net/url"
 | |
| 	"time"
 | |
| )
 | |
| 
 | |
| // RepositoryCommit represents a commit in a repo.
 | |
| // Note that it's wrapping a Commit, so author/committer information is in two places,
 | |
| // but contain different details about them: in RepositoryCommit "github details", in Commit - "git details".
 | |
| type RepositoryCommit struct {
 | |
| 	SHA         *string  `json:"sha,omitempty"`
 | |
| 	Commit      *Commit  `json:"commit,omitempty"`
 | |
| 	Author      *User    `json:"author,omitempty"`
 | |
| 	Committer   *User    `json:"committer,omitempty"`
 | |
| 	Parents     []Commit `json:"parents,omitempty"`
 | |
| 	HTMLURL     *string  `json:"html_url,omitempty"`
 | |
| 	URL         *string  `json:"url,omitempty"`
 | |
| 	CommentsURL *string  `json:"comments_url,omitempty"`
 | |
| 
 | |
| 	// Details about how many changes were made in this commit. Only filled in during GetCommit!
 | |
| 	Stats *CommitStats `json:"stats,omitempty"`
 | |
| 	// Details about which files, and how this commit touched. Only filled in during GetCommit!
 | |
| 	Files []CommitFile `json:"files,omitempty"`
 | |
| }
 | |
| 
 | |
| func (r RepositoryCommit) String() string {
 | |
| 	return Stringify(r)
 | |
| }
 | |
| 
 | |
| // CommitStats represents the number of additions / deletions from a file in a given RepositoryCommit or GistCommit.
 | |
| type CommitStats struct {
 | |
| 	Additions *int `json:"additions,omitempty"`
 | |
| 	Deletions *int `json:"deletions,omitempty"`
 | |
| 	Total     *int `json:"total,omitempty"`
 | |
| }
 | |
| 
 | |
| func (c CommitStats) String() string {
 | |
| 	return Stringify(c)
 | |
| }
 | |
| 
 | |
| // CommitFile represents a file modified in a commit.
 | |
| type CommitFile struct {
 | |
| 	SHA              *string `json:"sha,omitempty"`
 | |
| 	Filename         *string `json:"filename,omitempty"`
 | |
| 	Additions        *int    `json:"additions,omitempty"`
 | |
| 	Deletions        *int    `json:"deletions,omitempty"`
 | |
| 	Changes          *int    `json:"changes,omitempty"`
 | |
| 	Status           *string `json:"status,omitempty"`
 | |
| 	Patch            *string `json:"patch,omitempty"`
 | |
| 	BlobURL          *string `json:"blob_url,omitempty"`
 | |
| 	RawURL           *string `json:"raw_url,omitempty"`
 | |
| 	ContentsURL      *string `json:"contents_url,omitempty"`
 | |
| 	PreviousFilename *string `json:"previous_filename,omitempty"`
 | |
| }
 | |
| 
 | |
| func (c CommitFile) String() string {
 | |
| 	return Stringify(c)
 | |
| }
 | |
| 
 | |
| // CommitsComparison is the result of comparing two commits.
 | |
| // See CompareCommits() for details.
 | |
| type CommitsComparison struct {
 | |
| 	BaseCommit      *RepositoryCommit `json:"base_commit,omitempty"`
 | |
| 	MergeBaseCommit *RepositoryCommit `json:"merge_base_commit,omitempty"`
 | |
| 
 | |
| 	// Head can be 'behind' or 'ahead'
 | |
| 	Status       *string `json:"status,omitempty"`
 | |
| 	AheadBy      *int    `json:"ahead_by,omitempty"`
 | |
| 	BehindBy     *int    `json:"behind_by,omitempty"`
 | |
| 	TotalCommits *int    `json:"total_commits,omitempty"`
 | |
| 
 | |
| 	Commits []RepositoryCommit `json:"commits,omitempty"`
 | |
| 
 | |
| 	Files []CommitFile `json:"files,omitempty"`
 | |
| 
 | |
| 	HTMLURL      *string `json:"html_url,omitempty"`
 | |
| 	PermalinkURL *string `json:"permalink_url,omitempty"`
 | |
| 	DiffURL      *string `json:"diff_url,omitempty"`
 | |
| 	PatchURL     *string `json:"patch_url,omitempty"`
 | |
| 	URL          *string `json:"url,omitempty"` // API URL.
 | |
| }
 | |
| 
 | |
| func (c CommitsComparison) String() string {
 | |
| 	return Stringify(c)
 | |
| }
 | |
| 
 | |
| // CommitsListOptions specifies the optional parameters to the
 | |
| // RepositoriesService.ListCommits method.
 | |
| type CommitsListOptions struct {
 | |
| 	// SHA or branch to start listing Commits from.
 | |
| 	SHA string `url:"sha,omitempty"`
 | |
| 
 | |
| 	// Path that should be touched by the returned Commits.
 | |
| 	Path string `url:"path,omitempty"`
 | |
| 
 | |
| 	// Author of by which to filter Commits.
 | |
| 	Author string `url:"author,omitempty"`
 | |
| 
 | |
| 	// Since when should Commits be included in the response.
 | |
| 	Since time.Time `url:"since,omitempty"`
 | |
| 
 | |
| 	// Until when should Commits be included in the response.
 | |
| 	Until time.Time `url:"until,omitempty"`
 | |
| 
 | |
| 	ListOptions
 | |
| }
 | |
| 
 | |
| // ListCommits lists the commits of a repository.
 | |
| //
 | |
| // GitHub API docs: https://developer.github.com/v3/repos/commits/#list
 | |
| func (s *RepositoriesService) ListCommits(ctx context.Context, owner, repo string, opt *CommitsListOptions) ([]*RepositoryCommit, *Response, error) {
 | |
| 	u := fmt.Sprintf("repos/%v/%v/commits", 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
 | |
| 	}
 | |
| 
 | |
| 	var commits []*RepositoryCommit
 | |
| 	resp, err := s.client.Do(ctx, req, &commits)
 | |
| 	if err != nil {
 | |
| 		return nil, resp, err
 | |
| 	}
 | |
| 
 | |
| 	return commits, resp, nil
 | |
| }
 | |
| 
 | |
| // GetCommit fetches the specified commit, including all details about it.
 | |
| //
 | |
| // GitHub API docs: https://developer.github.com/v3/repos/commits/#get-a-single-commit
 | |
| // See also: https://developer.github.com/v3/git/commits/#get-a-single-commit provides the same functionality
 | |
| func (s *RepositoriesService) GetCommit(ctx context.Context, owner, repo, sha string) (*RepositoryCommit, *Response, error) {
 | |
| 	u := fmt.Sprintf("repos/%v/%v/commits/%v", owner, repo, sha)
 | |
| 
 | |
| 	req, err := s.client.NewRequest("GET", u, nil)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 
 | |
| 	commit := new(RepositoryCommit)
 | |
| 	resp, err := s.client.Do(ctx, req, commit)
 | |
| 	if err != nil {
 | |
| 		return nil, resp, err
 | |
| 	}
 | |
| 
 | |
| 	return commit, resp, nil
 | |
| }
 | |
| 
 | |
| // GetCommitRaw fetches the specified commit in raw (diff or patch) format.
 | |
| func (s *RepositoriesService) GetCommitRaw(ctx context.Context, owner string, repo string, sha string, opt RawOptions) (string, *Response, error) {
 | |
| 	u := fmt.Sprintf("repos/%v/%v/commits/%v", owner, repo, sha)
 | |
| 	req, err := s.client.NewRequest("GET", u, nil)
 | |
| 	if err != nil {
 | |
| 		return "", nil, err
 | |
| 	}
 | |
| 
 | |
| 	switch opt.Type {
 | |
| 	case Diff:
 | |
| 		req.Header.Set("Accept", mediaTypeV3Diff)
 | |
| 	case Patch:
 | |
| 		req.Header.Set("Accept", mediaTypeV3Patch)
 | |
| 	default:
 | |
| 		return "", nil, fmt.Errorf("unsupported raw type %d", opt.Type)
 | |
| 	}
 | |
| 
 | |
| 	var buf bytes.Buffer
 | |
| 	resp, err := s.client.Do(ctx, req, &buf)
 | |
| 	if err != nil {
 | |
| 		return "", resp, err
 | |
| 	}
 | |
| 
 | |
| 	return buf.String(), resp, nil
 | |
| }
 | |
| 
 | |
| // GetCommitSHA1 gets the SHA-1 of a commit reference. If a last-known SHA1 is
 | |
| // supplied and no new commits have occurred, a 304 Unmodified response is returned.
 | |
| //
 | |
| // GitHub API docs: https://developer.github.com/v3/repos/commits/#get-the-sha-1-of-a-commit-reference
 | |
| func (s *RepositoriesService) GetCommitSHA1(ctx context.Context, owner, repo, ref, lastSHA string) (string, *Response, error) {
 | |
| 	u := fmt.Sprintf("repos/%v/%v/commits/%v", owner, repo, url.QueryEscape(ref))
 | |
| 
 | |
| 	req, err := s.client.NewRequest("GET", u, nil)
 | |
| 	if err != nil {
 | |
| 		return "", nil, err
 | |
| 	}
 | |
| 	if lastSHA != "" {
 | |
| 		req.Header.Set("If-None-Match", `"`+lastSHA+`"`)
 | |
| 	}
 | |
| 
 | |
| 	req.Header.Set("Accept", mediaTypeV3SHA)
 | |
| 
 | |
| 	var buf bytes.Buffer
 | |
| 	resp, err := s.client.Do(ctx, req, &buf)
 | |
| 	if err != nil {
 | |
| 		return "", resp, err
 | |
| 	}
 | |
| 
 | |
| 	return buf.String(), resp, nil
 | |
| }
 | |
| 
 | |
| // CompareCommits compares a range of commits with each other.
 | |
| // todo: support media formats - https://github.com/google/go-github/issues/6
 | |
| //
 | |
| // GitHub API docs: https://developer.github.com/v3/repos/commits/#compare-two-commits
 | |
| func (s *RepositoriesService) CompareCommits(ctx context.Context, owner, repo string, base, head string) (*CommitsComparison, *Response, error) {
 | |
| 	u := fmt.Sprintf("repos/%v/%v/compare/%v...%v", owner, repo, base, head)
 | |
| 
 | |
| 	req, err := s.client.NewRequest("GET", u, nil)
 | |
| 	if err != nil {
 | |
| 		return nil, nil, err
 | |
| 	}
 | |
| 
 | |
| 	comp := new(CommitsComparison)
 | |
| 	resp, err := s.client.Do(ctx, req, comp)
 | |
| 	if err != nil {
 | |
| 		return nil, resp, err
 | |
| 	}
 | |
| 
 | |
| 	return comp, resp, nil
 | |
| }
 |