// Copyright 2021 The Gitea Authors. All rights reserved. // Use of this source code is governed by a MIT-style // license that can be found in the LICENSE file. package utils import ( "fmt" "net/http" "code.gitea.io/gitea/modules/context" "code.gitea.io/gitea/modules/git" ) // ResolveRefOrSha resolve ref to sha if exist func ResolveRefOrSha(ctx *context.APIContext, ref string) string { if len(ref) == 0 { ctx.Error(http.StatusBadRequest, "ref not given", nil) return "" } // Search branches and tags for _, refType := range []string{"heads", "tags"} { refSHA, lastMethodName, err := searchRefCommitByType(ctx, refType, ref) if err != nil { ctx.Error(http.StatusInternalServerError, lastMethodName, err) return "" } if refSHA != "" { return refSHA } } return MustConvertToSHA1(ctx.Context, ref) } // GetGitRefs return git references based on filter func GetGitRefs(ctx *context.APIContext, filter string) ([]*git.Reference, string, error) { if ctx.Repo.GitRepo == nil { return nil, "", fmt.Errorf("no open git repo found in context") } if len(filter) > 0 { filter = "refs/" + filter } refs, err := ctx.Repo.GitRepo.GetRefsFiltered(filter) return refs, "GetRefsFiltered", err } func searchRefCommitByType(ctx *context.APIContext, refType, filter string) (string, string, error) { refs, lastMethodName, err := GetGitRefs(ctx, refType+"/"+filter) // Search by type if err != nil { return "", lastMethodName, err } if len(refs) > 0 { return refs[0].Object.String(), "", nil // Return found SHA } return "", "", nil } // ConvertToSHA1 returns a full-length SHA1 from a potential ID string func ConvertToSHA1(ctx *context.Context, commitID string) (git.SHA1, error) { if len(commitID) == git.SHAFullLength && git.IsValidSHAPattern(commitID) { sha1, err := git.NewIDFromString(commitID) if err == nil { return sha1, nil } } gitRepo, closer, err := git.RepositoryFromContextOrOpen(ctx, ctx.Repo.Repository.RepoPath()) if err != nil { return git.SHA1{}, fmt.Errorf("RepositoryFromContextOrOpen: %w", err) } defer closer.Close() return gitRepo.ConvertToSHA1(commitID) } // MustConvertToSHA1 returns a full-length SHA1 string from a potential ID string, or returns origin input if it can't convert to SHA1 func MustConvertToSHA1(ctx *context.Context, commitID string) string { sha, err := ConvertToSHA1(ctx, commitID) if err != nil { return commitID } return sha.String() }