2
2
mirror of https://github.com/octoleo/restic.git synced 2025-01-26 00:28:26 +00:00
restic/backend/interface.go

62 lines
1.6 KiB
Go
Raw Normal View History

2014-09-23 22:39:12 +02:00
package backend
2015-03-28 11:50:23 +01:00
// Type is the type of a Blob.
2014-09-23 22:39:12 +02:00
type Type string
2016-01-23 12:46:20 +01:00
// These are the different data types a backend can store.
2014-09-23 22:39:12 +02:00
const (
Data Type = "data"
2014-09-23 22:39:12 +02:00
Key = "key"
Lock = "lock"
Snapshot = "snapshot"
2015-04-26 15:48:35 +02:00
Index = "index"
Config = "config"
2014-10-04 16:49:39 +02:00
)
2016-01-23 12:46:20 +01:00
// Backend is used to store and access data.
2015-03-28 11:50:23 +01:00
type Backend interface {
2016-01-23 12:46:20 +01:00
// Location returns a string that describes the type and location of the
// repository.
2015-03-28 11:50:23 +01:00
Location() string
2014-10-07 23:19:26 +02:00
2015-03-28 11:50:23 +01:00
// Test a boolean value whether a Blob with the name and type exists.
Test(t Type, name string) (bool, error)
2014-12-21 15:57:41 +01:00
2015-03-28 11:50:23 +01:00
// Remove removes a Blob with type t and name.
Remove(t Type, name string) error
2014-12-21 15:57:41 +01:00
2015-03-28 11:50:23 +01:00
// Close the backend
Close() error
Lister
2016-01-23 14:12:12 +01:00
// Load returns the data stored in the backend for h at the given offset
// and saves it in p. Load has the same semantics as io.ReaderAt.
Load(h Handle, p []byte, off int64) (int, error)
2016-01-23 23:27:58 +01:00
2016-01-24 01:15:35 +01:00
// Save stores the data in the backend under the given handle.
Save(h Handle, p []byte) error
2016-01-23 23:27:58 +01:00
// Stat returns information about the blob identified by h.
Stat(h Handle) (BlobInfo, error)
2014-12-21 15:57:41 +01:00
}
2016-01-23 12:46:20 +01:00
// Lister implements listing data items stored in a backend.
2015-03-28 11:50:23 +01:00
type Lister interface {
// List returns a channel that yields all names of blobs of type t in an
// arbitrary order. A goroutine is started for this. If the channel done is
// closed, sending stops.
2015-03-28 11:50:23 +01:00
List(t Type, done <-chan struct{}) <-chan string
2014-12-21 15:57:41 +01:00
}
2014-10-04 19:20:15 +02:00
2016-01-23 12:46:20 +01:00
// Deleter are backends that allow to self-delete all content stored in them.
2014-12-21 17:02:49 +01:00
type Deleter interface {
2015-03-28 11:50:23 +01:00
// Delete the complete repository.
2014-12-21 15:57:41 +01:00
Delete() error
}
2016-01-23 23:27:58 +01:00
// BlobInfo is returned by Stat() and contains information about a stored blob.
type BlobInfo struct {
Size int64
}