manifest

package
v0.2.18 Latest Latest
Warning

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

Go to latest
Published: Aug 19, 2021 License: Apache-2.0 Imports: 28 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
var ErrNoBinaries = errors.New("no binaries or apps provided")

ErrNoBinaries is returned when a resolved package does not contain binaries or apps

View Source
var ErrNoSource = errors.New("no source provided")

ErrNoSource is returned when a resolved package does not contain source

View Source
var ErrUnknownPackage = errors.New("unknown package")

ErrUnknownPackage is returned when a package cannot be resolved.

Functions

func AutoVersion added in v0.2.10

func AutoVersion(path string) (version string, err error)

AutoVersion rewrites the given manifest with new version information if applicable.

Auto-versioning configuration is defined in a "version > auto-version" block. If a new version is found in the defined location then the version block's versions are updated.

func ParseGlob

func ParseGlob(from string) (glob.Glob, error)

ParseGlob parses a version glob into a Glob selector

Types

type Action

type Action interface {
	Apply(p *Package) error
	String() string
	// contains filtered or unexported methods
}

Action interface implemented by all lifecycle trigger actions.

type AnnotatedManifest

type AnnotatedManifest struct {
	FS        fs.FS
	Path      string // Fully qualified path to manifest, including the FS.
	Name      string
	Errors    []error
	*Manifest // May be nil if errors were encountered.
}

AnnotatedManifest includes extra metadata not included in the manifest itself.

func (*AnnotatedManifest) String

func (f *AnnotatedManifest) String() string

type AutoVersionBlock added in v0.2.12

type AutoVersionBlock struct {
	GitHubRelease  string `hcl:"github-release" help:"GitHub <user>/<repo> to retrieve and update versions from the releases API."`
	VersionPattern string `hcl:"version-pattern" help:"Regex with one capture group to extract the version number from the origin." default:"v?(.*)"`
}

AutoVersionBlock represents auto-version configuration.

type ChannelBlock

type ChannelBlock struct {
	Name    string        `hcl:"name,label" help:"Name of the channel (eg. stable, alpha, etc.)."`
	Update  time.Duration `hcl:"update" help:"Update frequency for this channel."`
	Version string        `` /* 144-byte string literal not displayed */
	Layer
}

ChannelBlock is a Layer block specifying an installable channel for a package.

type ChmodAction

type ChmodAction struct {
	Pos hcl.Position `hcl:"-"`

	Mode int    `hcl:"mode" help:"File mode to set."`
	File string `hcl:"file" help:"File to set mode on."`
}

ChmodAction changes the file mode on a file.

func (*ChmodAction) Apply added in v0.2.6

func (c *ChmodAction) Apply(*Package) error

func (*ChmodAction) String

func (c *ChmodAction) String() string

type Config

type Config struct {
	// Path to environment root.
	Env string
	// State path where packages are installed.
	State string
	// Optional OS (will use runtime.GOOS if not provided).
	OS string
	// Optional Arch (will use runtime.GOARCH if not provided).
	Arch string
}

Config required for loading manifests.

type CopyAction

type CopyAction struct {
	Pos hcl.Position `hcl:"-"`

	From string      `` /* 149-byte string literal not displayed */
	To   string      `hcl:"to" help:"The relative destination to copy to, based on the context."`
	Mode os.FileMode `hcl:"mode,optional" help:"File mode of file."`
}

CopyAction is an action for copying

func (*CopyAction) Apply added in v0.2.6

func (c *CopyAction) Apply(p *Package) error

func (*CopyAction) String

func (c *CopyAction) String() string

type Event

type Event string

Event in the lifecycle of a package.

const (
	// Package specific events
	EventUnpack    Event = "unpack"
	EventInstall   Event = "install"
	EventUninstall Event = "uninstall"
	// Environment specific events
	EventEnvActivate   Event = "activate"
	EventEnvDeactivate Event = "deactivate"
)

