gitlabhq/gitlab-shell

View on GitHub
internal/command/gitauditevent/audit.go

Summary

Maintainability
A
35 mins
Test Coverage
package gitauditevent

import (
    "context"

    pb "gitlab.com/gitlab-org/gitaly/v16/proto/go/gitalypb"
    "gitlab.com/gitlab-org/gitlab-shell/v14/internal/command/commandargs"
    "gitlab.com/gitlab-org/gitlab-shell/v14/internal/command/shared/accessverifier"
    "gitlab.com/gitlab-org/gitlab-shell/v14/internal/config"
    "gitlab.com/gitlab-org/gitlab-shell/v14/internal/gitlabnet/gitauditevent"
    "gitlab.com/gitlab-org/labkit/log"
)

// Audit is called conditionally during `git-receive-pack` and `git-upload-pack` to generate streaming audit events.
// Errors are not propagated since this is more a logging process.
func Audit(ctx context.Context, commandType commandargs.CommandType, c *config.Config, response *accessverifier.Response, packfileStats *pb.PackfileNegotiationStatistics) {
    ctxlog := log.WithContextFields(ctx, log.Fields{
        "gl_repository": response.Repo,
        "command":       commandType,
        "username":      response.Username,
    })

    ctxlog.Debug("sending git audit event")

    gitAuditClient, errOnlyLog := gitauditevent.NewClient(c)
    if errOnlyLog != nil {
        ctxlog.Errorf("failed to create gitauditevent client: %v", errOnlyLog)
        return
    }

    errOnlyLog = gitAuditClient.Audit(ctx, response.Username, commandType, response.Repo, packfileStats)
    if errOnlyLog != nil {
        ctxlog.Errorf("failed to audit git event: %v", errOnlyLog)
        return
    }
}