123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237 |
- // 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"
- "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"`
- }
- 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
- }
- // TODO: remove custom Accept header when this API fully launches.
- req.Header.Set("Accept", mediaTypeGitSigningPreview)
- 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
- }
- // TODO: remove custom Accept header when this API fully launches.
- req.Header.Set("Accept", mediaTypeGitSigningPreview)
- 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, 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/index.html#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
- }
|