storage

package
v0.5.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 26, 2019 License: Apache-2.0 Imports: 16 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var Formats = map[string]Format{
	".json": FormatJSON,
	".yaml": FormatYAML,
	".yml":  FormatYAML,
}

Formats describes the connection between file extensions and a encoding formats.

Functions

This section is empty.

Types

type AnyKey added in v0.5.0

type AnyKey fmt.Stringer

This can be used to match either of the keys

type Format added in v0.5.0

type Format uint8

Format is an enum describing the format of data in a file. This is used by Storages to determine the encoding format for a file.

const (
	FormatJSON Format = iota
	FormatYAML
)

type GenericMappedRawStorage added in v0.5.0

type GenericMappedRawStorage struct {
	// contains filtered or unexported fields
}

GenericMappedRawStorage is the default implementation of a MappedRawStorage, it stores files in the given directory via a path translation map.

func (*GenericMappedRawStorage) AddMapping added in v0.5.0

func (r *GenericMappedRawStorage) AddMapping(key Key, path string)

func (*GenericMappedRawStorage) Checksum added in v0.5.0

func (r *GenericMappedRawStorage) Checksum(key Key) (s string, err error)

This returns the modification time as a UnixNano string If the file doesn't exist, return blank

func (*GenericMappedRawStorage) Delete added in v0.5.0

func (r *GenericMappedRawStorage) Delete(key Key) (err error)

func (*GenericMappedRawStorage) Exists added in v0.5.0

func (r *GenericMappedRawStorage) Exists(key Key) bool

func (*GenericMappedRawStorage) Format added in v0.5.0

func (r *GenericMappedRawStorage) Format(key Key) (f Format)

func (*GenericMappedRawStorage) GetKey added in v0.5.0

func (r *GenericMappedRawStorage) GetKey(path string) (Key, error)

func (*GenericMappedRawStorage) List added in v0.5.0

func (r *GenericMappedRawStorage) List(kind KindKey) ([]Key, error)

func (*GenericMappedRawStorage) Read added in v0.5.0

func (r *GenericMappedRawStorage) Read(key Key) ([]byte, error)

func (*GenericMappedRawStorage) RemoveMapping added in v0.5.0

func (r *GenericMappedRawStorage) RemoveMapping(key Key)

func (*GenericMappedRawStorage) WatchDir added in v0.5.0

func (r *GenericMappedRawStorage) WatchDir() string

func (*GenericMappedRawStorage) Write added in v0.5.0

func (r *GenericMappedRawStorage) Write(key Key, content []byte) error

type GenericRawStorage added in v0.5.0

type GenericRawStorage struct {
	// contains filtered or unexported fields
}

func (*GenericRawStorage) Checksum added in v0.5.0

func (r *GenericRawStorage) Checksum(key Key) (s string, err error)

This returns the modification time as a UnixNano string If the file doesn't exist, return blank

func (*GenericRawStorage) Delete added in v0.5.0

func (r *GenericRawStorage) Delete(key Key) error

func (*GenericRawStorage) Exists added in v0.5.0

func (r *GenericRawStorage) Exists(key Key) bool

func (*GenericRawStorage) Format added in v0.5.0

func (r *GenericRawStorage) Format(key Key) Format

func (*GenericRawStorage) GetKey added in v0.5.0

func (r *GenericRawStorage) GetKey(p string) (key Key, err error)

func (*GenericRawStorage) List added in v0.5.0

func (r *GenericRawStorage) List(key KindKey) ([]Key, error)

func (*GenericRawStorage) Read added in v0.5.0

func (r *GenericRawStorage) Read(key Key) ([]byte, error)

func (*GenericRawStorage) WatchDir added in v0.5.0

func (r *GenericRawStorage) WatchDir() string

func (*GenericRawStorage) Write added in v0.5.0

func (r *GenericRawStorage) Write(key Key, content []byte) error

type GenericStorage

type GenericStorage struct {
	// contains filtered or unexported fields
}

GenericStorage implements the Storage interface

func (*GenericStorage) Checksum added in v0.5.0

func (s *GenericStorage) Checksum(gvk schema.GroupVersionKind, uid meta.UID) (string, error)

Checksum returns a string representing the state of an Object on disk

func (*GenericStorage) Close added in v0.5.0

func (s *GenericStorage) Close() error

Close closes all underlying resources (e.g. goroutines) used; before the application exits

func (*GenericStorage) Count

Count counts the Objects for the specific kind

func (*GenericStorage) Delete

func (s *GenericStorage) Delete(gvk schema.GroupVersionKind, uid meta.UID) error

Delete removes an Object from the storage

func (*GenericStorage) Get

Get returns a new Object for the resource at the specified kind/uid path, based on the file content

func (*GenericStorage) GetMeta added in v0.5.0

func (s *GenericStorage) GetMeta(gvk schema.GroupVersionKind, uid meta.UID) (meta.Object, error)

TODO: Verify this works GetMeta returns a new Object's APIType representation for the resource at the specified kind/uid path

func (*GenericStorage) List

func (s *GenericStorage) List(gvk schema.GroupVersionKind) (result []meta.Object, walkerr error)

List lists Objects for the specific kind

func (*GenericStorage) ListMeta

func (s *GenericStorage) ListMeta(gvk schema.GroupVersionKind) (result []meta.Object, walkerr error)

ListMeta lists all Objects' APIType representation. In other words, only metadata about each Object is unmarshalled (uid/name/kind/apiVersion). This allows for faster runs (no need to unmarshal "the world"), and less resource usage, when only metadata is unmarshalled into memory

func (*GenericStorage) New added in v0.5.0

New creates a new Object for the specified kind TODO: Create better error handling if the GVK specified is not recognized

