2020-10-09 14:40:12 +01:00
|
|
|
// Copyright (C) 2020 Storj Labs, Inc.
|
|
|
|
// See LICENSE for copying information.
|
|
|
|
|
|
|
|
package console
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
|
|
|
"storj.io/common/macaroon"
|
|
|
|
"storj.io/common/storj"
|
|
|
|
"storj.io/common/uuid"
|
2021-04-21 13:42:57 +01:00
|
|
|
"storj.io/storj/satellite/metabase"
|
2020-10-09 14:40:12 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
// Buckets is the interface for the database to interact with buckets.
|
|
|
|
//
|
|
|
|
// architecture: Database
|
|
|
|
type Buckets interface {
|
|
|
|
// Create creates a new bucket.
|
|
|
|
CreateBucket(ctx context.Context, bucket storj.Bucket) (_ storj.Bucket, err error)
|
|
|
|
// Get returns an existing bucket.
|
|
|
|
GetBucket(ctx context.Context, bucketName []byte, projectID uuid.UUID) (bucket storj.Bucket, err error)
|
|
|
|
// GetBucketID returns an existing bucket id.
|
|
|
|
GetBucketID(ctx context.Context, bucket metabase.BucketLocation) (id uuid.UUID, err error)
|
|
|
|
// UpdateBucket updates an existing bucket.
|
|
|
|
UpdateBucket(ctx context.Context, bucket storj.Bucket) (_ storj.Bucket, err error)
|
|
|
|
// Delete deletes a bucket.
|
|
|
|
DeleteBucket(ctx context.Context, bucketName []byte, projectID uuid.UUID) (err error)
|
|
|
|
// List returns all buckets for a project.
|
|
|
|
ListBuckets(ctx context.Context, projectID uuid.UUID, listOpts storj.BucketListOptions, allowedBuckets macaroon.AllowedBuckets) (bucketList storj.BucketList, err error)
|
|
|
|
// CountBuckets returns the number of buckets a project currently has.
|
|
|
|
CountBuckets(ctx context.Context, projectID uuid.UUID) (int, error)
|
|
|
|
}
|