store

package
v0.0.0-...-d799dea Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 28, 2018 License: Apache-2.0 Imports: 6 Imported by: 5

Documentation

Index

Constants

View Source
const (
	// ETCD backend
	ETCD = "etcd"

	// ETCDV3 backend
	ETCDV3 = "etcdv3"

	// ZK backend
	ZK = "zk"
)
View Source
const (
	ActionPut    = "PUT"
	ActionDelete = "DELETE"
)

ActionXXX is the action definition of request.

Variables

View Source
var (
	// ErrBackendNotSupported is thrown when the backend k/v store is not supported by kvstore
	ErrBackendNotSupported = errors.New("Backend storage not supported yet, please choose one of")
	// ErrCallNotSupported is thrown when a method is not implemented/supported by the current backend
	ErrCallNotSupported = errors.New("The current call is not supported with this backend")
	// ErrNotReachable is thrown when the API cannot be reached for issuing common store operations
	ErrNotReachable = errors.New("Api not reachable")
	// ErrCannotLock is thrown when there is an error acquiring a lock on a key
	ErrCannotLock = errors.New("Error acquiring the lock")
	// ErrKeyModified is thrown during an atomic operation if the index does not match the one in the store
	ErrKeyModified = errors.New("Unable to complete atomic operation, key modified")
	// ErrKeyNotFound is thrown when the key is not found in the store during a Get operation
	ErrKeyNotFound = errors.New("Key not found in store")
	// ErrPreviousNotSpecified is thrown when the previous value is not specified for an atomic operation
	ErrPreviousNotSpecified = errors.New("Previous K/V pair should be provided for the Atomic operation")
	// ErrKeyExists is thrown when the previous value exists in the case of an AtomicPut
	ErrKeyExists = errors.New("Previous K/V pair exists, cannot complete Atomic operation")
	// ErrWatchFail is thrown when the watch fail or response channel closed
	ErrWatchFail = errors.New("Some error occurred when watch or response channel was closed")
)

Functions

func CreateEndpoints

func CreateEndpoints(addrs []string, scheme string) (entries []string)

CreateEndpoints creates a list of endpoints given the right scheme

func GetDirectory

func GetDirectory(key string) string

GetDirectory gets the full directory part of the key to the form:

/path/to/

func Normalize

func Normalize(key string) string

Normalize the key for each store to the form:

/path/to/key

func SplitKey

func SplitKey(key string) (path []string)

SplitKey splits the key to extract path informations

Types

type ClientTLSConfig

type ClientTLSConfig struct {
	CertFile   string
	KeyFile    string
	CACertFile string
}

ClientTLSConfig contains data for a Client TLS configuration in the form the etcd client wants it. Eventually we'll adapt it for ZK and Consul.

type Config

type Config struct {
	ClientTLS         *ClientTLSConfig
	TLS               *tls.Config
	ConnectionTimeout time.Duration
	Bucket            string
	PersistConnection bool
	Username          string
	Password          string
}

Config contains the options for a storage client

type KVPair

type KVPair struct {
	Key   string
	Value string
	Index uint64

	// only for etcdv3
	Version uint64
	Lease   uint64
}

KVPair represents {Key, Value} tuple

func (*KVPair) String

func (kv *KVPair) String() string

type LockOptions

type LockOptions struct {
	Value     string        // Optional, value to associate with the lock
	TTL       time.Duration // Optional, expiration ttl associated with the lock
	RenewLock chan struct{} // Optional, chan used to control and stop the session ttl renewal for the lock
}

LockOptions contains optional request parameters

type Locker

type Locker interface {
	Lock(ctx context.Context) error
	Unlock(ctx context.Context) error
}

Locker provides lock mechanism

type OpResponse

type OpResponse struct {
	Pairs []*KVPair // fill on Get/List
}

OpResponse will be returned when transaction commit.

type Store

type Store interface {
	// Put a value at the specified key
	Put(ctx context.Context, key, value string, options *WriteOptions) error

	// Get a value given its key
	Get(ctx context.Context, key string) (*KVPair, error)

	// Delete the value at the specified key
	Delete(ctx context.Context, key string) error

	// Verify if a Key exists in the store
	Exists(ctx context.Context, key string) (bool, error)

	// Update is an alias for Put with key exist
	Update(ctx context.Context, key, value string, opts *WriteOptions) error

	// Create is an alias for Put with key not exist
	Create(ctx context.Context, key, value string, opts *WriteOptions) error

	// Watch for changes on a key
	Watch(ctx context.Context, key string, opt *WatchOptions) (<-chan *WatchResponse, error)

	// WatchTree watches for changes on child nodes under
	// a given directory
	WatchTree(ctx context.Context, directory string, opt *WatchOptions) (<-chan *WatchResponse, error)

	// NewLock creates a lock for a given key.
	// The returned Locker is not held and must be acquired
	// with `.Lock`. The Value is optional.
	NewLock(key string, opt *LockOptions) Locker

	// List the content of a given prefix
	List(ctx context.Context, directory string) ([]*KVPair, error)

	// DeleteTree deletes a range of keys under a given directory
	DeleteTree(ctx context.Context, directory string) error

	// Atomic CAS operation on a single value.
	// Pass previous = nil to create a new key.
	AtomicPut(ctx context.Context, key, value string, previous *KVPair, options *WriteOptions) error

	// Atomic delete of a single value
	AtomicDelete(ctx context.Context, key string, previous *KVPair) error

	// Compact compacts etcd KV history before the given rev.
	Compact(ctx context.Context, rev uint64, wait bool) error

	// NewTxn creates a transaction Txn.
	NewTxn(ctx context.Context) (Txn, error)

	// Close the store connection
	Close()
}

Store represents the backend K/V storage Each store should support every call listed here. Or it couldn't be implemented as a K/V backend for kvstore

type Txn

type Txn interface {
	Begin()
	Commit() (*TxnResponse, error)

	// compare operation. Operator should only be "=" "!=" ">" "<".
	IfValue(key, operator, value string)
	IfVersion(key, operator string, version uint64)
	IfCreateRevision(key, operator string, revision uint64)
	IfModifyRevision(key, operator string, revision uint64)

	// create operation
	Put(key, value string, options *WriteOptions)
	Get(key string)
	List(dir string)
	Delete(key string)
	DeleteTree(key string)

	// default operation execute when compare success.
	// If you want to execute when compare fail, you
	// should call "Else", all operation after "Else" will
	// execute when compare fail.
	Else()
}

Txn provides transaction interface.

type TxnResponse

type TxnResponse struct {
	CompareSuccess bool
	Revision       uint64
	Responses      []*OpResponse
}

TxnResponse will be returned when transaction commit.

func (*TxnResponse) String

func (t *TxnResponse) String() string

type WatchOptions

type WatchOptions struct {
	Index uint64
}

WatchOptions contains optional request parameters

type WatchResponse

type WatchResponse struct {
	Error   error
	Action  string
	PreNode *KVPair
	Node    *KVPair
}

WatchResponse will be returned when watch event happen.

func (*WatchResponse) String

func (wr *WatchResponse) String() string

type WriteOptions

type WriteOptions struct {
	IsDir bool // useless in etcdv3
	TTL   time.Duration
}

WriteOptions contains optional request parameters

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL