Documentation
¶
Index ¶
- Variables
- type BackupOption
- type BackupResult
- type CatResult
- type CheckError
- type CheckOption
- type CheckResult
- type Client
- func (c *Client) Backup(ctx context.Context, src store.Source, opts ...BackupOption) (*BackupResult, error)
- func (c *Client) BreakLock(ctx context.Context) ([]*RepoLock, error)
- func (c *Client) Cat(ctx context.Context, keys ...string) ([]*CatResult, error)
- func (c *Client) Check(ctx context.Context, opts ...CheckOption) (*CheckResult, error)
- func (c *Client) Diff(ctx context.Context, snap1, snap2 string, opts ...DiffOption) (*DiffResult, error)
- func (c *Client) Forget(ctx context.Context, snapshotID string, opts ...ForgetOption) (*ForgetResult, error)
- func (c *Client) ForgetPolicy(ctx context.Context, opts ...ForgetOption) (*PolicyResult, error)
- func (c *Client) List(ctx context.Context, opts ...ListOption) (*ListResult, error)
- func (c *Client) LsSnapshot(ctx context.Context, snapshotID string, opts ...LsSnapshotOption) (*LsSnapshotResult, error)
- func (c *Client) Prune(ctx context.Context, opts ...PruneOption) (*PruneResult, error)
- func (c *Client) Restore(ctx context.Context, w io.Writer, snapshotRef string, opts ...RestoreOption) (*RestoreResult, error)
- func (c *Client) Store() store.ObjectStore
- type ClientOption
- type Credentials
- type DiffOption
- type DiffResult
- type ForgetOption
- type ForgetResult
- type KMSDecrypter
- type KeyProvider
- type KeySlot
- type ListOption
- type ListResult
- type LsSnapshotOption
- type LsSnapshotResult
- type Phase
- type PolicyResult
- type PruneOption
- type PruneResult
- type RepoConfig
- type RepoLock
- type Reporter
- type RestoreOption
- type RestoreResult
- type StaticKey
Constants ¶
This section is empty.
Variables ¶
var ( WithVerbose = engine.WithVerbose WithBackupDryRun = engine.WithBackupDryRun WithTags = engine.WithTags WithGenerator = engine.WithGenerator WithMeta = engine.WithMeta WithExcludeHash = engine.WithExcludeHash )
var ( WithRestoreDryRun = engine.WithRestoreDryRun WithRestoreVerbose = engine.WithRestoreVerbose WithRestorePath = engine.WithRestorePath )
var ( WithPruneDryRun = engine.WithPruneDryRun WithPruneVerbose = engine.WithPruneVerbose )
var ( WithPrune = engine.WithPrune WithDryRun = engine.WithDryRun WithForgetVerbose = engine.WithForgetVerbose WithKeepLast = engine.WithKeepLast WithKeepHourly = engine.WithKeepHourly WithKeepDaily = engine.WithKeepDaily WithKeepWeekly = engine.WithKeepWeekly WithKeepMonthly = engine.WithKeepMonthly WithKeepYearly = engine.WithKeepYearly WithGroupBy = engine.WithGroupBy WithFilterTag = engine.WithFilterTag WithFilterSource = engine.WithFilterSource WithFilterAccount = engine.WithFilterAccount WithFilterPath = engine.WithFilterPath )
var ( WithReadData = engine.WithReadData WithCheckVerbose = engine.WithCheckVerbose WithSnapshotRef = engine.WithSnapshotRef )
var WithDiffVerbose = engine.WithDiffVerbose
var WithListVerbose = engine.WithListVerbose
var WithLsVerbose = engine.WithLsVerbose
Functions ¶
This section is empty.
Types ¶
type BackupOption ¶
type BackupOption = engine.BackupOption
type BackupResult ¶ added in v1.2.0
type CatResult ¶ added in v1.4.6
type CatResult struct {
Key string // The object key requested
Data []byte // Raw object data (typically JSON)
}
CatResult contains the raw data for an object key.
type CheckError ¶ added in v1.4.7
type CheckError = engine.CheckError
type CheckOption ¶ added in v1.4.7
type CheckOption = engine.CheckOption
type CheckResult ¶ added in v1.4.7
type CheckResult = engine.CheckResult
type Client ¶
type Client struct {
// contains filtered or unexported fields
}
Client is the high-level interface for using Cloudstic as a library.
func NewClient ¶
func NewClient(base store.ObjectStore, opts ...ClientOption) (*Client, error)
func (*Client) Backup ¶
func (c *Client) Backup(ctx context.Context, src store.Source, opts ...BackupOption) (*BackupResult, error)
func (*Client) Cat ¶ added in v1.4.6
Cat fetches the raw data for one or more object keys from the repository. Object keys can be snapshot/<hash>, filemeta/<hash>, content/<hash>, node/<hash>, chunk/<hash>, config, index/latest, keys/<slot>, etc.
This is useful for debugging, inspection, and understanding the internal structure of the repository.
func (*Client) Check ¶ added in v1.4.7
func (c *Client) Check(ctx context.Context, opts ...CheckOption) (*CheckResult, error)
Check verifies the integrity of the repository by walking the full reference chain (snapshots → HAMT nodes → filemeta → content → chunks) and checking that every referenced object can be read. With WithReadData(), chunk data is re-hashed for byte-level verification.
func (*Client) Diff ¶
func (c *Client) Diff(ctx context.Context, snap1, snap2 string, opts ...DiffOption) (*DiffResult, error)
func (*Client) Forget ¶
func (c *Client) Forget(ctx context.Context, snapshotID string, opts ...ForgetOption) (*ForgetResult, error)
func (*Client) ForgetPolicy ¶
func (c *Client) ForgetPolicy(ctx context.Context, opts ...ForgetOption) (*PolicyResult, error)
func (*Client) List ¶
func (c *Client) List(ctx context.Context, opts ...ListOption) (*ListResult, error)
func (*Client) LsSnapshot ¶
func (c *Client) LsSnapshot(ctx context.Context, snapshotID string, opts ...LsSnapshotOption) (*LsSnapshotResult, error)
func (*Client) Prune ¶
func (c *Client) Prune(ctx context.Context, opts ...PruneOption) (*PruneResult, error)
func (*Client) Restore ¶
func (c *Client) Restore(ctx context.Context, w io.Writer, snapshotRef string, opts ...RestoreOption) (*RestoreResult, error)
Restore writes the snapshot's file tree as a ZIP archive to w. snapshotRef can be "", "latest", a bare hash, or "snapshot/<hash>".
func (*Client) Store ¶ added in v1.1.0
func (c *Client) Store() store.ObjectStore
type ClientOption ¶
type ClientOption func(*Client)
ClientOption configures a Client.
func WithEncryptionKey ¶ added in v1.1.0
func WithEncryptionKey(key []byte) ClientOption
WithEncryptionKey directly sets the AES-256-GCM encryption key (32 bytes). This bypasses repo config detection and unconditionally applies encryption. The HMAC deduplication key is automatically derived from this key. Use this for the SaaS product where the key is already resolved externally.
func WithKeyProvider ¶ added in v1.4.6
func WithKeyProvider(kp KeyProvider) ClientOption
WithKeyProvider sets a KeyProvider for automatic key resolution. During NewClient, the repo config is read from the store; if the repository is encrypted, ResolveKey is called to obtain the encryption key. If the repository is not encrypted, the provider is silently ignored.
func WithPackfile ¶ added in v1.4.3
func WithPackfile(enable bool) ClientOption
WithPackfile enables bundling small objects into 8MB packs to save API calls.
func WithReporter ¶
func WithReporter(r Reporter) ClientOption
WithReporter sets the progress reporter for the client.
type Credentials ¶ added in v1.4.6
type Credentials struct {
PlatformKey []byte // Raw 32-byte platform key
Password string // Password for password-based slots
RecoveryMnemonic string // BIP39 24-word recovery phrase
KMSDecrypter crypto.KMSDecrypter // For kms-platform slots (optional)
PasswordPrompt func() (string, error) // Interactive password fallback (optional)
}
Credentials resolves the encryption key by trying credentials against the repository's stored key slots. The resolution order is: KMS → platform key → password → recovery mnemonic → password prompt.
func (Credentials) ResolveKey ¶ added in v1.4.6
func (c Credentials) ResolveKey(ctx context.Context, rawStore store.ObjectStore) ([]byte, error)
type DiffOption ¶
type DiffOption = engine.DiffOption
type DiffResult ¶
type DiffResult = engine.DiffResult
type ForgetOption ¶
type ForgetOption = engine.ForgetOption
type ForgetResult ¶ added in v1.2.0
type ForgetResult = engine.ForgetResult
type KMSDecrypter ¶ added in v1.4.6
type KMSDecrypter = crypto.KMSDecrypter
KMSDecrypter is re-exported for callers that provide KMS credentials.
type KeyProvider ¶ added in v1.4.6
type KeyProvider interface {
ResolveKey(ctx context.Context, rawStore store.ObjectStore) ([]byte, error)
}
KeyProvider resolves the encryption key for a repository. It is called during NewClient when the repository config indicates encryption is enabled.
type KeySlot ¶ added in v1.4.6
KeySlot is re-exported for callers that need to inspect slot metadata.
type ListOption ¶
type ListOption = engine.ListOption
type ListResult ¶
type ListResult = engine.ListResult
type LsSnapshotOption ¶
type LsSnapshotOption = engine.LsSnapshotOption
type LsSnapshotResult ¶
type LsSnapshotResult = engine.LsSnapshotResult
type PolicyResult ¶
type PolicyResult = engine.PolicyResult
type PruneOption ¶
type PruneOption = engine.PruneOption
type PruneResult ¶ added in v1.2.0
type PruneResult = engine.PruneResult
type RepoConfig ¶ added in v1.2.0
type RepoConfig = core.RepoConfig
RepoConfig is the repository marker written by "init".
type RestoreOption ¶
type RestoreOption = engine.RestoreOption
type RestoreResult ¶
type RestoreResult = engine.RestoreResult
type StaticKey ¶ added in v1.4.6
type StaticKey []byte
StaticKey is a KeyProvider that returns a pre-resolved encryption key. Use this when the key has already been unwrapped externally (e.g. the SaaS product passes the derived key directly).