101 lines
3.0 KiB
Go
101 lines
3.0 KiB
Go
package tenant
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"time"
|
|
|
|
"github.com/influxdata/influxdb/v2"
|
|
"go.uber.org/zap"
|
|
)
|
|
|
|
type OrgLogger struct {
|
|
logger *zap.Logger
|
|
orgService influxdb.OrganizationService
|
|
}
|
|
|
|
// NewOrgLogger returns a logging service middleware for the Organization Service.
|
|
func NewOrgLogger(log *zap.Logger, s influxdb.OrganizationService) *OrgLogger {
|
|
return &OrgLogger{
|
|
logger: log,
|
|
orgService: s,
|
|
}
|
|
}
|
|
|
|
var _ influxdb.OrganizationService = (*OrgLogger)(nil)
|
|
|
|
func (l *OrgLogger) CreateOrganization(ctx context.Context, u *influxdb.Organization) (err error) {
|
|
defer func(start time.Time) {
|
|
dur := zap.Duration("took", time.Since(start))
|
|
if err != nil {
|
|
l.logger.Debug("failed to create org", zap.Error(err), dur)
|
|
return
|
|
}
|
|
l.logger.Debug("org create", dur)
|
|
}(time.Now())
|
|
return l.orgService.CreateOrganization(ctx, u)
|
|
}
|
|
|
|
func (l *OrgLogger) FindOrganizationByID(ctx context.Context, id influxdb.ID) (u *influxdb.Organization, err error) {
|
|
defer func(start time.Time) {
|
|
dur := zap.Duration("took", time.Since(start))
|
|
if err != nil {
|
|
msg := fmt.Sprintf("failed to find org with ID %v", id)
|
|
l.logger.Debug(msg, zap.Error(err), dur)
|
|
return
|
|
}
|
|
l.logger.Debug("org find by ID", dur)
|
|
}(time.Now())
|
|
return l.orgService.FindOrganizationByID(ctx, id)
|
|
}
|
|
|
|
func (l *OrgLogger) FindOrganization(ctx context.Context, filter influxdb.OrganizationFilter) (u *influxdb.Organization, err error) {
|
|
defer func(start time.Time) {
|
|
dur := zap.Duration("took", time.Since(start))
|
|
if err != nil {
|
|
l.logger.Debug("failed to find org matching the given filter", zap.Error(err), dur)
|
|
return
|
|
}
|
|
l.logger.Debug("org find", dur)
|
|
|
|
}(time.Now())
|
|
return l.orgService.FindOrganization(ctx, filter)
|
|
}
|
|
|
|
func (l *OrgLogger) FindOrganizations(ctx context.Context, filter influxdb.OrganizationFilter, opt ...influxdb.FindOptions) (orgs []*influxdb.Organization, n int, err error) {
|
|
defer func(start time.Time) {
|
|
dur := zap.Duration("took", time.Since(start))
|
|
if err != nil {
|
|
l.logger.Debug("failed to find org matching the given filter", zap.Error(err), dur)
|
|
return
|
|
}
|
|
l.logger.Debug("orgs find", dur)
|
|
}(time.Now())
|
|
return l.orgService.FindOrganizations(ctx, filter, opt...)
|
|
}
|
|
|
|
func (l *OrgLogger) UpdateOrganization(ctx context.Context, id influxdb.ID, upd influxdb.OrganizationUpdate) (u *influxdb.Organization, err error) {
|
|
defer func(start time.Time) {
|
|
dur := zap.Duration("took", time.Since(start))
|
|
if err != nil {
|
|
l.logger.Debug("failed to update org", zap.Error(err), dur)
|
|
return
|
|
}
|
|
l.logger.Debug("org update", dur)
|
|
}(time.Now())
|
|
return l.orgService.UpdateOrganization(ctx, id, upd)
|
|
}
|
|
|
|
func (l *OrgLogger) DeleteOrganization(ctx context.Context, id influxdb.ID) (err error) {
|
|
defer func(start time.Time) {
|
|
dur := zap.Duration("took", time.Since(start))
|
|
if err != nil {
|
|
msg := fmt.Sprintf("failed to delete org with ID %v", id)
|
|
l.logger.Debug(msg, zap.Error(err), dur)
|
|
return
|
|
}
|
|
l.logger.Debug("org delete", dur)
|
|
}(time.Now())
|
|
return l.orgService.DeleteOrganization(ctx, id)
|
|
}
|