Skip to content
Snippets Groups Projects
Select Git revision
  • 51517e17cdac7accb5548f8320c21c10e6cf603c
  • master default protected
  • feature/PRXS-3156-SaveRevision
  • PRXS-3421-RecursiveReferences
  • feature/PRXS-NotifyAttachment
  • feature/PRXS-3170-TemplateFuncsFix
  • feature/PRXS-3143-3235-ReferenceOptions
  • feature/PRXS-1869-SuperUser
  • feature/PRXS-3106-NoCache
  • release/0.33
  • feature/2781-SpacesLoggingMiddleware
  • feature/PRXS-3143-LimitReferenceFields
  • feature/PRXS-3234-FeaturePruneIdents
  • feature/3109-SerializeFeature
  • 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
  • v0.34.0
  • v0.33.2
  • 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
41 results

logging_middleware.go

Blame
  • logging_middleware.go 2.19 KiB
    package middleware
    
    import (
    	"context"
    
    	"git.perx.ru/perxis/perxis-go/id"
    	"git.perx.ru/perxis/perxis-go/pkg/locales"
    	logzap "git.perx.ru/perxis/perxis-go/zap"
    	"go.uber.org/zap"
    )
    
    type loggingMiddleware struct {
    	logger *zap.Logger
    	next   locales.Locales
    }
    
    func LoggingMiddleware(logger *zap.Logger) Middleware {
    	return func(next locales.Locales) locales.Locales {
    		return &loggingMiddleware{
    			next:   next,
    			logger: logger.With(logzap.Component("Locales")),
    		}
    	}
    }
    
    func (m *loggingMiddleware) Create(ctx context.Context, locale *locales.Locale) (created *locales.Locale, err error) {
    	logger := m.logger.With(
    		logzap.Caller(ctx),
    		logzap.Event(locales.EventCreate),
    	)
    
    	created, err = m.next.Create(ctx, locale)
    	if err != nil {
    		logger.Error("Failed to create", zap.Error(err), logzap.Channels(logzap.Userlog, logzap.Syslog), logzap.Object(locale))
    		return
    	}
    
    	logger.Info("Locale created", logzap.Channels(logzap.Userlog), logzap.Object(created))
    	return created, err
    }
    
    func (m *loggingMiddleware) Update(ctx context.Context, locale *locales.Locale) (err error) {
    	logger := m.logger.With(
    		logzap.Caller(ctx),
    		logzap.Event(locales.EventUpdate),
    		logzap.Object(locale),
    	)
    
    	err = m.next.Update(ctx, locale)
    	if err != nil {
    		logger.Error("Failed to update", zap.Error(err), logzap.Channels(logzap.Userlog, logzap.Syslog))
    		return
    	}
    
    	logger.Info("Locale updated", logzap.Channels(logzap.Userlog))
    	return err
    }
    
    func (m *loggingMiddleware) List(ctx context.Context, spaceId string) (locales []*locales.Locale, err error) {
    	logger := m.logger.With(
    		logzap.Caller(ctx),
    	)
    
    	locales, err = m.next.List(ctx, spaceId)
    	if err != nil {
    		logger.Error("Failed to list", zap.Error(err))
    		return
    	}
    
    	return locales, err
    }
    
    func (m *loggingMiddleware) Delete(ctx context.Context, spaceId, localeId string) (err error) {
    	logger := m.logger.With(
    		logzap.Caller(ctx),
    		logzap.Event(locales.EventDelete),
    		logzap.Object(id.NewLocaleId(spaceId, localeId)),
    	)
    
    	err = m.next.Delete(ctx, spaceId, localeId)
    	if err != nil {
    		logger.Error("Failed to delete", zap.Error(err), logzap.Channels(logzap.Userlog, logzap.Syslog))
    		return
    	}
    
    	logger.Info("Locale deleted", logzap.Channels(logzap.Userlog))
    	return err
    }