2019-01-09 13:35:25 +00:00
|
|
|
package storage
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"errors"
|
2019-03-05 20:54:32 +00:00
|
|
|
|
2020-03-12 18:32:52 +00:00
|
|
|
"github.com/influxdata/influxdb"
|
2019-03-06 00:18:04 +00:00
|
|
|
"github.com/influxdata/influxdb/kit/tracing"
|
2019-01-09 13:35:25 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// BucketDeleter defines the behaviour of deleting a bucket.
|
|
|
|
type BucketDeleter interface {
|
2020-03-12 18:32:52 +00:00
|
|
|
DeleteBucket(context.Context, influxdb.ID, influxdb.ID) error
|
2019-01-09 13:35:25 +00:00
|
|
|
}
|
|
|
|
|
2020-03-12 18:32:52 +00:00
|
|
|
// BucketService wraps an existing influxdb.BucketService implementation.
|
2019-01-09 13:35:25 +00:00
|
|
|
//
|
|
|
|
// BucketService ensures that when a bucket is deleted, all stored data
|
|
|
|
// associated with the bucket is either removed, or marked to be removed via a
|
|
|
|
// future compaction.
|
|
|
|
type BucketService struct {
|
2020-03-12 18:32:52 +00:00
|
|
|
inner influxdb.BucketService
|
2019-01-09 13:35:25 +00:00
|
|
|
engine BucketDeleter
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewBucketService returns a new BucketService for the provided BucketDeleter,
|
|
|
|
// which typically will be an Engine.
|
2020-03-12 18:32:52 +00:00
|
|
|
func NewBucketService(s influxdb.BucketService, engine BucketDeleter) *BucketService {
|
2019-01-09 13:35:25 +00:00
|
|
|
return &BucketService{
|
|
|
|
inner: s,
|
|
|
|
engine: engine,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// FindBucketByID returns a single bucket by ID.
|
2020-03-12 18:32:52 +00:00
|
|
|
func (s *BucketService) FindBucketByID(ctx context.Context, id influxdb.ID) (*influxdb.Bucket, error) {
|
2019-03-06 00:18:04 +00:00
|
|
|
span, ctx := tracing.StartSpanFromContext(ctx)
|
2019-03-05 00:38:10 +00:00
|
|
|
defer span.Finish()
|
|
|
|
|
2019-01-09 13:35:25 +00:00
|
|
|
if s.inner == nil || s.engine == nil {
|
|
|
|
return nil, errors.New("nil inner BucketService or Engine")
|
|
|
|
}
|
|
|
|
return s.inner.FindBucketByID(ctx, id)
|
|
|
|
}
|
|
|
|
|
2019-10-16 21:25:07 +00:00
|
|
|
// FindBucketByName returns a single bucket by name.
|
2020-03-12 18:32:52 +00:00
|
|
|
func (s *BucketService) FindBucketByName(ctx context.Context, orgID influxdb.ID, name string) (*influxdb.Bucket, error) {
|
2019-10-16 21:25:07 +00:00
|
|
|
span, ctx := tracing.StartSpanFromContext(ctx)
|
|
|
|
defer span.Finish()
|
|
|
|
|
|
|
|
if s.inner == nil || s.engine == nil {
|
|
|
|
return nil, errors.New("nil inner BucketService or Engine")
|
|
|
|
}
|
|
|
|
return s.inner.FindBucketByName(ctx, orgID, name)
|
|
|
|
}
|
|
|
|
|
2019-01-09 13:35:25 +00:00
|
|
|
// FindBucket returns the first bucket that matches filter.
|
2020-03-12 18:32:52 +00:00
|
|
|
func (s *BucketService) FindBucket(ctx context.Context, filter influxdb.BucketFilter) (*influxdb.Bucket, error) {
|
2019-03-06 00:18:04 +00:00
|
|
|
span, ctx := tracing.StartSpanFromContext(ctx)
|
2019-03-05 00:38:10 +00:00
|
|
|
defer span.Finish()
|
|
|
|
|
2019-01-09 13:35:25 +00:00
|
|
|
if s.inner == nil || s.engine == nil {
|
|
|
|
return nil, errors.New("nil inner BucketService or Engine")
|
|
|
|
}
|
|
|
|
return s.inner.FindBucket(ctx, filter)
|
|
|
|
}
|
|
|
|
|
|
|
|
// FindBuckets returns a list of buckets that match filter and the total count of matching buckets.
|
|
|
|
// Additional options provide pagination & sorting.
|
2020-03-12 18:32:52 +00:00
|
|
|
func (s *BucketService) FindBuckets(ctx context.Context, filter influxdb.BucketFilter, opt ...influxdb.FindOptions) ([]*influxdb.Bucket, int, error) {
|
2019-03-06 00:18:04 +00:00
|
|
|
span, ctx := tracing.StartSpanFromContext(ctx)
|
2019-03-05 00:38:10 +00:00
|
|
|
defer span.Finish()
|
|
|
|
|
2019-01-09 13:35:25 +00:00
|
|
|
if s.inner == nil || s.engine == nil {
|
|
|
|
return nil, 0, errors.New("nil inner BucketService or Engine")
|
|
|
|
}
|
|
|
|
return s.inner.FindBuckets(ctx, filter, opt...)
|
|
|
|
}
|
|
|
|
|
|
|
|
// CreateBucket creates a new bucket and sets b.ID with the new identifier.
|
2020-03-12 18:32:52 +00:00
|
|
|
func (s *BucketService) CreateBucket(ctx context.Context, b *influxdb.Bucket) error {
|
2019-03-06 00:18:04 +00:00
|
|
|
span, ctx := tracing.StartSpanFromContext(ctx)
|
2019-03-05 00:38:10 +00:00
|
|
|
defer span.Finish()
|
|
|
|
|
2019-01-09 13:35:25 +00:00
|
|
|
if s.inner == nil || s.engine == nil {
|
|
|
|
return errors.New("nil inner BucketService or Engine")
|
|
|
|
}
|
|
|
|
return s.inner.CreateBucket(ctx, b)
|
|
|
|
}
|
|
|
|
|
|
|
|
// UpdateBucket updates a single bucket with changeset.
|
|
|
|
// Returns the new bucket state after update.
|
2020-03-12 18:32:52 +00:00
|
|
|
func (s *BucketService) UpdateBucket(ctx context.Context, id influxdb.ID, upd influxdb.BucketUpdate) (*influxdb.Bucket, error) {
|
2019-03-06 00:18:04 +00:00
|
|
|
span, ctx := tracing.StartSpanFromContext(ctx)
|
2019-03-05 00:38:10 +00:00
|
|
|
defer span.Finish()
|
|
|
|
|
2019-01-09 13:35:25 +00:00
|
|
|
if s.inner == nil || s.engine == nil {
|
|
|
|
return nil, errors.New("nil inner BucketService or Engine")
|
|
|
|
}
|
|
|
|
return s.inner.UpdateBucket(ctx, id, upd)
|
|
|
|
}
|
|
|
|
|
|
|
|
// DeleteBucket removes a bucket by ID.
|
2020-03-12 18:32:52 +00:00
|
|
|
func (s *BucketService) DeleteBucket(ctx context.Context, bucketID influxdb.ID) error {
|
2019-03-06 00:18:04 +00:00
|
|
|
span, ctx := tracing.StartSpanFromContext(ctx)
|
2019-03-05 00:38:10 +00:00
|
|
|
defer span.Finish()
|
|
|
|
|
2019-01-09 13:35:25 +00:00
|
|
|
bucket, err := s.FindBucketByID(ctx, bucketID)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// The data is dropped first from the storage engine. If this fails for any
|
|
|
|
// reason, then the bucket will still be available in the future to retrieve
|
|
|
|
// the orgID, which is needed for the engine.
|
2019-08-21 15:46:43 +00:00
|
|
|
if err := s.engine.DeleteBucket(ctx, bucket.OrgID, bucketID); err != nil {
|
2019-01-09 13:35:25 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
return s.inner.DeleteBucket(ctx, bucketID)
|
|
|
|
}
|