Skip to content
Snippets Groups Projects
Commit c944d3ed authored by Pavel Antonov's avatar Pavel Antonov :asterisk:
Browse files

Merge branch 'feature/PRXS-951-1964-ZapCustomFields' into 'feature/PRXS-951-Log'

Добавлены собственные zap поля для работы с сервисом логирования

See merge request perxis/perxis-go!147
parents 2d7c6c72 6c0ecb0e
No related branches found
No related tags found
No related merge requests found
package zap
import (
"context"
"fmt"
"git.perx.ru/perxis/perxis-go/id"
"git.perx.ru/perxis/perxis-go/pkg/auth"
"go.uber.org/zap"
"go.uber.org/zap/zapcore"
)
const (
unknownObject = "unknown"
unknownCaller = "unknown"
)
func Category(category string) zapcore.Field {
return zap.String("category", category)
}
func Component(component string) zapcore.Field {
return zap.String("component", component)
}
func Event(event string) zapcore.Field {
return zap.String("event", event)
}
// Object возвращает поле и устанавливает передаваемый аргумент в качестве идентификатора объекта в формате ObjectID.
// Поддерживаемые типы: string, fmt.Stringer.
// Если передан аргумент другого типа, будет произведена попытка привести переданное значение к ObjectID.
func Object(v any) zapcore.Field {
var object = unknownObject
switch value := v.(type) {
case string:
object = value
case fmt.Stringer:
object = value.String()
default:
oid, err := id.FromObject(v)
if err == nil {
object = oid.String()
}
}
return zap.String("object", object)
}
// Caller возвращает поле и устанавливает передаваемый аргумент в качестве "вызывающего" в формате ObjectID.
// Поддерживаемые типы: string, fmt.Stringer.
// Если передан аргумент другого типа, будет произведена попытка привести переданное значение к ObjectID.
func Caller(v any) zapcore.Field {
var caller = unknownCaller
switch value := v.(type) {
case string:
caller = value
case fmt.Stringer:
caller = value.String()
default:
oid, err := id.FromObject(v)
if err == nil {
caller = oid.String()
}
}
return zap.String("caller", caller)
}
// CallerFromContext извлекает auth.Principal из контекста и устанавливает его в качестве "вызывающего" в формате ObjectID.
func CallerFromContext(ctx context.Context) zapcore.Field {
return Caller(auth.GetPrincipal(ctx))
}
func Attr(attr any) zapcore.Field {
return zap.Any("attr", attr)
}
func Tags(tags ...string) zapcore.Field {
return zap.Strings("tags", tags)
}
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment