Documentation ¶
Index ¶
- Constants
- Variables
- func NewTestBucket(t testing.TB, component string) (objstore.Bucket, func(), error)
- type Bucket
- func (b *Bucket) Attributes(ctx context.Context, name string) (objstore.ObjectAttributes, error)
- func (b *Bucket) Close() error
- func (b *Bucket) Delete(ctx context.Context, name string) error
- func (b *Bucket) Exists(ctx context.Context, name string) (bool, error)
- func (b *Bucket) Get(ctx context.Context, name string) (io.ReadCloser, error)
- func (b *Bucket) GetRange(ctx context.Context, name string, offset, length int64) (io.ReadCloser, error)
- func (b *Bucket) IsAccessDeniedErr(err error) bool
- func (b *Bucket) IsObjNotFoundErr(err error) bool
- func (b *Bucket) Iter(ctx context.Context, dir string, f func(string) error, ...) error
- func (b *Bucket) IterWithAttributes(ctx context.Context, dir string, ...) error
- func (b *Bucket) Name() string
- func (b *Bucket) Provider() objstore.ObjProvider
- func (b *Bucket) SupportedIterOptions() []objstore.IterOptionType
- func (b *Bucket) Upload(ctx context.Context, name string, r io.Reader) error
- type Config
- type HTTPConfig
- type PipelineConfig
- type ReaderConfig
Constants ¶
const DirDelim = "/"
DirDelim is the delimiter used to model a directory structure in an object store bucket.
Variables ¶
var DefaultConfig = Config{ Endpoint: "blob.core.windows.net", StorageCreateContainer: true, HTTPConfig: exthttp.HTTPConfig{ IdleConnTimeout: model.Duration(90 * time.Second), ResponseHeaderTimeout: model.Duration(2 * time.Minute), TLSHandshakeTimeout: model.Duration(10 * time.Second), ExpectContinueTimeout: model.Duration(1 * time.Second), MaxIdleConns: 100, MaxIdleConnsPerHost: 100, MaxConnsPerHost: 0, DisableCompression: false, }, }
DefaultConfig for Azure objstore client.
Functions ¶
Types ¶
type Bucket ¶
type Bucket struct {
// contains filtered or unexported fields
}
Bucket implements the store.Bucket interface against Azure APIs.
func NewBucket ¶
func NewBucket(logger log.Logger, azureConfig []byte, component string, wrapRoundtripper func(http.RoundTripper) http.RoundTripper) (*Bucket, error)
NewBucket returns a new Bucket using the provided Azure config.
func NewBucketWithConfig ¶
func NewBucketWithConfig(logger log.Logger, conf Config, component string, wrapRoundtripper func(http.RoundTripper) http.RoundTripper) (*Bucket, error)
NewBucketWithConfig returns a new Bucket using the provided Azure config struct.
func (*Bucket) Attributes ¶
Attributes returns information about the specified object.
func (*Bucket) GetRange ¶
func (b *Bucket) GetRange(ctx context.Context, name string, offset, length int64) (io.ReadCloser, error)
GetRange returns a new range reader for the given object name and range.
func (*Bucket) IsAccessDeniedErr ¶
IsAccessDeniedErr returns true if access to object is denied.
func (*Bucket) IsObjNotFoundErr ¶
IsObjNotFoundErr returns true if error means that object is not found. Relevant to Get operations.
func (*Bucket) Iter ¶
func (b *Bucket) Iter(ctx context.Context, dir string, f func(string) error, opts ...objstore.IterOption) error
Iter calls f for each entry in the given directory. The argument to f is the full object name including the prefix of the inspected directory.
func (*Bucket) IterWithAttributes ¶
func (b *Bucket) IterWithAttributes(ctx context.Context, dir string, f func(attrs objstore.IterObjectAttributes) error, options ...objstore.IterOption) error
func (*Bucket) Provider ¶
func (b *Bucket) Provider() objstore.ObjProvider
func (*Bucket) SupportedIterOptions ¶
func (b *Bucket) SupportedIterOptions() []objstore.IterOptionType
type Config ¶
type Config struct { StorageAccountName string `yaml:"storage_account"` StorageAccountKey string `yaml:"storage_account_key"` StorageConnectionString string `yaml:"storage_connection_string"` StorageCreateContainer bool `yaml:"storage_create_container"` ContainerName string `yaml:"container"` Endpoint string `yaml:"endpoint"` UserAssignedID string `yaml:"user_assigned_id"` MaxRetries int `yaml:"max_retries"` ReaderConfig ReaderConfig `yaml:"reader_config"` PipelineConfig PipelineConfig `yaml:"pipeline_config"` HTTPConfig exthttp.HTTPConfig `yaml:"http_config"` // Deprecated: Is automatically set by the Azure SDK. MSIResource string `yaml:"msi_resource"` }
Config Azure storage configuration.
type HTTPConfig ¶
type HTTPConfig = exthttp.HTTPConfig
HTTPConfig exists here only because Cortex depends on it, and we depend on Cortex. Deprecated. TODO(bwplotka): Remove it, once we remove Cortex cycle dep, or Cortex stops using this.
type PipelineConfig ¶
type ReaderConfig ¶
type ReaderConfig struct {
MaxRetryRequests int `yaml:"max_retry_requests"`
}