func (*GenericStorage) Patch added in v0.5.0

func (s *GenericStorage) Patch(gvk schema.GroupVersionKind, uid meta.UID, patch []byte) error

Patch performs a strategic merge patch on the object with the given UID, using the byte-encoded patch given

func (*GenericStorage) RawStorage added in v0.5.0

func (s *GenericStorage) RawStorage() RawStorage

RawStorage returns the RawStorage instance backing this Storage

func (*GenericStorage) Set

Set saves the Object to disk

type Key added in v0.5.0

type Key struct {
	KindKey
	meta.UID
}

Key represents the internal format of Object virtual paths

func KeyForUID

func KeyForUID(gvk schema.GroupVersionKind, uid meta.UID) Key

func NewKey added in v0.5.0

func NewKey(kind meta.Kind, uid meta.UID) Key

NewKey generates a new virtual path Key for an Object

func ParseKey added in v0.5.0

func ParseKey(input string) (k Key, err error)

ParseKey parses the given string and returns a Key

func (Key) String added in v0.5.0

func (k Key) String() string

String returns the virtual path for the Object

func (Key) ToKindKey added in v0.5.0

func (k Key) ToKindKey() KindKey

ToKindKey creates a KindKey out of a Key

type KindKey added in v0.5.0

type KindKey struct {
	meta.Kind
}

KindKey represents the internal format of Kind virtual paths

func KeyForKind

func KeyForKind(gvk schema.GroupVersionKind) KindKey

func NewKindKey added in v0.5.0

func NewKindKey(kind meta.Kind) KindKey

NewKindKey generates a new virtual path Key for a Kind

func (KindKey) String added in v0.5.0

func (k KindKey) String() string

String returns the virtual path for the Kind

type MappedRawStorage added in v0.5.0

type MappedRawStorage interface {
	RawStorage

	// AddMapping binds a Key's virtual path to a physical file path
	AddMapping(key Key, path string)
	// RemoveMapping removes the physical file
	// path mapping matching the given Key
	RemoveMapping(key Key)
}

MappedRawStorage is an interface for RawStorages which store their data in a flat/unordered directory format like manifest directories.

func NewGenericMappedRawStorage added in v0.5.0

func NewGenericMappedRawStorage(dir string) MappedRawStorage

type RawStorage

type RawStorage interface {
	// Read returns a resource's content based on key
	Read(key Key) ([]byte, error)
	// Exists checks if the resource indicated by key exists
	Exists(key Key) bool
	// Write writes the given content to the resource indicated by key
	Write(key Key, content []byte) error
	// Delete deletes the resource indicated by key
	Delete(key Key) error
	// List returns all matching resource Keys based on the given KindKey
	List(key KindKey) ([]Key, error)
	// Checksum returns a string checksum for the resource indicated by key
	Checksum(key Key) (string, error)
	// Format returns the format of the contents of the resource indicated by key
	Format(key Key) Format

	// WatchDir returns the path for Watchers to watch changes in
	WatchDir() string
	// GetKey retrieves the Key containing the virtual path based
	// on the given physical file path returned by a Watcher
	GetKey(path string) (Key, error)
}

RawStorage is a Key-indexed low-level interface to store byte-encoded Objects (resources) in non-volatile memory.

func NewGenericRawStorage added in v0.5.0

func NewGenericRawStorage(dir string) RawStorage

type Storage

type Storage interface {
	// New creates a new Object for the specified kind
	New(gvk schema.GroupVersionKind) (meta.Object, error)
	// Get returns a new Object for the resource at the specified kind/uid path, based on the file content
	Get(gvk schema.GroupVersionKind, uid meta.UID) (meta.Object, error)
	// GetMeta returns a new Object's APIType representation for the resource at the specified kind/uid path
	GetMeta(gvk schema.GroupVersionKind, uid meta.UID) (meta.Object, error)
	// Set saves the Object to disk. If the Object does not exist, the
	// ObjectMeta.Created field is set automatically
	Set(gvk schema.GroupVersionKind, obj meta.Object) error
	// Patch performs a strategic merge patch on the Object with the given UID, using the byte-encoded patch given
	Patch(gvk schema.GroupVersionKind, uid meta.UID, patch []byte) error
	// Delete removes an Object from the storage
	Delete(gvk schema.GroupVersionKind, uid meta.UID) error
	// List lists Objects for the specific kind
	List(gvk schema.GroupVersionKind) ([]meta.Object, error)
	// ListMeta lists all Objects' APIType representation. In other words,
	// only metadata about each Object is unmarshalled (uid/name/kind/apiVersion).
	// This allows for faster runs (no need to unmarshal "the world"), and less
	// resource usage, when only metadata is unmarshalled into memory
	ListMeta(gvk schema.GroupVersionKind) ([]meta.Object, error)
	// Count returns the amount of available Objects of a specific kind
	// This is used by Caches to check if all Objects are cached to perform a List
	Count(gvk schema.GroupVersionKind) (uint64, error)
	// Checksum returns a string representing the state of an Object on disk
	// The checksum should change if any modifications have been made to the
	// Object on disk, it can be e.g. the Object's modification timestamp or
	// calculated checksum
	Checksum(gvk schema.GroupVersionKind, uid meta.UID) (string, error)
	// RawStorage returns the RawStorage instance backing this Storage
	RawStorage() RawStorage
	// Close closes all underlying resources (e.g. goroutines) used; before the application exits
	Close() error
}

Storage is an interface for persisting and retrieving API objects to/from a backend One Storage instance handles all different Kinds of Objects

func NewGenericStorage

func NewGenericStorage(rawStorage RawStorage, serializer serializer.Serializer) Storage

NewGenericStorage constructs a new Storage

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL