driver

package
v0.1.0 Latest Latest
Warning

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

Go to latest
Published: Nov 16, 2022 License: Apache-2.0 Imports: 1 Imported by: 3

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Config

type Config interface {
	// UnmarshalKey takes the value corresponding to the passed key and unmarshals it into the passed structure
	UnmarshalKey(key string, rawVal interface{}) error
}

Config provides access to the underlying configuration

type Driver

type Driver interface {
	// NewVersioned returns a new VersionedPersistence for the passed data source and config
	NewVersioned(sp view.ServiceProvider, dataSourceName string, config Config) (VersionedPersistence, error)
	// New returns a new Persistence for the passed data source and config
	New(sp view.ServiceProvider, dataSourceName string, config Config) (Persistence, error)
}

type Persistence

type Persistence interface {
	// SetState sets the given value for the given namespace and key
	SetState(namespace, key string, value []byte) error
	// GetState gets the value for given namespace and key
	GetState(namespace, key string) ([]byte, error)
	// DeleteState deletes the given namespace and key
	DeleteState(namespace, key string) error
	// GetStateRangeScanIterator returns an iterator that contains all the key-values between given key ranges.
	// startKey is included in the results and endKey is excluded. An empty startKey refers to the first available key
	// and an empty endKey refers to the last available key. For scanning all the keys, both the startKey and the endKey
	// can be supplied as empty strings. However, a full scan should be used judiciously for performance reasons.
	// The returned ResultsIterator contains results of type *Read.
	GetStateRangeScanIterator(namespace string, startKey string, endKey string) (ResultsIterator, error)
	// Close closes this persistence instance
	Close() error
	// BeginUpdate starts the session
	BeginUpdate() error
	// Commit commits the changes since BeginUpdate
	Commit() error
	// Discard discards the changes since BeginUpdate
	Discard() error
}

Persistence models a key-value storage place

type Read

type Read struct {
	Key string
	Raw []byte
}

type ResultsIterator

type ResultsIterator interface {
	// Next returns the next item in the result set. The `QueryResult` is expected to be nil when
	// the iterator gets exhausted
	Next() (*Read, error)
	// Close releases resources occupied by the iterator
	Close()
}

type VersionedPersistence

type VersionedPersistence interface {
	// SetState sets the given value for the given namespace, key, and version
	SetState(namespace, key string, value []byte, block, txnum uint64) error
	// GetState gets the value and version for given namespace and key
	GetState(namespace, key string) ([]byte, uint64, uint64, error)
	// DeleteState deletes the given namespace and key
	DeleteState(namespace, key string) error
	// GetStateMetadata gets the metadata and version for given namespace and key
	GetStateMetadata(namespace, key string) (map[string][]byte, uint64, uint64, error)
	// SetStateMetadata sets the given metadata for the given namespace, key, and version
	SetStateMetadata(namespace, key string, metadata map[string][]byte, block, txnum uint64) error
	// GetStateRangeScanIterator returns an iterator that contains all the key-values between given key ranges.
	// startKey is included in the results and endKey is excluded. An empty startKey refers to the first available key
	// and an empty endKey refers to the last available key. For scanning all the keys, both the startKey and the endKey
	// can be supplied as empty strings. However, a full scan should be used judiciously for performance reasons.
	// The returned VersionedResultsIterator contains results of type *VersionedRead.
	GetStateRangeScanIterator(namespace string, startKey string, endKey string) (VersionedResultsIterator, error)
	// Close closes this persistence instance
	Close() error
	// BeginUpdate starts the session
	BeginUpdate() error
	// Commit commits the changes since BeginUpdate
	Commit() error
	// Discard discanrds the changes since BeginUpdate
	Discard() error
}

VersionedPersistence models a versioned key-value storage place

type VersionedRead

type VersionedRead struct {
	Key          string
	Raw          []byte
	Block        uint64
	IndexInBlock int
}

func (*VersionedRead) K

func (v *VersionedRead) K() string

func (*VersionedRead) V

func (v *VersionedRead) V() []byte

type VersionedResultsIterator

type VersionedResultsIterator interface {
	// Next returns the next item in the result set. The `QueryResult` is expected to be nil when
	// the iterator gets exhausted
	Next() (*VersionedRead, error)
	// Close releases resources occupied by the iterator
	Close()
}

Directories

Path Synopsis
mock
Code generated by counterfeiter.
Code generated by counterfeiter.
mocks
Code generated by counterfeiter.
Code generated by counterfeiter.

Jump to

Keyboard shortcuts

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