Lifecycle events.

type Layer

type Layer struct {
	Arch     string            `hcl:"arch,optional" help:"CPU architecture to match (amd64, 386, arm, etc.)."`
	Binaries []string          `hcl:"binaries,optional" help:"Relative glob from $root to individual terminal binaries."`
	Apps     []string          `hcl:"apps,optional" help:"Relative paths to Mac .app packages to install."`
	Rename   map[string]string `hcl:"rename,optional" help:"Rename files after unpacking to ${root}."`
	Requires []string          `hcl:"requires,optional" help:"Packages this one requires."`
	Provides []string          `hcl:"provides,optional" help:"This package provides the given virtual packages."`
	Dest     string            `hcl:"dest,optional" help:"Override archive extraction destination for package."`
	Files    map[string]string `hcl:"files,optional" help:"Files to load strings from to be used in the manifest."`
	Strip    int               `hcl:"strip,optional" help:"Number of path prefix elements to strip."`
	Root     string            `hcl:"root,optional" help:"Override root for package."`
	Test     *string           `hcl:"test,optional" help:"Command that will test the package is operational."`
	Env      envars.Envars     `hcl:"env,optional" help:"Environment variables to export."`
	Source   string            `hcl:"source,optional" help:"URL for source package."`
	Mirrors  []string          `hcl:"mirrors,optional" help:"Mirrors to use if the primary source is unavailable."`
	SHA256   string            `hcl:"sha256,optional" help:"SHA256 of source package for verification."`
	Darwin   []*Layer          `hcl:"darwin,block" help:"Darwin-specific configuration."`
	Linux    []*Layer          `hcl:"linux,block" help:"Linux-specific configuration."`
	Platform []*PlatformBlock  `` /* 134-byte string literal not displayed */
	Triggers []*Trigger        `hcl:"on,block" help:"Triggers to run on lifecycle events."`
}

A Layer contributes to the final merged manifest definition.

type Loader

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

Loader of manifests.

func NewLoader

func NewLoader(sources *sources.Sources) *Loader

NewLoader constructs a new Loader.

func (*Loader) All

func (l *Loader) All() ([]*AnnotatedManifest, error)

All loads all package manifests and returns them.

Non-critical errors will be made available in each AnnotatedManifest and also via Errors().

func (*Loader) Errors

func (l *Loader) Errors() ManifestErrors

Errors returns all errors encountered _so far_ by the Loader.

func (*Loader) Get

func (l *Loader) Get(name string) (*AnnotatedManifest, error)

Get manifest for the given package.

Will return a wrapped ErrUnknownPackage if the package could not be found.

If any errors occur during the load, the first error will be returned.

type Manifest

type Manifest struct {
	Layer
	Default     string         `hcl:"default,optional" help:"Default version or channel if not specified."`
	Description string         `hcl:"description" help:"Human readable description of the package."`
	Versions    []VersionBlock `hcl:"version,block" help:"Definition of and configuration for a specific version."`
	Channels    []ChannelBlock `hcl:"channel,block" help:"Definition of and configuration for an auto-update channel."`
}

Manifest for a package.

func (*Manifest) ChannelByName

func (m *Manifest) ChannelByName(name string) *ChannelBlock

ChannelByName returns the channel with the given name, or nil if not found

func (*Manifest) GetChannels added in v0.2.18

func (m *Manifest) GetChannels() []string

GetChannels returns all the channels defined in this manifest.

func (*Manifest) GetVersions added in v0.2.18

func (m *Manifest) GetVersions() []Version

GetVersions returns all the versions defined in this manifest

func (*Manifest) HighestMatch

func (m *Manifest) HighestMatch(to glob.Glob) (result *VersionBlock, highest *Version)

HighestMatch returns the VersionBlock with highest version number matching the given Glob

type ManifestErrors

type ManifestErrors map[string][]error

ManifestErrors are collection of errors for named manifests

func (ManifestErrors) LogErrors

