// Copyright 2023 Harness, Inc. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. package repo import ( "context" "io" "strings" apiauth "github.com/harness/gitness/app/api/auth" "github.com/harness/gitness/app/api/usererror" "github.com/harness/gitness/app/auth" "github.com/harness/gitness/gitrpc" "github.com/harness/gitness/types" "github.com/harness/gitness/types/enum" ) func (c *Controller) RawDiff( ctx context.Context, session *auth.Session, repoRef string, path string, w io.Writer, ) error { repo, err := c.getRepoCheckAccess(ctx, session, repoRef, enum.PermissionRepoView, true) if err != nil { return err } info, err := parseDiffPath(path) if err != nil { return err } return c.gitRPCClient.RawDiff(ctx, &gitrpc.DiffParams{ ReadParams: CreateRPCReadParams(repo), BaseRef: info.BaseRef, HeadRef: info.HeadRef, MergeBase: info.MergeBase, }, w) } func (c *Controller) CommitDiff( ctx context.Context, session *auth.Session, repoRef string, sha string, w io.Writer, ) error { repo, err := c.getRepoCheckAccess(ctx, session, repoRef, enum.PermissionRepoView, true) if err != nil { return err } return c.gitRPCClient.CommitDiff(ctx, &gitrpc.GetCommitParams{ ReadParams: CreateRPCReadParams(repo), SHA: sha, }, w) } type CompareInfo struct { BaseRef string HeadRef string MergeBase bool } func parseDiffPath(path string) (CompareInfo, error) { infos := strings.SplitN(path, "...", 2) if len(infos) != 2 { infos = strings.SplitN(path, "..", 2) } if len(infos) != 2 { return CompareInfo{}, usererror.BadRequestf("invalid format \"%s\"", path) } return CompareInfo{ BaseRef: infos[0], HeadRef: infos[1], MergeBase: strings.Contains(path, "..."), }, nil } func (c *Controller) DiffStats( ctx context.Context, session *auth.Session, repoRef string, path string, ) (types.DiffStats, error) { repo, err := c.repoStore.FindByRef(ctx, repoRef) if err != nil { return types.DiffStats{}, err } if err = apiauth.CheckRepo(ctx, c.authorizer, session, repo, enum.PermissionRepoView, false); err != nil { return types.DiffStats{}, err } info, err := parseDiffPath(path) if err != nil { return types.DiffStats{}, err } output, err := c.gitRPCClient.DiffStats(ctx, &gitrpc.DiffParams{ ReadParams: gitrpc.CreateRPCReadParams(repo), BaseRef: info.BaseRef, HeadRef: info.HeadRef, MergeBase: info.MergeBase, }) if err != nil { return types.DiffStats{}, err } return types.DiffStats{ Commits: output.Commits, FilesChanged: output.FilesChanged, }, nil } func (c *Controller) Diff( ctx context.Context, session *auth.Session, repoRef string, path string, includePatch bool, ) (types.Stream[*gitrpc.FileDiff], error) { repo, err := c.repoStore.FindByRef(ctx, repoRef) if err != nil { return nil, err } if err = apiauth.CheckRepo(ctx, c.authorizer, session, repo, enum.PermissionRepoView, false); err != nil { return nil, err } info, err := parseDiffPath(path) if err != nil { return nil, err } reader := gitrpc.NewStreamReader(c.gitRPCClient.Diff(ctx, &gitrpc.DiffParams{ ReadParams: gitrpc.CreateRPCReadParams(repo), BaseRef: info.BaseRef, HeadRef: info.HeadRef, MergeBase: info.MergeBase, IncludePatch: includePatch, })) return reader, nil }