Skip to content
Snippets Groups Projects
Select Git revision
  • f9169554a5c162449d3150d5d4da87b2ac38ec4d
  • master default protected
  • feature/PRXS-2974-FillImageDimensions
  • docs/PRXS-2972-HugoModules
  • refactor/PRXS-3053-FilesFixSubmodule
  • feature/PRXS-3421-3426-AddAPI
  • docs/3247-PerxisWebCDN
  • docs/3247-СDNReleaseNotes
  • feature/PRXS-3421-RecursiveReferences
  • feature/3146-UpdateItemStorageInterface
  • feature/3180-RemoveOldHugo
  • feature/3264-FixExtracTranslationsArrays
  • feature/3274-ObjectIndexesFixes
  • feature/2931-AllowPartialDecode
  • feature/3055-ItemsRestAPI
  • feature/3082-gitlab-triage
  • feature/3055-LogsRestAPI
  • feature/2985-add-preset-settings
  • feature/2929-MultiInvitationFix
  • feature/2929-MultiInvitation
  • docs/2889-HugoModules
  • v0.27.0
  • v0.21.0
  • v0.19.0
  • v0.20.0
25 results

extension.proto

Blame
  • field.go 2.36 KiB
    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)
    }