func (merrors ManifestErrors) LogErrors(l ui.Logger)

LogErrors to the given logger

type MessageAction

type MessageAction struct {
	Pos hcl.Position `hcl:"-"`

	Text string `hcl:"text" help:"Message text to display to user."`
}

MessageAction displays a message to the user.

func (*MessageAction) Apply added in v0.2.6

func (m *MessageAction) Apply(p *Package) error

func (*MessageAction) String

func (m *MessageAction) String() string

type Package

type Package struct {
	Description    string
	Reference      Reference
	Arch           string
	Binaries       []string
	Apps           []string
	Requires       []string
	Provides       []string
	Env            envars.Ops
	Source         string
	Mirrors        []string
	Root           string
	SHA256         string
	Dest           string
	Test           string
	Strip          int
	Triggers       map[Event][]Action `json:"-"` // Triggers keyed by event.
	UpdateInterval time.Duration      // How often should we check for updates? 0, if never
	Files          []*ResolvedFileRef `json:"-"`
	FS             fs.FS              `json:"-"` // FS the Package was loaded from.
	Warnings       []string           `json:"-"`

	// Filled in by Env.
	Linked    bool `json:"-"` // Linked into environment.
	State     PackageState
	LastUsed  time.Time
	ETag      string
	UpdatedAt time.Time
}

Package resolved from a manifest.

func (*Package) ApplyEnvironment

func (p *Package) ApplyEnvironment(envRoot string, env envars.Envars)

ApplyEnvironment applies the env ops defined in the Package to the given environment.

func (*Package) DeprecationWarningf

func (p *Package) DeprecationWarningf(format string, args ...interface{})

DeprecationWarningf adds a new deprecation warning to the Package's warnings.

func (*Package) EnsureSupported added in v0.2.18

func (p *Package) EnsureSupported() error

EnsureSupported returns an error if the package is not supported on this platform

func (*Package) LogWarnings

func (p *Package) LogWarnings(l *ui.UI)

LogWarnings logs possible warnings found in the package manifest

func (*Package) ResolveBinaries

func (p *Package) ResolveBinaries() ([]string, error)

ResolveBinaries resolves binary globs from the filesystem.

func (*Package) String

func (p *Package) String() string

func (*Package) Trigger

func (p *Package) Trigger(l ui.Logger, event Event) (messages []string, err error)

Trigger triggers an event in this package. Noop if the event is not defined for the package

func (*Package) Unsupported added in v0.2.18

func (p *Package) Unsupported() bool

Unsupported package in this environment.

type PackageState

type PackageState int

PackageState is the state a package is in.

const (
	PackageStateRemote     PackageState = iota // remote
	PackageStateDownloaded                     // downloaded
	PackageStateInstalled                      // installed
)

Different states a package can be in.

func (PackageState) MarshalJSON

func (s PackageState) MarshalJSON() ([]byte, error)

func (PackageState) String

func (i PackageState) String() string

type Packages

type Packages []*Package

Packages sortable by name + version.

Prerelease versions will sort as the oldest versions.

func (Packages) Len

func (p Packages) Len() int

func (Packages) Less

func (p Packages) Less(i, j int) bool

func (Packages) Swap

func (p Packages) Swap(i, j int)

type PlatformBlock added in v0.2.13

type PlatformBlock struct {
	Attrs []string `hcl:"attr,label" help:"Platform attributes to match."`
	Layer
}

PlatformBlock matches a set of attributes describing a platform (eg. CPU, OS, etc.)

The PlatformBlock replaces "linux" and "darwin".

type Reference

type Reference struct {
	Name    string
	Version Version
	Channel string
}

A Reference to a package, potentially only providing partial versions, etc.

func ParseReference

func ParseReference(pkg string) Reference

ParseReference parses a name+version for a package.

func (Reference) Compare

func (r Reference) Compare(other Reference) int

Compare reference to another, returning -1, 0, or +1.

