Documentation ¶
Index ¶
- Constants
- type Config
- type Item
- type Plugin
- func (p *Plugin) Collects() []interface{}
- func (p *Plugin) GetAllStorageDrivers(name endure.Named, storage StorageDriver)
- func (p *Plugin) Init(cfg config.Configurer, log logger.Logger) error
- func (p *Plugin) Name() string
- func (p *Plugin) RPC() interface{}
- func (p *Plugin) Serve() chan error
- func (p *Plugin) Stop() error
- type Provider
- type Storage
- type StorageDriver
Constants ¶
View Source
const PluginName string = "kv"
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Config ¶ added in v2.1.0
type Config struct {
Data map[string]interface{} `mapstructure:"kv"`
}
type Item ¶
type Item struct { // Key of item Key string // Value of item Value string // live until time provided by TTL in RFC 3339 format TTL string }
Item represents general storage item
type Plugin ¶ added in v2.1.0
type Plugin struct {
// contains filtered or unexported fields
}
Plugin for the unified storage
func (*Plugin) Collects ¶ added in v2.1.0
func (p *Plugin) Collects() []interface{}
Collects will get all plugins which implement Storage interface
func (*Plugin) GetAllStorageDrivers ¶ added in v2.1.0
func (p *Plugin) GetAllStorageDrivers(name endure.Named, storage StorageDriver)
type Provider ¶ added in v2.1.0
type Provider interface { // Provide provides Storage based on the config key Provide(key string) (Storage, error) }
Provider provides storage based on the config
type Storage ¶
type Storage interface { // Has checks if value exists. Has(keys ...string) (map[string]bool, error) // Get loads value content into a byte slice. Get(key string) ([]byte, error) // MGet loads content of multiple values // Returns the map with existing keys and associated values MGet(keys ...string) (map[string]interface{}, error) // Set used to upload item to KV with TTL // 0 value in TTL means no TTL Set(items ...Item) error // MExpire sets the TTL for multiply keys MExpire(items ...Item) error // TTL return the rest time to live for provided keys // Not supported for the memcached and boltdb TTL(keys ...string) (map[string]interface{}, error) // Delete one or multiple keys. Delete(keys ...string) error }
Storage represents single abstract storage.
type StorageDriver ¶ added in v2.1.0
type StorageDriver interface { Provider }
StorageDriver interface provide storage
Click to show internal directories.
Click to hide internal directories.