mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
03c6949739
This allows a plugin to be upgraded without requiring to uninstall/reinstall a plugin. Since plugin resources (e.g. volumes) are tied to a plugin ID, this is important to ensure resources aren't lost. The plugin must be disabled while upgrading (errors out if enabled). This does not add any convenience flags for automatically disabling/re-enabling the plugin during before/after upgrade. Since an upgrade may change requested permissions, the user is required to accept permissions just like `docker plugin install`. Signed-off-by: Brian Goff <cpuguy83@gmail.com>
31 lines
729 B
Go
31 lines
729 B
Go
package plugin
|
|
|
|
import (
|
|
"github.com/docker/docker/cli"
|
|
"github.com/docker/docker/cli/command"
|
|
"github.com/spf13/cobra"
|
|
)
|
|
|
|
// NewPluginCommand returns a cobra command for `plugin` subcommands
|
|
func NewPluginCommand(dockerCli *command.DockerCli) *cobra.Command {
|
|
cmd := &cobra.Command{
|
|
Use: "plugin",
|
|
Short: "Manage plugins",
|
|
Args: cli.NoArgs,
|
|
RunE: dockerCli.ShowHelp,
|
|
}
|
|
|
|
cmd.AddCommand(
|
|
newDisableCommand(dockerCli),
|
|
newEnableCommand(dockerCli),
|
|
newInspectCommand(dockerCli),
|
|
newInstallCommand(dockerCli),
|
|
newListCommand(dockerCli),
|
|
newRemoveCommand(dockerCli),
|
|
newSetCommand(dockerCli),
|
|
newPushCommand(dockerCli),
|
|
newCreateCommand(dockerCli),
|
|
newUpgradeCommand(dockerCli),
|
|
)
|
|
return cmd
|
|
}
|