Packages
This is dedicated to package
commands. The command type
field must be package
. Package is a type that allows one to perform package operations. There are several additional options available when type
is package
:
name | notes | type | required |
---|---|---|---|
packageName |
The name of a package to be modified. | string |
yes |
packageManager |
The name of the package manger to be used. | string |
yes |
packageOperation |
The type of operation to be perform. | string |
yes |
packageVersion |
The version of a package to be modified. | string |
no |
example
The following is an example of a package command:
update-docker:
type: package
shell: zsh
packageName: docker-ce
packageManager: apt
packageOperation: install
host: debian-based-host
packageOperation
The following package operations are supported:
install
remove
upgrade
packageManager
The following package managers are recognized:
apt
yum
dnf
package command args
You can add additional arguments using the standard Args
key. This is useful for adding more packages.
Development
The PackageManager interface provides an easy to enforce functions and options. There are two interfaces, PackageManager
and ConfigurablePackageManager
in the directory pkg/pkgman
. Go’s import-cycle “feature” caused me to implement functional options using a third interface. PackageManagerOption
is a function that takes an interface.
PackageManager
// PackageManager is an interface used to define common package commands. This shall be implemented by every package.
type PackageManager interface {
Install(pkg, version string, args []string) (string, []string)
Remove(pkg string, args []string) (string, []string)
Upgrade(pkg, version string) (string, []string) // Upgrade a specific package
UpgradeAll() (string, []string)
// Configure applies functional options to customize the package manager.
Configure(options ...pkgcommon.PackageManagerOption)
}
There are a few functional options that should be implemented using the ConfigurablePackageManager
interface:
// ConfigurablePackageManager defines methods for setting configuration options.
type ConfigurablePackageManager interface {
SetUseAuth(useAuth bool)
SetAuthCommand(authCommand string)
}