Skip to content
Snippets Groups Projects
Select Git revision
  • c3c51afff6e53092165c2b238a463995012393c4
  • master default protected
  • bugfix/fix-return-var-in-find
  • feature/upgrade2
  • v1.11.0
  • v1.10.0
  • v1.8.2
  • v1.8.1
  • v1.8.0
  • 1.7.3
  • v1.7.1
  • v1.6.1
  • v1.6.0
  • v1.5.0
  • v1.4.1
  • v1.3.0
  • v1.2.2
  • v1.2.1
  • v1.2.0
  • v1.0.1
  • v1.0.0
  • v0.0.23
  • v0.0.17
  • v0.0.10
24 results

__init__.py

Blame
  • field.go 2.41 KiB
    package zap
    
    import (
    	"context"
    
    	"git.perx.ru/perxis/perxis-go/id"
    	_ "git.perx.ru/perxis/perxis-go/id/system" // регистрируем обработчики для системных объектов
    	"git.perx.ru/perxis/perxis-go/pkg/auth"
    	"go.uber.org/zap"
    	"go.uber.org/zap/zapcore"
    )
    
    type StringArray []string
    
    func (ss StringArray) MarshalLogArray(arr zapcore.ArrayEncoder) error {
    	for i := range ss {
    		arr.AppendString(ss[i])
    	}
    	return nil
    }
    
    // Channels возвращает поле, содержащее список каналов, в которые должна быть передана запись.
    func Channels(channels ...string) zap.Field {
    	return zap.Field{
    		Key:       channelKey,
    		Type:      zapcore.SkipType, // используем тип zapcore.SkipType, чтобы при кодировании поле игнорировалось
    		Interface: StringArray(channels),
    	}
    }
    
    func Category(category string) zap.Field {
    	return zap.String("category", category)
    }
    
    func Component(component string) zap.Field {
    	return zap.String("component", component)
    }
    
    func Event(event string) zap.Field {
    	return zap.String("event", event)
    }
    
    // Object возвращает поле и устанавливает передаваемый аргумент в качестве идентификатора объекта в формате ObjectId.
    // Поддерживает типы в формате ObjectId: id.Descriptor, string, map[string]any, системные объекты.
    func Object(v any) zap.Field {
    	oid, _ := id.NewObjectId(v)
    	return zap.Reflect("object", oid)
    }
    
    // Caller возвращает поле и устанавливает передаваемый аргумент в качестве "вызывающего" в формате ObjectId.
    // Поддерживает типы в формате ObjectId: id.Descriptor, string, map[string]any, системные объекты.
    func Caller(v any) zap.Field {
    	oid, _ := id.NewObjectId(v)
    	return zap.Reflect("caller", oid)
    }
    
    // CallerFromContext извлекает auth.Principal из контекста и устанавливает его в качестве "вызывающего" в формате Object.
    func CallerFromContext(ctx context.Context) zap.Field {
    	return Caller(auth.GetPrincipal(ctx))
    }
    
    func Attr(attr any) zap.Field {
    	return zap.Reflect("attr", attr)
    }
    
    func Tags(tags ...string) zap.Field {
    	return zap.Array("tags", StringArray(tags))
    }