Documentation ¶
Index ¶
- Variables
- func Filename(snapshot *client.Snapshot) string
- func Iter(ctx context.Context, f func(*Reader) error) error
- func List(ctx context.Context, setID uint64, snapNames []string) ([]client.SnapshotSet, error)
- func MockUserLookup(newLookup func(string) (*user.User, error)) func()
- func Save(ctx context.Context, id uint64, si *snap.Info, cfg map[string]interface{}, ...) (*client.Snapshot, error)
- type Flags
- type Logf
- type Reader
- type RestoreState
Constants ¶
This section is empty.
Variables ¶
var ( // Stop is used to ask Iter to stop iteration, without it being an error. Stop = errors.New("stop iteration") )
Functions ¶
func Iter ¶
Iter loops over all snapshots in the snapshots directory, applying the given function to each. The snapshot will be closed after the function returns. If the function returns an error, iteration is stopped (and if the error isn't Stop, it's returned as the error of the iterator).
Types ¶
type Flags ¶
type Flags struct {
Auto bool
}
Flags encompasses extra flags for snapshots backend Save.
type Logf ¶
type Logf func(format string, args ...interface{})
Logf is the type implemented by logging functions.
type Reader ¶
A Reader is a snapshot that's been opened for reading.
func Open ¶
Open a Snapshot given its full filename.
If the returned error is nil, the caller must close the reader (or its file) when done with it.
If the returned error is non-nil, the returned Reader will be nil, *or* have a non-empty Broken; in the latter case its file will be closed.
func (*Reader) Restore ¶
func (r *Reader) Restore(ctx context.Context, current snap.Revision, usernames []string, logf Logf) (rs *RestoreState, e error)
Restore the data from the snapshot.
If successful this will replace the existing data (for the given revision, or the one in the snapshot) with that contained in the snapshot. It keeps track of the old data in the task so it can be undone (or cleaned up).
type RestoreState ¶
type RestoreState struct { Done bool `json:"done,omitempty"` Created []string `json:"created,omitempty"` Moved []string `json:"moved,omitempty"` // Config is here for convenience; this package doesn't touch it Config map[string]interface{} `json:"config,omitempty"` }
RestoreState stores information that can be used to cleanly revert (or finish cleaning up) a snapshot Restore.
This is useful when a Restore is part of a chain of operations, and a later one failing necessitates undoing the Restore.
func (*RestoreState) Cleanup ¶
func (rs *RestoreState) Cleanup()
Cleanup the backed up data from disk.
func (*RestoreState) Revert ¶
func (rs *RestoreState) Revert()
Revert the backed up data: remove what was added, move back what was moved aside.