Documentation ¶
Overview ¶
Package database provides a database for lings.
Overview ¶
This package provides a database layer to store and retrieve data in a simple and efficient manner.
The current backend is ffldb, which makes use of leveldb, flat files, and strict checksums in key areas to ensure data integrity.
Implementors of additional backends are required to implement the following interfaces:
DataAccessor ¶
This defines the common interface by which data gets accessed in a generic lings database. Both the Database and the Transaction interfaces (see below) implement it.
Database ¶
This defines the interface of a database that can begin transactions and close itself.
Transaction ¶
This defines the interface of a generic lings database transaction. Note: transactions provide data consistency over the state of the database as it was when the transaction started. There is NO guarantee that if one puts data into the transaction then it will be available to get within the same transaction.
Cursor ¶
This iterates over database entries given some bucket.
Index ¶
Constants ¶
This section is empty.
Variables ¶
var ErrNotFound = errors.New("not found")
ErrNotFound denotes that the requested item was not found in the database.
Functions ¶
func IsNotFoundError ¶
IsNotFoundError checks whether an error is an ErrNotFound.
Types ¶
type Bucket ¶
type Bucket struct {
// contains filtered or unexported fields
}
Bucket is a helper type meant to combine buckets and sub-buckets that can be used to create database keys and prefix-based cursors.
func MakeBucket ¶
MakeBucket creates a new Bucket using the given path of buckets.
type Cursor ¶
type Cursor interface { // Next moves the iterator to the next key/value pair. It returns whether the // iterator is exhausted. Panics if the cursor is closed. Next() bool // First moves the iterator to the first key/value pair. It returns false if // such a pair does not exist. Panics if the cursor is closed. First() bool // Seek moves the iterator to the first key/value pair whose key is greater // than or equal to the given key. It returns ErrNotFound if such pair does not // exist. Seek(key *Key) error // Key returns the key of the current key/value pair, or ErrNotFound if done. // The caller should not modify the contents of the returned key, and // its contents may change on the next call to Next. Key() (*Key, error) // Value returns the value of the current key/value pair, or ErrNotFound if done. // The caller should not modify the contents of the returned slice, and its // contents may change on the next call to Next. Value() ([]byte, error) // Close releases associated resources. Close() error }
Cursor iterates over database entries given some bucket.
type DataAccessor ¶
type DataAccessor interface { // Put sets the value for the given key. It overwrites // any previous value for that key. Put(key *Key, value []byte) error // Get gets the value for the given key. It returns // ErrNotFound if the given key does not exist. Get(key *Key) ([]byte, error) // Has returns true if the database does contains the // given key. Has(key *Key) (bool, error) // Delete deletes the value for the given key. Will not // return an error if the key doesn't exist. Delete(key *Key) error // Cursor begins a new cursor over the given bucket. Cursor(bucket *Bucket) (Cursor, error) }
DataAccessor defines the common interface by which data gets accessed in a generic lings database.
type Database ¶
type Database interface { DataAccessor // Begin begins a new database transaction. Begin() (Transaction, error) // Compact compacts the database instance. Compact() error // Close closes the database. Close() error }
Database defines the interface of a database that can begin transactions and close itself.
Important: This is not part of the DataAccessor interface because the Transaction interface includes it. Were we to merge Database with DataAccessor, implementors of the Transaction interface would be forced to implement methods such as Begin and Close, which is undesirable.
type Key ¶
type Key struct {
// contains filtered or unexported fields
}
Key is a helper type meant to combine prefix and suffix into a single database key.
type Transaction ¶
type Transaction interface { DataAccessor // Rollback rolls back whatever changes were made to the // database within this transaction. Rollback() error // Commit commits whatever changes were made to the database // within this transaction. Commit() error // RollbackUnlessClosed rolls back changes that were made to // the database within the transaction, unless the transaction // had already been closed using either Rollback or Commit. RollbackUnlessClosed() error }
Transaction defines the interface of a generic lings database transaction.
Note: Transactions provide data consistency over the state of the database as it was when the transaction started. There is NO guarantee that if one puts data into the transaction then it will be available to get within the same transaction.