123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 |
- package repo
- import (
- "net/http"
- "strings"
- "time"
- "github.com/gogs/git-module"
- api "github.com/gogs/go-gogs-client"
- "gogs.io/gogs/internal/conf"
- "gogs.io/gogs/internal/context"
- "gogs.io/gogs/internal/db"
- "gogs.io/gogs/internal/gitutil"
- )
- func GetSingleCommit(c *context.APIContext) {
- if strings.Contains(c.Req.Header.Get("Accept"), api.MediaApplicationSHA) {
- c.SetParams("*", c.Params(":sha"))
- GetReferenceSHA(c)
- return
- }
- gitRepo, err := git.Open(c.Repo.Repository.RepoPath())
- if err != nil {
- c.Error(err, "open repository")
- return
- }
- commit, err := gitRepo.CatFileCommit(c.Params(":sha"))
- if err != nil {
- c.NotFoundOrError(gitutil.NewError(err), "get commit")
- return
- }
-
- var apiAuthor, apiCommitter *api.User
- author, err := db.GetUserByEmail(commit.Author.Email)
- if err != nil && !db.IsErrUserNotExist(err) {
- c.Error(err, "get user by author email")
- return
- } else if err == nil {
- apiAuthor = author.APIFormat()
- }
-
- if commit.Committer.Email == commit.Author.Email {
- apiCommitter = apiAuthor
- } else {
- committer, err := db.GetUserByEmail(commit.Committer.Email)
- if err != nil && !db.IsErrUserNotExist(err) {
- c.Error(err, "get user by committer email")
- return
- } else if err == nil {
- apiCommitter = committer.APIFormat()
- }
- }
-
- apiParents := make([]*api.CommitMeta, commit.ParentsCount())
- for i := 0; i < commit.ParentsCount(); i++ {
- sha, _ := commit.ParentID(i)
- apiParents[i] = &api.CommitMeta{
- URL: c.BaseURL + "/repos/" + c.Repo.Repository.FullName() + "/commits/" + sha.String(),
- SHA: sha.String(),
- }
- }
- c.JSONSuccess(&api.Commit{
- CommitMeta: &api.CommitMeta{
- URL: conf.Server.ExternalURL + c.Link[1:],
- SHA: commit.ID.String(),
- },
- HTMLURL: c.Repo.Repository.HTMLURL() + "/commits/" + commit.ID.String(),
- RepoCommit: &api.RepoCommit{
- URL: conf.Server.ExternalURL + c.Link[1:],
- Author: &api.CommitUser{
- Name: commit.Author.Name,
- Email: commit.Author.Email,
- Date: commit.Author.When.Format(time.RFC3339),
- },
- Committer: &api.CommitUser{
- Name: commit.Committer.Name,
- Email: commit.Committer.Email,
- Date: commit.Committer.When.Format(time.RFC3339),
- },
- Message: commit.Summary(),
- Tree: &api.CommitMeta{
- URL: c.BaseURL + "/repos/" + c.Repo.Repository.FullName() + "/tree/" + commit.ID.String(),
- SHA: commit.ID.String(),
- },
- },
- Author: apiAuthor,
- Committer: apiCommitter,
- Parents: apiParents,
- })
- }
- func GetReferenceSHA(c *context.APIContext) {
- gitRepo, err := git.Open(c.Repo.Repository.RepoPath())
- if err != nil {
- c.Error(err, "open repository")
- return
- }
- ref := c.Params("*")
- refType := 0
- if strings.HasPrefix(ref, git.RefsHeads) {
- ref = strings.TrimPrefix(ref, git.RefsHeads)
- refType = 1
- } else if strings.HasPrefix(ref, git.RefsTags) {
- ref = strings.TrimPrefix(ref, git.RefsTags)
- refType = 2
- } else {
- if gitRepo.HasBranch(ref) {
- refType = 1
- } else if gitRepo.HasTag(ref) {
- refType = 2
- } else {
- c.NotFound()
- return
- }
- }
- var sha string
- if refType == 1 {
- sha, err = gitRepo.BranchCommitID(ref)
- } else if refType == 2 {
- sha, err = gitRepo.TagCommitID(ref)
- }
- if err != nil {
- c.NotFoundOrError(gitutil.NewError(err), "get reference commit ID")
- return
- }
- c.PlainText(http.StatusOK, sha)
- }
|