func (Reference) GoString

func (r Reference) GoString() string

func (Reference) IsChannel

func (r Reference) IsChannel() bool

IsChannel returns true if the reference refers to a channel package

func (Reference) IsFullyQualified

func (r Reference) IsFullyQualified() bool

IsFullyQualified returns true if the Reference is fully qualified, ie. has a version or channel.

func (Reference) IsSet

func (r Reference) IsSet() bool

IsSet returns true if the Reference isn't empty.

func (Reference) Less

func (r Reference) Less(other Reference) bool

Less returns true if other is less than us.

func (Reference) Major

func (r Reference) Major() Reference

Major package-major of the package reference.

func (Reference) MajorMinor

func (r Reference) MajorMinor() Reference

MajorMinor package-major.minor of the package reference.

func (Reference) Match

func (r Reference) Match(other Reference) bool

Match returns true if the name and version components we have match those of other.

func (Reference) String

func (r Reference) String() string

func (Reference) StringNoName

func (r Reference) StringNoName() string

StringNoName returns the formatted version+channel portion of the reference.

type References

type References []Reference

References is a sortable list of Reference's.

func (References) Len

func (r References) Len() int

func (References) Less

func (r References) Less(i, j int) bool

func (References) Swap

func (r References) Swap(i, j int)

type RenameAction

type RenameAction struct {
	Pos hcl.Position `hcl:"-"`

	From string `hcl:"from" help:"Source path to rename."`
	To   string `hcl:"to" help:"Destination path to rename to."`
}

RenameAction renames a file.

func (*RenameAction) Apply added in v0.2.6

func (r *RenameAction) Apply(*Package) error

func (*RenameAction) String

func (r *RenameAction) String() string

type ResolvedFileRef

type ResolvedFileRef struct {
	FS       fs.FS
	FromPath string
	ToPAth   string
}

ResolvedFileRef contains information of a file that should be copied to the target package after unpacking

type Resolver

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

Resolver of packages.

func New

func New(sources *sources.Sources, config Config) (*Resolver, error)

New constructs a new package loader.

func (*Resolver) Errors

func (r *Resolver) Errors() ManifestErrors

Errors returns all errors encountered _so far_ by the Loader.

func (*Resolver) LoadAll

func (r *Resolver) LoadAll() error

LoadAll manifests.

func (*Resolver) Resolve

func (r *Resolver) Resolve(l *ui.UI, selector Selector) (pkg *Package, err error)

Resolve a package reference.

Returns the highest version matching the given reference

func (*Resolver) ResolveVirtual

func (r *Resolver) ResolveVirtual(name string) (pkgs []*Package, err error)

ResolveVirtual references to concrete packages.

func (*Resolver) Search

func (r *Resolver) Search(l ui.Logger, pattern string) (Packages, error)

Search for packages using the given regular expression.

func (*Resolver) Sync

func (r *Resolver) Sync(l *ui.UI, force bool) error

Sync the sources of this resolver.

type RunAction

type RunAction struct {
	Pos hcl.Position `hcl:"-"`

	Command string   `hcl:"cmd" help:"The command to execute, split by shellquote."`
	Dir     string   `hcl:"dir,optional" help:"The directory where the command is run. Defaults to the ${root} directory."`
	Args    []string `hcl:"args,optional" help:"The arguments to the binary."`
	Env     []string `hcl:"env,optional" help:"The environment variables for the execution."`
	Stdin   string   `hcl:"stdin,optional" help:"Optional string to be used as the stdin for the command."`
}

RunAction executes a command when a lifecycle event occurs

func (*RunAction) Apply added in v0.2.6

func (r *RunAction) Apply(p *Package) error

func (*RunAction) String

func (r *RunAction) String() string

type Selector

type Selector interface {
	// Name of the package without version or channel qualifiers
	Name() string
	// String representation of this selector
	String() string
	// Matches checks if the selector matches this Reference
	Matches(ref Reference) bool
	// IsFullyQualified returns true if the selector specifies a version or a channel
	IsFullyQualified() bool
}

