Documentation ¶
Overview ¶
Package manifest contains the abstractions needed for collection representation in Swarm. It uses implementations in ethersphere/manifest repo under the hood.
Index ¶
- Constants
- Variables
- type Entry
- type Interface
- func NewDefaultManifest(ls file.LoadSaver, encrypted bool) (Interface, error)
- func NewManifest(manifestType string, ls file.LoadSaver, encrypted bool) (Interface, error)
- func NewManifestReference(manifestType string, reference swarm.Address, ls file.LoadSaver) (Interface, error)
- func NewMantarayManifest(ls file.LoadSaver, encrypted bool) (Interface, error)
- func NewMantarayManifestReference(reference swarm.Address, ls file.LoadSaver) (Interface, error)
- func NewSimpleManifest(ls file.LoadSaver) (Interface, error)
- func NewSimpleManifestReference(ref swarm.Address, l file.LoadSaver) (Interface, error)
- type StoreSizeFunc
Constants ¶
View Source
const DefaultManifestType = ManifestMantarayContentType
View Source
const ( // ManifestMantarayContentType represents content type used for noting that // specific file should be processed as mantaray manifest. ManifestMantarayContentType = "application/bzz-manifest-mantaray+octet-stream" )
View Source
const ( // ManifestSimpleContentType represents content type used for noting that // specific file should be processed as 'simple' manifest ManifestSimpleContentType = "application/bzz-manifest-simple+json" )
Variables ¶
View Source
var ( // ErrNotFound is returned when an Entry is not found in the manifest. ErrNotFound = errors.New("manifest: not found") // ErrInvalidManifestType is returned when an unknown manifest type // is provided to the function. ErrInvalidManifestType = errors.New("manifest: invalid type") // ErrMissingReference is returned when the reference for the manifest file // is missing. ErrMissingReference = errors.New("manifest: missing reference") )
Functions ¶
This section is empty.
Types ¶
type Entry ¶
type Entry interface { // Reference returns the address of the file. Reference() swarm.Address // Metadata returns the metadata of the file. Metadata() map[string]string }
Entry represents a single manifest entry.
type Interface ¶
type Interface interface { // Type returns manifest implementation type information Type() string // Add a manifest entry to the specified path. Add(context.Context, string, Entry) error // Remove a manifest entry on the specified path. Remove(context.Context, string) error // Lookup returns a manifest entry if one is found in the specified path. Lookup(context.Context, string) (Entry, error) // HasPrefix tests whether the specified prefix path exists. HasPrefix(context.Context, string) (bool, error) // Store stores the manifest, returning the resulting address. Store(context.Context, ...StoreSizeFunc) (swarm.Address, error) // IterateAddresses is used to iterate over chunks addresses for // the manifest. IterateAddresses(context.Context, swarm.AddressIterFunc) error }
Interface for operations with manifest.
func NewDefaultManifest ¶
NewDefaultManifest creates a new manifest with default type.
func NewManifest ¶
NewManifest creates a new manifest.
func NewManifestReference ¶
func NewManifestReference( manifestType string, reference swarm.Address, ls file.LoadSaver, ) (Interface, error)
NewManifestReference loads existing manifest.
func NewMantarayManifest ¶
NewMantarayManifest creates a new mantaray-based manifest.
func NewMantarayManifestReference ¶
NewMantarayManifestReference loads existing mantaray-based manifest.
func NewSimpleManifest ¶
NewSimpleManifest creates a new simple manifest.
type StoreSizeFunc ¶
StoreSizeFunc is a callback on every content size that will be stored by the Store function.
Click to show internal directories.
Click to hide internal directories.