2020-03-17 19:23:00 +00:00
|
|
|
package tenant
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
2020-04-03 17:39:20 +00:00
|
|
|
"github.com/influxdata/influxdb/v2"
|
|
|
|
"github.com/influxdata/influxdb/v2/kv"
|
2020-03-17 19:23:00 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// FindBucketByID returns a single bucket by ID.
|
|
|
|
func (s *Service) FindBucketByID(ctx context.Context, id influxdb.ID) (*influxdb.Bucket, error) {
|
|
|
|
var bucket *influxdb.Bucket
|
|
|
|
err := s.store.View(ctx, func(tx kv.Tx) error {
|
|
|
|
b, err := s.store.GetBucket(ctx, tx, id)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
bucket = b
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return bucket, nil
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Service) FindBucketByName(ctx context.Context, orgID influxdb.ID, name string) (*influxdb.Bucket, error) {
|
|
|
|
var bucket *influxdb.Bucket
|
|
|
|
err := s.store.View(ctx, func(tx kv.Tx) error {
|
|
|
|
b, err := s.store.GetBucketByName(ctx, tx, orgID, name)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
bucket = b
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return bucket, nil
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
// FindBucket returns the first bucket that matches filter.
|
|
|
|
func (s *Service) FindBucket(ctx context.Context, filter influxdb.BucketFilter) (*influxdb.Bucket, error) {
|
2020-05-12 22:00:38 +00:00
|
|
|
if filter.ID != nil {
|
|
|
|
return s.FindBucketByID(ctx, *filter.ID)
|
|
|
|
}
|
|
|
|
|
|
|
|
if filter.Name != nil && filter.OrganizationID != nil {
|
|
|
|
return s.FindBucketByName(ctx, *filter.OrganizationID, *filter.Name)
|
|
|
|
}
|
|
|
|
|
2020-03-17 19:23:00 +00:00
|
|
|
buckets, _, err := s.FindBuckets(ctx, filter, influxdb.FindOptions{
|
|
|
|
Limit: 1,
|
|
|
|
})
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2020-04-23 14:32:50 +00:00
|
|
|
if len(buckets) < 1 {
|
|
|
|
return nil, ErrBucketNotFound
|
2020-03-17 19:23:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return buckets[0], nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// FindBuckets returns a list of buckets that match filter and the total count of matching buckets.
|
|
|
|
// Additional options provide pagination & sorting.
|
|
|
|
func (s *Service) FindBuckets(ctx context.Context, filter influxdb.BucketFilter, opt ...influxdb.FindOptions) ([]*influxdb.Bucket, int, error) {
|
|
|
|
if filter.ID != nil {
|
|
|
|
b, err := s.FindBucketByID(ctx, *filter.ID)
|
|
|
|
if err != nil {
|
|
|
|
return nil, 0, err
|
|
|
|
}
|
|
|
|
return []*influxdb.Bucket{b}, 1, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
var buckets []*influxdb.Bucket
|
|
|
|
err := s.store.View(ctx, func(tx kv.Tx) error {
|
|
|
|
if filter.OrganizationID == nil && filter.Org != nil {
|
|
|
|
org, err := s.store.GetOrgByName(ctx, tx, *filter.Org)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
filter.OrganizationID = &org.ID
|
|
|
|
}
|
|
|
|
|
2020-05-22 15:30:14 +00:00
|
|
|
if filter.Name != nil && filter.OrganizationID != nil {
|
|
|
|
b, err := s.store.GetBucketByName(ctx, tx, *filter.OrganizationID, *filter.Name)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
buckets = []*influxdb.Bucket{b}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2020-03-17 19:23:00 +00:00
|
|
|
bs, err := s.store.ListBuckets(ctx, tx, BucketFilter{
|
|
|
|
Name: filter.Name,
|
|
|
|
OrganizationID: filter.OrganizationID,
|
|
|
|
}, opt...)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
buckets = bs
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, 0, err
|
|
|
|
}
|
|
|
|
|
2020-04-23 14:32:50 +00:00
|
|
|
if len(opt) > 0 && len(buckets) >= opt[0].Limit {
|
|
|
|
// if we have reached the limit we will not add system buckets
|
|
|
|
return buckets, len(buckets), nil
|
|
|
|
}
|
|
|
|
|
2020-05-26 21:36:01 +00:00
|
|
|
// if a name is provided dont fill in system buckets
|
|
|
|
if filter.Name != nil {
|
|
|
|
return buckets, len(buckets), nil
|
|
|
|
}
|
|
|
|
|
2020-04-02 09:01:44 +00:00
|
|
|
// NOTE: this is a remnant of the old system.
|
|
|
|
// There are org that do not have system buckets stored, but still need to be displayed.
|
2020-03-27 21:31:35 +00:00
|
|
|
needsSystemBuckets := true
|
|
|
|
for _, b := range buckets {
|
|
|
|
if b.Type == influxdb.BucketTypeSystem {
|
|
|
|
needsSystemBuckets = false
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if needsSystemBuckets {
|
|
|
|
tb := &influxdb.Bucket{
|
|
|
|
ID: influxdb.TasksSystemBucketID,
|
|
|
|
Type: influxdb.BucketTypeSystem,
|
|
|
|
Name: influxdb.TasksSystemBucketName,
|
|
|
|
RetentionPeriod: influxdb.TasksSystemBucketRetention,
|
|
|
|
Description: "System bucket for task logs",
|
|
|
|
}
|
|
|
|
|
|
|
|
buckets = append(buckets, tb)
|
|
|
|
|
|
|
|
mb := &influxdb.Bucket{
|
|
|
|
ID: influxdb.MonitoringSystemBucketID,
|
|
|
|
Type: influxdb.BucketTypeSystem,
|
|
|
|
Name: influxdb.MonitoringSystemBucketName,
|
|
|
|
RetentionPeriod: influxdb.MonitoringSystemBucketRetention,
|
|
|
|
Description: "System bucket for monitoring logs",
|
|
|
|
}
|
|
|
|
|
|
|
|
buckets = append(buckets, mb)
|
|
|
|
}
|
|
|
|
|
2020-03-17 19:23:00 +00:00
|
|
|
return buckets, len(buckets), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// CreateBucket creates a new bucket and sets b.ID with the new identifier.
|
|
|
|
func (s *Service) CreateBucket(ctx context.Context, b *influxdb.Bucket) error {
|
|
|
|
if !b.OrgID.Valid() {
|
|
|
|
// we need a valid org id
|
|
|
|
return ErrOrgNotFound
|
|
|
|
}
|
|
|
|
|
|
|
|
return s.store.Update(ctx, func(tx kv.Tx) error {
|
|
|
|
// make sure the org exists
|
|
|
|
if _, err := s.store.GetOrg(ctx, tx, b.OrgID); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2020-04-06 21:58:15 +00:00
|
|
|
return s.store.CreateBucket(ctx, tx, b)
|
2020-03-17 19:23:00 +00:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
// UpdateBucket updates a single bucket with changeset.
|
|
|
|
// Returns the new bucket state after update.
|
|
|
|
func (s *Service) UpdateBucket(ctx context.Context, id influxdb.ID, upd influxdb.BucketUpdate) (*influxdb.Bucket, error) {
|
|
|
|
var bucket *influxdb.Bucket
|
|
|
|
err := s.store.Update(ctx, func(tx kv.Tx) error {
|
|
|
|
b, err := s.store.UpdateBucket(ctx, tx, id, upd)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
bucket = b
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return bucket, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// DeleteBucket removes a bucket by ID.
|
|
|
|
func (s *Service) DeleteBucket(ctx context.Context, id influxdb.ID) error {
|
|
|
|
return s.store.Update(ctx, func(tx kv.Tx) error {
|
|
|
|
bucket, err := s.store.GetBucket(ctx, tx, id)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if bucket.Type == influxdb.BucketTypeSystem {
|
|
|
|
// TODO: I think we should allow bucket deletes but maybe im wrong.
|
|
|
|
return errDeleteSystemBucket
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := s.store.DeleteBucket(ctx, tx, id); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return s.removeResourceRelations(ctx, tx, id)
|
|
|
|
})
|
|
|
|
}
|