Skip to content
Snippets Groups Projects
Select Git revision
  • cb2f77c0f81a4ebe605176ccba7e1774a1574ad1
  • master default protected
  • fix/PRXS-3401-ValidateValidationOpts
  • feature/PRXS-3383-CollectionsRankSortAPI
  • feature/3149-LocaleCodeAsID-Feature
  • feature/PRXS-3383-CollectionsSort
  • feature/3109-SerializeFeature
  • release/0.33
  • feature/3109-RecoverySchema
  • feature/3109-feature
  • fix/PRXS-3369-ValidateFields
  • refactor/PRXS-3306-MovePkgGroup1
  • refactor/6-pkg-refactor-expr
  • fix/PRXS-3360-TemplateBuilderPatch
  • feature/3293-MongoV2
  • feature/3272-GoVersionUp
  • feature/PRXS-3218-HideTemplateActions
  • feature/PRXS-3234-PruneIdents
  • feature/3146-UpdateItemStorageInterface
  • feature/3274-ObjectIndexesFixes
  • feature/PRXS-3143-3235-ReferenceOptions
  • v0.33.1
  • v0.32.0
  • v0.31.1
  • v0.31.0
  • v0.30.0
  • v0.29.0
  • v0.28.0
  • v0.27.0-alpha.1+16
  • v0.27.0-alpha.1+15
  • v0.27.0-alpha.1+14
  • v0.27.0-alpha.1+13
  • v0.27.0-alpha.1+12
  • v0.27.0-alpha.1+11
  • v0.27.0-alpha.1+10
  • v0.27.0-alpha.1+9
  • v0.27.0-alpha.1+8
  • v0.27.0-alpha.1+7
  • v0.27.0-alpha.1+6
  • v0.27.0-alpha.1+5
  • v0.27.0-alpha.1+4
41 results

field.go

Blame
  • user avatar
    Semyon Krestyaninov authored
    cb2f77c0
    History
    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)
    }