Documentation ¶
Overview ¶
Package s3 implements the AWS S3 storage.
Index ¶
- Constants
- func Get() storage.IStorage
- func Set(s storage.IStorage)
- type Config
- type ResponseListKeys
- type S3
- func (s *S3) Count(ctx context.Context, target string, prm *count.Count, ...) (int64, error)
- func (s *S3) Create(ctx context.Context, id, target string, v any, prm *create.Create, ...) (string, error)
- func (s *S3) Delete(ctx context.Context, id, target string, prm *delete.Delete, ...) error
- func (s *S3) GetClient() any
- func (s *S3) List(ctx context.Context, target string, v any, prm *list.List, ...) error
- func (s *S3) Retrieve(ctx context.Context, id, target string, v any, prm *retrieve.Retrieve, ...) error
- func (s *S3) Update(ctx context.Context, id, target string, v any, prm *update.Update, ...) error
Constants ¶
View Source
const Name = "s3"
Name of the storage.
Variables ¶
This section is empty.
Functions ¶
Types ¶
type ResponseListKeys ¶
type ResponseListKeys struct {
Keys []string `json:"keys"`
}
ResponseListKeys is the response from the Redis list SCAN command.
type S3 ¶
type S3 struct { *storage.Storage Bucket string `json:"bucket" validate:"required,gt=0"` // Client is the S3 client. Client *s3.S3 `json:"-" validate:"required"` // Config is the S3 configuration. Config *Config `json:"-"` // Target allows to set a static target. If it is empty, the target will be // dynamic - the one set at the operation (count, create, delete, etc) time. // Depending on the storage, target is a collection, a table, a bucket, etc. // For ElasticSearch, for example it doesn't have a concept of a database - // the target then is the index. Due to different cases of ElasticSearch // usage, the target can be static or dynamic - defined at the index time, // for example: log-{YYYY}-{MM}. For S3, it isn't used at all. Target string `json:"-" validate:"omitempty,gt=0"` }
S3 storage definition.
func (*S3) Count ¶
func (s *S3) Count(ctx context.Context, target string, prm *count.Count, options ...storage.Func[*count.Count]) (int64, error)
Count returns the number of items in the storage.
func (*S3) Create ¶
func (s *S3) Create(ctx context.Context, id, target string, v any, prm *create.Create, options ...storage.Func[*create.Create]) (string, error)
Create data.
NOTE: Not all storages returns the ID, neither all storages requires `id` to be set. You are better off setting the ID yourself.
func (*S3) Delete ¶
func (s *S3) Delete(ctx context.Context, id, target string, prm *delete.Delete, options ...storage.Func[*delete.Delete]) error
Delete removes data.
func (*S3) List ¶
func (s *S3) List(ctx context.Context, target string, v any, prm *list.List, options ...storage.Func[*list.List]) error
List data.
NOTE: It uses params.List.Search to query the data.
NOTE: S3 does not support the concept of "offset" and "limit" in the same way that a traditional SQL database does.
Click to show internal directories.
Click to hide internal directories.