2019-02-19 23:47:19 +00:00
|
|
|
package kv
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2019-05-16 15:30:36 +00:00
|
|
|
"time"
|
2019-02-19 23:47:19 +00:00
|
|
|
|
2019-03-05 20:54:32 +00:00
|
|
|
"go.uber.org/zap"
|
|
|
|
|
2019-02-19 23:47:19 +00:00
|
|
|
"github.com/influxdata/influxdb"
|
|
|
|
"github.com/influxdata/influxdb/rand"
|
|
|
|
"github.com/influxdata/influxdb/snowflake"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
_ influxdb.UserService = (*Service)(nil)
|
|
|
|
)
|
|
|
|
|
|
|
|
// OpPrefix is the prefix for kv errors.
|
|
|
|
const OpPrefix = "kv/"
|
|
|
|
|
|
|
|
// Service is the struct that influxdb services are implemented on.
|
|
|
|
type Service struct {
|
|
|
|
kv Store
|
|
|
|
Logger *zap.Logger
|
2019-05-15 17:16:47 +00:00
|
|
|
Config ServiceConfig
|
2019-02-19 23:47:19 +00:00
|
|
|
|
2019-09-07 23:00:26 +00:00
|
|
|
IDGenerator influxdb.IDGenerator
|
|
|
|
|
|
|
|
// special ID generator that never returns bytes with backslash,
|
|
|
|
// comma, or space. Used to support very specific encoding of org &
|
|
|
|
// bucket into the old measurement in storage.
|
|
|
|
OrgBucketIDs influxdb.IDGenerator
|
|
|
|
|
2019-02-19 23:47:19 +00:00
|
|
|
TokenGenerator influxdb.TokenGenerator
|
2019-04-19 19:46:58 +00:00
|
|
|
influxdb.TimeGenerator
|
|
|
|
Hash Crypt
|
2019-02-19 23:47:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// NewService returns an instance of a Service.
|
2019-05-15 17:16:47 +00:00
|
|
|
func NewService(kv Store, configs ...ServiceConfig) *Service {
|
|
|
|
s := &Service{
|
2019-09-07 23:00:26 +00:00
|
|
|
Logger: zap.NewNop(),
|
|
|
|
IDGenerator: snowflake.NewIDGenerator(),
|
|
|
|
// Seed the random number generator with the current time
|
|
|
|
OrgBucketIDs: rand.NewOrgBucketID(time.Now().UnixNano()),
|
2019-02-19 23:47:19 +00:00
|
|
|
TokenGenerator: rand.NewTokenGenerator(64),
|
|
|
|
Hash: &Bcrypt{},
|
|
|
|
kv: kv,
|
2019-04-19 19:46:58 +00:00
|
|
|
TimeGenerator: influxdb.RealTimeGenerator{},
|
2019-02-19 23:47:19 +00:00
|
|
|
}
|
2019-05-15 17:16:47 +00:00
|
|
|
|
|
|
|
if len(configs) > 0 {
|
|
|
|
s.Config = configs[0]
|
|
|
|
} else {
|
|
|
|
s.Config.SessionLength = influxdb.DefaultSessionLength
|
|
|
|
}
|
|
|
|
|
|
|
|
return s
|
|
|
|
}
|
|
|
|
|
|
|
|
// ServiceConfig allows us to configure Services
|
|
|
|
type ServiceConfig struct {
|
|
|
|
SessionLength time.Duration
|
2019-02-19 23:47:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Initialize creates Buckets needed.
|
|
|
|
func (s *Service) Initialize(ctx context.Context) error {
|
2019-03-05 00:38:10 +00:00
|
|
|
return s.kv.Update(ctx, func(tx Tx) error {
|
2019-02-19 23:47:19 +00:00
|
|
|
if err := s.initializeAuths(ctx, tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2019-03-04 17:41:24 +00:00
|
|
|
if err := s.initializeDocuments(ctx, tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2019-02-19 23:47:19 +00:00
|
|
|
if err := s.initializeBuckets(ctx, tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := s.initializeDashboards(ctx, tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := s.initializeKVLog(ctx, tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := s.initializeLabels(ctx, tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := s.initializeOnboarding(ctx, tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := s.initializeOrgs(ctx, tx); err != nil {
|
|
|
|
return err
|
2019-04-09 22:52:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if err := s.initializeTasks(ctx, tx); err != nil {
|
|
|
|
return err
|
2019-02-19 23:47:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if err := s.initializePasswords(ctx, tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := s.initializeScraperTargets(ctx, tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := s.initializeSecrets(ctx, tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := s.initializeSessions(ctx, tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := s.initializeSources(ctx, tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := s.initializeTelegraf(ctx, tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := s.initializeURMs(ctx, tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := s.initializeVariables(ctx, tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2019-07-19 17:43:29 +00:00
|
|
|
if err := s.initializeChecks(ctx, tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2019-07-24 02:46:42 +00:00
|
|
|
if err := s.initializeNotificationRule(ctx, tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2019-08-09 15:25:07 +00:00
|
|
|
if err := s.initializeNotificationEndpoint(ctx, tx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2019-02-19 23:47:19 +00:00
|
|
|
return s.initializeUsers(ctx, tx)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
// WithStore sets kv store for the service.
|
|
|
|
// Should only be used in tests for mocking.
|
|
|
|
func (s *Service) WithStore(store Store) {
|
|
|
|
s.kv = store
|
|
|
|
}
|
2019-09-07 23:00:26 +00:00
|
|
|
|
|
|
|
// WithSpecialOrgBucketIDs sets the generator for the org
|
|
|
|
// and bucket ids.
|
|
|
|
//
|
|
|
|
// Should only be used in tests for mocking.
|
|
|
|
func (s *Service) WithSpecialOrgBucketIDs(gen influxdb.IDGenerator) {
|
|
|
|
s.OrgBucketIDs = gen
|
|
|
|
}
|