Documentation ¶
Overview ¶
Package updatessmagent implements the UpdateSsmAgent plugin.
Package updatessmagent implements the UpdateSsmAgent plugin.
Index ¶
- func Name() string
- type FileContent
- type Manifest
- func (m *Manifest) DownloadURLAndHash(context *updateutil.InstanceContext, packageName string, version string) (result string, hash string, err error)
- func (m *Manifest) HasVersion(context *updateutil.InstanceContext, packageName string, version string) bool
- func (m *Manifest) LatestVersion(log log.T, context *updateutil.InstanceContext, packageName string) (result string, err error)
- type PackageContent
- type PackageVersion
- type Plugin
- type UpdatePluginConfig
- type UpdatePluginInput
- type UpdatePluginOutput
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
Types ¶
type FileContent ¶
type FileContent struct { Name string `json:"Name"` AvailableVersions []*PackageVersion `json:"AvailableVersions"` }
FileContent holds the file name and available versions
type Manifest ¶
type Manifest struct { SchemaVersion string `json:"SchemaVersion"` URIFormat string `json:"UriFormat"` Packages []*PackageContent `json:"Packages"` }
Manifest represents the json structure of online manifest file.
func ParseManifest ¶
func ParseManifest(log log.T, fileName string, context *updateutil.InstanceContext, packageName string) (parsedManifest *Manifest, err error)
ParseManifest parses the public manifest file to provide agent update information.
func (*Manifest) DownloadURLAndHash ¶
func (m *Manifest) DownloadURLAndHash( context *updateutil.InstanceContext, packageName string, version string) (result string, hash string, err error)
DownloadURLAndHash returns download source url and hash value
func (*Manifest) HasVersion ¶
func (m *Manifest) HasVersion(context *updateutil.InstanceContext, packageName string, version string) bool
HasVersion returns if manifest file has particular version for package
func (*Manifest) LatestVersion ¶
func (m *Manifest) LatestVersion(log log.T, context *updateutil.InstanceContext, packageName string) (result string, err error)
LatestVersion returns latest version for specific package
type PackageContent ¶
type PackageContent struct { Name string `json:"Name"` Files []*FileContent `json:"Files"` }
PackageContent section in the Manifest json.
type PackageVersion ¶
PackageVersion section in the PackageContent
type Plugin ¶
type Plugin struct { // UploadToS3Sync is true if uploading to S3 should be done synchronously, false for async. UploadToS3Sync bool // StdoutFileName is the name of the file that stores standard output. StdoutFileName string // StderrFileName is the name of the file that stores standard error. StderrFileName string // MaxStdoutLength is the maximum length of the standard output returned in the plugin result. // If the output is longer, it will be truncated. The full output will be uploaded to s3. MaxStdoutLength int // MaxStderrLength is the maximum length of the standard error returned in the plugin result. MaxStderrLength int // OutputTruncatedSuffix is an optional suffix that is inserted at the end of the truncated stdout/stderr. OutputTruncatedSuffix string // Manifest location ManifestLocation string }
Plugin is the type for the RunCommand plugin.
func NewPlugin ¶
func NewPlugin(updatePluginConfig UpdatePluginConfig) (*Plugin, error)
NewPlugin returns a new instance of the plugin.
func (*Plugin) Execute ¶
func (p *Plugin) Execute(context context.T, config contracts.Configuration, cancelFlag task.CancelFlag) (res contracts.PluginResult)
Execute runs multiple sets of commands and returns their outputs. res.Output will contain a slice of RunCommandPluginOutput.
type UpdatePluginConfig ¶
type UpdatePluginConfig struct { ManifestLocation string StdoutFileName string StderrFileName string MaxStdoutLength int MaxStderrLength int OutputTruncatedSuffix string }
UpdatePluginConfig is used for initializing update agent plugin with default values
func GetUpdatePluginConfig ¶
func GetUpdatePluginConfig(context context.T) UpdatePluginConfig
GetUpdatePluginConfig returns the default values for the update plugin
type UpdatePluginInput ¶
type UpdatePluginInput struct { contracts.PluginInput AgentName string `json:"agentName"` AllowDowngrade string `json:"allowDowngrade"` TargetVersion string `json:"targetVersion"` Source string `json:"source"` UpdaterName string `json:"-"` }
UpdatePluginInput represents one set of commands executed by the UpdateAgent plugin.
type UpdatePluginOutput ¶
type UpdatePluginOutput struct {
contracts.PluginOutput
}
UpdatePluginOutput represents the output of the plugin
func (*UpdatePluginOutput) AppendInfo ¶
func (out *UpdatePluginOutput) AppendInfo(log log.T, format string, params ...interface{})
AppendInfo adds info to UpdateContext StandardOut
func (*UpdatePluginOutput) Failed ¶
func (out *UpdatePluginOutput) Failed(log log.T, err error)
Failed marks update as Failed
func (*UpdatePluginOutput) Pending ¶
func (out *UpdatePluginOutput) Pending()
Pending mark update as Pending
func (*UpdatePluginOutput) Succeed ¶
func (out *UpdatePluginOutput) Succeed()
Succeed marks update as Successful