Documentation ¶
Overview ¶
Package storage provides a simple interface to store and retrieve data from multiple data stores.
Index ¶
- Constants
- Variables
- func Count(ctx context.Context, s IStorage, target string, prm *count.Count, ...) (int64, error)
- func Create[T any](ctx context.Context, s IStorage, id, target string, t T, prm *create.Create, ...) (string, error)
- func CreateMany(ctx context.Context, m Map, id, target string, v any, prm *create.Create, ...) (map[string]string, error)
- func Delete(ctx context.Context, s IStorage, id, target string, prm *delete.Delete, ...) error
- func DeleteMany(ctx context.Context, m Map, id, target string, prm *delete.Delete, ...) error
- func List[T any](ctx context.Context, s IStorage, target string, prm *list.List, ...) (T, error)
- func ListMany[T any](ctx context.Context, m Map, target string, prm *list.List, ...) (map[string]T, error)
- func ParseToStruct(from, to any) error
- func Retrieve[T any](ctx context.Context, s IStorage, id, target string, prm *retrieve.Retrieve, ...) (T, error)
- func RetrieveMany[T any](ctx context.Context, m Map, id, target string, prm *retrieve.Retrieve, ...) (map[string]T, error)
- func Update[T any](ctx context.Context, s IStorage, id, target string, t T, prm *update.Update, ...) error
- func UpdateMany(ctx context.Context, m Map, id, target string, v any, prm *update.Update, ...) error
- type Func
- type HookFunc
- type IStorage
- type Map
- type Mock
- func (m *Mock) Count(ctx context.Context, target string, prm *count.Count, ...) (int64, error)
- func (m *Mock) Create(ctx context.Context, id, target string, v any, prm *create.Create, ...) (string, error)
- func (m *Mock) Delete(ctx context.Context, id, target string, prm *delete.Delete, ...) error
- func (m *Mock) GetClient() any
- func (m *Mock) GetCounterCounted() *expvar.Int
- func (m *Mock) GetCounterCountedFailed() *expvar.Int
- func (m *Mock) GetCounterCreated() *expvar.Int
- func (m *Mock) GetCounterCreatedFailed() *expvar.Int
- func (m *Mock) GetCounterDeleted() *expvar.Int
- func (m *Mock) GetCounterDeletedFailed() *expvar.Int
- func (m *Mock) GetCounterListed() *expvar.Int
- func (m *Mock) GetCounterListedFailed() *expvar.Int
- func (m *Mock) GetCounterPingFailed() *expvar.Int
- func (m *Mock) GetCounterRetrieved() *expvar.Int
- func (m *Mock) GetCounterRetrievedFailed() *expvar.Int
- func (m *Mock) GetCounterUpdated() *expvar.Int
- func (m *Mock) GetCounterUpdatedFailed() *expvar.Int
- func (m *Mock) GetLogger() sypl.ISypl
- func (m *Mock) GetName() string
- func (m *Mock) GetType() string
- func (m *Mock) List(ctx context.Context, target string, v any, prm *list.List, ...) error
- func (m *Mock) Retrieve(ctx context.Context, id, target string, v any, prm *retrieve.Retrieve, ...) error
- func (m *Mock) Update(ctx context.Context, id, target string, v any, prm *update.Update, ...) error
- type Operation
- type Options
- type Storage
- func (s *Storage) GetCounterCounted() *expvar.Int
- func (s *Storage) GetCounterCountedFailed() *expvar.Int
- func (s *Storage) GetCounterCreated() *expvar.Int
- func (s *Storage) GetCounterCreatedFailed() *expvar.Int
- func (s *Storage) GetCounterDeleted() *expvar.Int
- func (s *Storage) GetCounterDeletedFailed() *expvar.Int
- func (s *Storage) GetCounterListed() *expvar.Int
- func (s *Storage) GetCounterListedFailed() *expvar.Int
- func (s *Storage) GetCounterPingFailed() *expvar.Int
- func (s *Storage) GetCounterRetrieved() *expvar.Int
- func (s *Storage) GetCounterRetrievedFailed() *expvar.Int
- func (s *Storage) GetCounterUpdated() *expvar.Int
- func (s *Storage) GetCounterUpdatedFailed() *expvar.Int
- func (s *Storage) GetLogger() sypl.ISypl
- func (s *Storage) GetName() string
- func (s *Storage) GetType() string
Constants ¶
const ( DefaultMetricCounterLabel = "counter" Type = "storage" )
Type is the type of the entity regarding the framework. It is used to for example, to identify the entity in the logs, metrics, and for tracing.
Variables ¶
var ( // ErrRequiredPostHook is the error returned when the post-hook function is // missing. ErrRequiredPostHook = customerror.NewRequiredError("post-hook function", customerror.WithCode("ERR_REQUIRED_POST_HOOK")) // ErrRequiredPreHook is the error returned when the pre-hook function is // missing. ErrRequiredPreHook = customerror.NewRequiredError("pre-hook function", customerror.WithCode("ERR_REQUIRED_PRE_HOOK")) )
Functions ¶
func Count ¶ added in v0.0.28
func Count(ctx context.Context, s IStorage, target string, prm *count.Count, options ...Func[*count.Count]) (int64, error)
Count data.
func Create ¶ added in v0.0.28
func Create[T any](ctx context.Context, s IStorage, id, target string, t T, prm *create.Create, options ...Func[*create.Create]) (string, error)
Create data.
func CreateMany ¶ added in v0.0.20
func CreateMany(ctx context.Context, m Map, id, target string, v any, prm *create.Create, options ...Func[*create.Create]) (map[string]string, error)
CreateMany will make all DAL to concurrently create `v`.
func Delete ¶ added in v0.0.28
func Delete(ctx context.Context, s IStorage, id, target string, prm *delete.Delete, options ...Func[*delete.Delete]) error
Delete data.
func DeleteMany ¶ added in v0.0.20
func DeleteMany(ctx context.Context, m Map, id, target string, prm *delete.Delete, options ...Func[*delete.Delete]) error
DeleteMany will make all DAL to concurrently delete `id`.
func List ¶ added in v0.0.28
func List[T any](ctx context.Context, s IStorage, target string, prm *list.List, options ...Func[*list.List]) (T, error)
List data.
func ListMany ¶ added in v0.0.20
func ListMany[T any](ctx context.Context, m Map, target string, prm *list.List, options ...Func[*list.List]) (map[string]T, error)
ListMany will make all DAL to concurrently list.
func ParseToStruct ¶
ParseToStruct parses the given JSON (`from`) to struct (`to`).
func Retrieve ¶ added in v0.0.28
func Retrieve[T any](ctx context.Context, s IStorage, id, target string, prm *retrieve.Retrieve, options ...Func[*retrieve.Retrieve]) (T, error)
Retrieve data.
func RetrieveMany ¶ added in v0.0.20
func RetrieveMany[T any](ctx context.Context, m Map, id, target string, prm *retrieve.Retrieve, options ...Func[*retrieve.Retrieve]) (map[string]T, error)
RetrieveMany will make all DAL to concurrently retrieve `id`.
Types ¶
type Func ¶
Func allows to set options.
func WithPostHook ¶
WithPostHook set the post-hook function.
func WithPreHook ¶
WithPreHook set the pre-hook function.
type HookFunc ¶
type HookFunc[T any] func(ctx context.Context, strg IStorage, id, target string, data any, param T) error
HookFunc specifies the function that will be called before and after the operation.
type IStorage ¶
type IStorage interface { // Count data. Count(ctx context.Context, target string, prm *count.Count, options ...Func[*count.Count]) (int64, error) // Delete data. Delete(ctx context.Context, id, target string, prm *delete.Delete, options ...Func[*delete.Delete]) error // Retrieve data. Retrieve(ctx context.Context, id, target string, v any, prm *retrieve.Retrieve, options ...Func[*retrieve.Retrieve]) error // List data. List(ctx context.Context, target string, v any, prm *list.List, options ...Func[*list.List]) error // Create data. Create(ctx context.Context, id, target string, v any, prm *create.Create, options ...Func[*create.Create]) (string, error) // Update data. Update(ctx context.Context, id, target string, v any, prm *update.Update, options ...Func[*update.Update]) error // GetType returns its type. GetType() string // GetClient returns the storage client. Use that to interact with the // underlying storage client. GetClient() any // GetLogger returns the logger. GetLogger() sypl.ISypl // GetName returns the storage name. GetName() string // GetCounterCounted returns the metric. GetCounterCounted() *expvar.Int // GetCounterCountedFailed returns the metric. GetCounterCountedFailed() *expvar.Int // GetCounterDeleted returns the metric. GetCounterDeleted() *expvar.Int // GetCounterDeletedFailed returns the metric. GetCounterDeletedFailed() *expvar.Int // GetCounterRetrieved returns the metric. GetCounterRetrieved() *expvar.Int // GetCounterRetrievedFailed returns the metric. GetCounterRetrievedFailed() *expvar.Int // GetCounterListed returns the metric. GetCounterListed() *expvar.Int // GetCounterListedFailed returns the metric. GetCounterListedFailed() *expvar.Int // GetCounterPingFailed returns the metric. GetCounterPingFailed() *expvar.Int // GetCounterCreated returns the metric. GetCounterCreated() *expvar.Int // GetCounterCreatedFailed returns the metric. GetCounterCreatedFailed() *expvar.Int // GetCounterUpdated returns the metric. GetCounterUpdated() *expvar.Int // GetCounterUpdatedFailed returns the metric. GetCounterUpdatedFailed() *expvar.Int }
IStorage defines the data access layer interface.
The Data Access Layer (DAL) is generally more abstract and wider than the Data Access Object (DAO).
The DAL is responsible for providing a consistent and unified interface to access data from different data sources (such as databases, files, or web services) regardless of their underlying implementation details. It abstracts away the complexity of data access by providing a simple, unified interface that shields the rest of the application from the underlying data storage details.
On the other hand, the DAO is typically more specific to a particular data source, such as a particular database management system (such as MySQL or MongoDB) or a particular web service API. Its primary responsibility is to abstract away the details of the underlying data source and provide a simplified interface for performing CRUD (Create, Read, Update, Delete) operations on that data source.
So while both DAL and DAO are used to abstract away the complexities of data access, the DAL is generally wider and more abstract because it deals with multiple data sources, while the DAO is more specific and deals with a particular data source.
type Mock ¶
type Mock struct { // Count data. MockCount func(ctx context.Context, target string, prm *count.Count, options ...Func[*count.Count]) (int64, error) // Delete data. MockDelete func(ctx context.Context, id, target string, prm *delete.Delete, options ...Func[*delete.Delete]) error // Retrieve data. MockRetrieve func(ctx context.Context, id, target string, v any, prm *retrieve.Retrieve, options ...Func[*retrieve.Retrieve]) error // List data. MockList func(ctx context.Context, target string, v any, prm *list.List, options ...Func[*list.List]) error // Create data. MockCreate func(ctx context.Context, id, target string, v any, prm *create.Create, options ...Func[*create.Create]) (string, error) // Update data. MockUpdate func(ctx context.Context, id, target string, v any, prm *update.Update, options ...Func[*update.Update]) error // GetType returns its type. MockGetType func() string // GetClient returns the storage client. Use that to interact with the underlying storage client. MockGetClient func() any // GetLogger returns the logger. MockGetLogger func() sypl.ISypl // GetName returns the storage name. MockGetName func() string // GetCounterCounted returns the metric. MockGetCounterCounted func() *expvar.Int // GetCounterCountedFailed returns the metric. MockGetCounterCountedFailed func() *expvar.Int // GetCounterDeleted returns the metric. MockGetCounterDeleted func() *expvar.Int // GetCounterDeletedFailed returns the metric. MockGetCounterDeletedFailed func() *expvar.Int // GetCounterRetrieved returns the metric. MockGetCounterRetrieved func() *expvar.Int // GetCounterRetrievedFailed returns the metric. MockGetCounterRetrievedFailed func() *expvar.Int // GetCounterListed returns the metric. MockGetCounterListed func() *expvar.Int // GetCounterListedFailed returns the metric. MockGetCounterListedFailed func() *expvar.Int // GetCounterPingFailed returns the metric. MockGetCounterPingFailed func() *expvar.Int // GetCounterCreated returns the metric. MockGetCounterCreated func() *expvar.Int // GetCounterCreatedFailed returns the metric. MockGetCounterCreatedFailed func() *expvar.Int // GetCounterUpdated returns the metric. MockGetCounterUpdated func() *expvar.Int // GetCounterUpdatedFailed returns the metric. MockGetCounterUpdatedFailed func() *expvar.Int }
Mock is a struct which satisfies the storage.IStorage interface.
func (*Mock) Count ¶
func (m *Mock) Count(ctx context.Context, target string, prm *count.Count, options ...Func[*count.Count]) (int64, error)
Count data.
func (*Mock) Create ¶ added in v0.0.17
func (m *Mock) Create(ctx context.Context, id, target string, v any, prm *create.Create, options ...Func[*create.Create]) (string, error)
Create data.
func (*Mock) Delete ¶
func (m *Mock) Delete(ctx context.Context, id, target string, prm *delete.Delete, options ...Func[*delete.Delete]) error
Delete data.
func (*Mock) GetClient ¶
GetClient returns the storage client. Use that to interact with the underlying storage client.
func (*Mock) GetCounterCounted ¶ added in v0.0.17
GetCounterCounted returns the metric.
func (*Mock) GetCounterCountedFailed ¶ added in v0.0.17
GetCounterCountedFailed returns the metric.
func (*Mock) GetCounterCreated ¶ added in v0.0.17
GetCounterCreated returns the metric.
func (*Mock) GetCounterCreatedFailed ¶ added in v0.0.17
GetCounterCreatedFailed returns the metric.
func (*Mock) GetCounterDeleted ¶ added in v0.0.17
GetCounterDeleted returns the metric.
func (*Mock) GetCounterDeletedFailed ¶ added in v0.0.17
GetCounterDeletedFailed returns the metric.
func (*Mock) GetCounterListed ¶ added in v0.0.17
GetCounterListed returns the metric.
func (*Mock) GetCounterListedFailed ¶ added in v0.0.17
GetCounterListedFailed returns the metric.
func (*Mock) GetCounterPingFailed ¶ added in v0.0.17
GetCounterPingFailed returns the metric.
func (*Mock) GetCounterRetrieved ¶ added in v0.0.17
GetCounterRetrieved returns the metric.
func (*Mock) GetCounterRetrievedFailed ¶ added in v0.0.17
GetCounterRetrievedFailed returns the metric.
func (*Mock) GetCounterUpdated ¶ added in v0.0.17
GetCounterUpdated returns the metric.
func (*Mock) GetCounterUpdatedFailed ¶ added in v0.0.17
GetCounterUpdatedFailed returns the metric.
func (*Mock) List ¶
func (m *Mock) List(ctx context.Context, target string, v any, prm *list.List, options ...Func[*list.List]) error
List data.
type Options ¶
type Options[T any] struct { // PreHookFunc is the function which runs before the operation. PreHookFunc HookFunc[T] `json:"-"` // PostHookFunc is the function which runs after the operation. PostHookFunc HookFunc[T] `json:"-"` }
Options for operations.
type Storage ¶
type Storage struct { // Logger. Logger sypl.ISypl `json:"-" validate:"required"` // Name of the storage type. Name string `json:"name" validate:"required,lowercase,gte=1"` // contains filtered or unexported fields }
Storage definition.
func (*Storage) GetCounterCounted ¶ added in v0.0.15
GetCounterCounted returns the metric.
func (*Storage) GetCounterCountedFailed ¶ added in v0.0.15
GetCounterCountedFailed returns the metric.
func (*Storage) GetCounterCreated ¶ added in v0.0.15
GetCounterCreated returns the metric.
func (*Storage) GetCounterCreatedFailed ¶ added in v0.0.15
GetCounterCreatedFailed returns the metric.
func (*Storage) GetCounterDeleted ¶ added in v0.0.15
GetCounterDeleted returns the metric.
func (*Storage) GetCounterDeletedFailed ¶ added in v0.0.15
GetCounterDeletedFailed returns the metric.
func (*Storage) GetCounterListed ¶ added in v0.0.15
GetCounterListed returns the metric.
func (*Storage) GetCounterListedFailed ¶ added in v0.0.15
GetCounterListedFailed returns the metric.
func (*Storage) GetCounterPingFailed ¶ added in v0.0.15
GetCounterPingFailed returns the metric.
func (*Storage) GetCounterRetrieved ¶ added in v0.0.15
GetCounterRetrieved returns the metric.
func (*Storage) GetCounterRetrievedFailed ¶ added in v0.0.15
GetCounterRetrievedFailed returns the metric.
func (*Storage) GetCounterUpdated ¶ added in v0.0.15
GetCounterUpdated returns the metric.
func (*Storage) GetCounterUpdatedFailed ¶ added in v0.0.15
GetCounterUpdatedFailed returns the metric.