Skip to content
Snippets Groups Projects
Select Git revision
  • a6f365cb565f6455f951ca5b72446082b2230892
  • master default protected
  • feature/PRXS-1869-SuperUser
  • fix/PRXS-3121-SaveFileInfo
  • feature/PRXS-3106-NoCache
  • feature/PRXS-3043-NewURLFormat
  • feature/2781-SpacesLoggingMiddleware
  • feature/PRXS-2974-FillImageDimensions
  • feature/PRXS-3143-3235-ReferenceOptions
  • feature/PRXS-3056-LocalesFromToMap
  • feature/PRXS-3421-ImplementNewRefAPI
  • feature/PRXS-3143-LimitReferenceFields
  • feature/PRXS-3234-FeaturePruneIdents
  • PRXS-3421-RecursiveReferences
  • 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
  • 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

error_logging_middleware.go

Blame
  • client.go 2.10 KiB
    package account
    
    import (
    	"time"
    
    	"git.perx.ru/perxis/perxis-go/pkg/cache"
    	serviceMembers "git.perx.ru/perxis/perxis-go/pkg/members/middleware"
    	membersObserverTransport "git.perx.ru/perxis/perxis-go/pkg/members/observer/transport/grpc"
    	membersTransport "git.perx.ru/perxis/perxis-go/pkg/members/transport/grpc"
    	serviceOrganizations "git.perx.ru/perxis/perxis-go/pkg/organizations/middleware"
    	organizationsTransport "git.perx.ru/perxis/perxis-go/pkg/organizations/transport/grpc"
    	serviceUsers "git.perx.ru/perxis/perxis-go/pkg/users/middleware"
    	usersTransport "git.perx.ru/perxis/perxis-go/pkg/users/transport/grpc"
    	"go.uber.org/zap"
    	"google.golang.org/grpc"
    )
    
    const (
    	DefaultCacheSize = 1000
    	DefaultCacheTTL  = time.Second * 10
    )
    
    func NewClient(conn *grpc.ClientConn, opts ...Option) *Account {
    
    	client := &Account{}
    	c := &config{}
    
    	for _, o := range opts {
    		o(c)
    
    	}
    
    	if c.logger == nil {
    		c.logger = zap.NewNop()
    	}
    
    	client.Members = membersTransport.NewClient(conn, c.clientOptions...)
    	client.Organizations = organizationsTransport.NewClient(conn, c.clientOptions...)
    	client.Users = usersTransport.NewClient(conn, c.clientOptions...)
    	client.MembersObserver = membersObserverTransport.NewClient(conn, c.clientOptions...)
    
    	if !c.noCache {
    		client = WithCaching(client, DefaultCacheSize, DefaultCacheTTL)
    	}
    
    	if !c.noLog {
    		client = WithLogging(client, c.logger, c.accessLog)
    	}
    
    	return client
    }
    
    func WithCaching(client *Account, size int, ttl time.Duration) *Account {
    	c := *client
    
    	c.Members = serviceMembers.CachingMiddleware(cache.NewMemoryCache(size, ttl))(client.Members)
    	c.Organizations = serviceOrganizations.CachingMiddleware(cache.NewMemoryCache(size, ttl))(client.Organizations)
    	c.Users = serviceUsers.CachingMiddleware(cache.NewMemoryCache(size, ttl))(client.Users)
    
    	return &c
    }
    
    func WithLogging(client *Account, logger *zap.Logger, accessLog bool) *Account {
    	c := *client
    
    	c.Members = serviceMembers.WithLog(c.Members, logger, accessLog)
    	c.Organizations = serviceOrganizations.WithLog(c.Organizations, logger, accessLog)
    	c.Users = serviceUsers.WithLog(c.Users, logger, accessLog)
    
    	return &c
    }