aboutsummaryrefslogtreecommitdiff
package store

// QuarantineBase is one quarantined write.
// It is intended to be embedded.
type QuarantineBase interface {
	// Reader exposes the objects written into this quarantine.
	ObjectReader

	// Promote publishes quarantined writes into their final destination.
	//
	// Promote is not atomic.
	// Because objects are content-addressed and immutable,
	// a partial promotion is safe:
	// it only makes some objects visible early,
	// which is harmless until a ref references them.
	//
	// Promote invalidates the receiver.
	Promote() error

	// Discard abandons quarantined writes.
	//
	// Discard invalidates the receiver.
	Discard() error
}

// ObjectQuarantine represents one quarantined object-wise write.
type ObjectQuarantine interface {
	QuarantineBase
	ObjectWriter
}

// ObjectQuarantineOptions controls the options
// for one object quarantine creation.
type ObjectQuarantineOptions struct{}

// ObjectQuarantiner creates quarantines
// for object-wise writes.
type ObjectQuarantiner interface {
	BeginObjectQuarantine(opts ObjectQuarantineOptions) (ObjectQuarantine, error)
}

// PackQuarantine represents one quarantined pack-wise write.
type PackQuarantine interface {
	QuarantineBase
	PackWriter
}

// PackQuarantineOptions controls the options
// for one pack quarantine creation.
type PackQuarantineOptions struct{}

// PackQuarantiner creates quarantines
// for pack-wise writes.
type PackQuarantiner interface {
	BeginPackQuarantine(opts PackQuarantineOptions) (PackQuarantine, error)
}

// CoordinatedQuarantine represents one quarantine
// that accepts both object-wise and pack-wise writes
// behind a single Promote/Discard.
type CoordinatedQuarantine interface {
	ObjectQuarantine
	PackQuarantine
}

// CoordinatedQuarantineOptions controls the options
// for one coordinated quarantine creation.
type CoordinatedQuarantineOptions struct {
	Object ObjectQuarantineOptions
	Pack   PackQuarantineOptions
}

// CoordinatedQuarantiner creates coordinated quarantines
// that accept both object-wise and pack-wise writes
// behind a single Promote/Discard.
//
// The returned quarantine is usable
// anywhere either split quarantine is expected.
type CoordinatedQuarantiner interface {
	BeginCoordinatedQuarantine(opts CoordinatedQuarantineOptions) (CoordinatedQuarantine, error)
}