Selector is a selector that matches package References and can be used to select a specific version of a package

func ExactSelector

func ExactSelector(ref Reference) Selector

ExactSelector returns a selector that matches packages matching exactly the given reference

func GlobSelector

func GlobSelector(from string) (Selector, error)

GlobSelector parses the given search string into a Glob based selector

func NameSelector

func NameSelector(name string) Selector

NameSelector returns a selector that matches all package versions of the given name

func PrefixSelector

func PrefixSelector(ref Reference) Selector

PrefixSelector returns a selector that matches packages with this reference as a prefix

type Trigger

type Trigger struct {
	Event Event `hcl:"event,label" help:"Event to Trigger (unpack, install, activate)."`

	Run     []*RunAction     `hcl:"run,block" help:"A command to run when the event is triggered."`
	Copy    []*CopyAction    `hcl:"copy,block" help:"A file to copy when the event is triggered."`
	Chmod   []*ChmodAction   `hcl:"chmod,block" help:"Change a files mode."`
	Rename  []*RenameAction  `hcl:"rename,block" help:"Rename a file."`
	Message []*MessageAction `hcl:"message,block" help:"Display a message to the user."`
}

A Trigger applied when a lifecycle event occurs.

func (*Trigger) Ordered

func (a *Trigger) Ordered() []Action

Ordered list of actions.

type Version

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

Version of a package.

This is very loosely parsed to support the myriad different ways of specifying versions, though it does attempt to support semver prerelease and metadata.

func ParseVersion

func ParseVersion(version string) Version

ParseVersion "parses" a package version.

func (Version) Clean added in v0.2.2

func (v Version) Clean() Version

Clean pre-release and metadata.

func (Version) Compare

func (v Version) Compare(rhs Version) int

Compare two versions.

This attempts to follow semantic versioning, ie. prereleases are not considered and metadata is ignored.

func (Version) Components

func (v Version) Components() []string

Components returns the numeric version number components of the

func (Version) GoString

func (v Version) GoString() string

func (Version) IsSet

func (v Version) IsSet() bool

IsSet returns true if the Version is set.

func (Version) Less

func (v Version) Less(other Version) bool

Less return true if this version is smaller than the given version

func (Version) Major

func (v Version) Major() Version

Major version number components only (includes prerelease + metadata).

func (Version) MajorMinor

func (v Version) MajorMinor() Version

MajorMinor version number components only (includes prerelease + metadata).

func (Version) MarshalJSON

func (v Version) MarshalJSON() ([]byte, error)

func (Version) Match

func (v Version) Match(other Version) bool

Match returns true if this version is equal to or a more general version of "other".

That is, if "other" is "1.2.3" and our version is "1.2" this will return true.

func (Version) Metadata

func (v Version) Metadata() string

Metadata in the version, if any.

See https://semver.org/#spec-item-10

func (Version) Prerelease

func (v Version) Prerelease() string

Prerelease data in the version, if any.

See https://semver.org/#spec-item-9

func (Version) PrereleaseComponents

func (v Version) PrereleaseComponents() []string

PrereleaseComponents returns the . separated parts of the prerelease section.

func (Version) String

func (v Version) String() string

type VersionBlock

type VersionBlock struct {
	Version     []string          `hcl:"version,label" help:"Version(s) of package."`
	AutoVersion *AutoVersionBlock `hcl:"auto-version,block" help:"Automatically update versions."`
	Layer
}

VersionBlock is a Layer block specifying an installable version of a package.

type Versions

type Versions []Version

Versions sortable.

func (Versions) Len

func (v Versions) Len() int

func (Versions) Less

func (v Versions) Less(i, j int) bool

func (Versions) Swap

func (v Versions) Swap(i, j int)

Directories

Path Synopsis

Jump to

Keyboard shortcuts

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