summaryrefslogtreecommitdiff
path: root/cmd/podman/restore.go
diff options
context:
space:
mode:
authorOpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com>2020-04-16 14:04:58 -0700
committerGitHub <noreply@github.com>2020-04-16 14:04:58 -0700
commit0d2b5532c417c58bd24e71a56c5c55b43e423a59 (patch)
tree4001e8e47a022bb1b9bfbf2332c42e1aeb802f9e /cmd/podman/restore.go
parent88c6fd06cd54fb9a8826306dfdf1a77e400de5de (diff)
parent241326a9a8c20ad7f2bcf651416b836e7778e090 (diff)
downloadpodman-0d2b5532c417c58bd24e71a56c5c55b43e423a59.tar.gz
podman-0d2b5532c417c58bd24e71a56c5c55b43e423a59.tar.bz2
podman-0d2b5532c417c58bd24e71a56c5c55b43e423a59.zip
Merge pull request #5852 from baude/v1prune
Podman V2 birth
Diffstat (limited to 'cmd/podman/restore.go')
-rw-r--r--cmd/podman/restore.go96
1 files changed, 0 insertions, 96 deletions
diff --git a/cmd/podman/restore.go b/cmd/podman/restore.go
deleted file mode 100644
index a8db7fa94..000000000
--- a/cmd/podman/restore.go
+++ /dev/null
@@ -1,96 +0,0 @@
-package main
-
-import (
- "github.com/containers/libpod/cmd/podman/cliconfig"
- "github.com/containers/libpod/pkg/adapter"
- "github.com/containers/libpod/pkg/rootless"
- "github.com/pkg/errors"
- "github.com/spf13/cobra"
-)
-
-var (
- restoreCommand cliconfig.RestoreValues
- restoreDescription = `
- podman container restore
-
- Restores a container from a checkpoint. The container name or ID can be used.
-`
- _restoreCommand = &cobra.Command{
- Use: "restore [flags] CONTAINER [CONTAINER...]",
- Short: "Restores one or more containers from a checkpoint",
- Long: restoreDescription,
- RunE: func(cmd *cobra.Command, args []string) error {
- restoreCommand.InputArgs = args
- restoreCommand.GlobalFlags = MainGlobalOpts
- restoreCommand.Remote = remoteclient
- return restoreCmd(&restoreCommand, cmd)
- },
- Args: func(cmd *cobra.Command, args []string) error {
- return checkAllLatestAndCIDFile(cmd, args, true, false)
- },
- Example: `podman container restore ctrID
- podman container restore --latest
- podman container restore --all`,
- }
-)
-
-func init() {
- restoreCommand.Command = _restoreCommand
- restoreCommand.SetHelpTemplate(HelpTemplate())
- restoreCommand.SetUsageTemplate(UsageTemplate())
- flags := restoreCommand.Flags()
- flags.BoolVarP(&restoreCommand.All, "all", "a", false, "Restore all checkpointed containers")
- flags.BoolVarP(&restoreCommand.Keep, "keep", "k", false, "Keep all temporary checkpoint files")
- flags.BoolVarP(&restoreCommand.Latest, "latest", "l", false, "Act on the latest container podman is aware of")
- flags.BoolVar(&restoreCommand.TcpEstablished, "tcp-established", false, "Restore a container with established TCP connections")
- flags.StringVarP(&restoreCommand.Import, "import", "i", "", "Restore from exported checkpoint archive (tar.gz)")
- flags.StringVarP(&restoreCommand.Name, "name", "n", "", "Specify new name for container restored from exported checkpoint (only works with --import)")
- flags.BoolVar(&restoreCommand.IgnoreRootfs, "ignore-rootfs", false, "Do not apply root file-system changes when importing from exported checkpoint")
- flags.BoolVar(&restoreCommand.IgnoreStaticIP, "ignore-static-ip", false, "Ignore IP address set via --static-ip")
- flags.BoolVar(&restoreCommand.IgnoreStaticMAC, "ignore-static-mac", false, "Ignore MAC address set via --mac-address")
-
- markFlagHiddenForRemoteClient("latest", flags)
-}
-
-func restoreCmd(c *cliconfig.RestoreValues, cmd *cobra.Command) error {
- if rootless.IsRootless() {
- return errors.New("restoring a container requires root")
- }
-
- runtime, err := adapter.GetRuntime(getContext(), &c.PodmanCommand)
- if err != nil {
- return errors.Wrapf(err, "could not get runtime")
- }
- defer runtime.DeferredShutdown(false)
-
- if c.Import == "" && c.IgnoreRootfs {
- return errors.Errorf("--ignore-rootfs can only be used with --import")
- }
-
- if c.Import == "" && c.Name != "" {
- return errors.Errorf("--name can only be used with --import")
- }
-
- if c.Name != "" && c.TcpEstablished {
- return errors.Errorf("--tcp-established cannot be used with --name")
- }
-
- argLen := len(c.InputArgs)
- if c.Import != "" {
- if c.All || c.Latest {
- return errors.Errorf("Cannot use --import with --all or --latest")
- }
- if argLen > 0 {
- return errors.Errorf("Cannot use --import with positional arguments")
- }
- }
-
- if (c.All || c.Latest) && argLen > 0 {
- return errors.Errorf("no arguments are needed with --all or --latest")
- }
- if argLen < 1 && !c.All && !c.Latest && c.Import == "" {
- return errors.Errorf("you must provide at least one name or id")
- }
-
- return runtime.Restore(getContext(), c)
-}