File: gitlab_logger.go

package info (click to toggle)
gitlab-shell 14.35.0%2Bds1-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 23,652 kB
  • sloc: ruby: 1,129; makefile: 583; sql: 391; sh: 384
file content (43 lines) | stat: -rw-r--r-- 1,203 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
// Package lfstransfer wraps https://github.com/charmbracelet/git-lfs-transfer logic
package lfstransfer

import (
	"context"

	"gitlab.com/gitlab-org/labkit/log"
)

// WrappedLoggerForGitLFSTransfer is responsible for creating a compatible logger
// for github.com/charmbracelet/git-lfs-transfer
type WrappedLoggerForGitLFSTransfer struct {
	ctx context.Context
}

// NewWrappedLoggerForGitLFSTransfer returns a new WrappedLoggerForGitLFSTransfer
// passing through context.Context
func NewWrappedLoggerForGitLFSTransfer(ctx context.Context) *WrappedLoggerForGitLFSTransfer {
	return &WrappedLoggerForGitLFSTransfer{ctx: ctx}
}

// Log allows logging in github.com/charmbracelet/git-lfs-transfer to take place
// using gitlab.com/gitlab-org/labkit/log
func (l *WrappedLoggerForGitLFSTransfer) Log(msg string, args ...interface{}) {
	fields := make(map[string]interface{})
	fieldsFallback := map[string]interface{}{"args": args}

	for i := 0; i < len(args); i += 2 {
		if i >= len(args)-1 {
			fields = fieldsFallback
			break
		}

		if arg, ok := args[i].(string); ok {
			fields[arg] = args[i+1]
		} else {
			fields = fieldsFallback
			break
		}
	}

	log.WithContextFields(l.ctx, fields).Info(msg)
}