diff options
author | OpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com> | 2020-12-09 10:39:48 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-12-09 10:39:48 -0500 |
commit | 9abbe0728c5050914168a154622087a4dacd4dfe (patch) | |
tree | 6cba60b3f7e8feb4c3062c1865bbe5c9d2c17750 /pkg/copy/parse.go | |
parent | 3cd143fc5851d5080c5dcdde5e3b227a163f85d9 (diff) | |
parent | a12323884fd576063ba8f5785a3c9c2e48140c7f (diff) | |
download | podman-9abbe0728c5050914168a154622087a4dacd4dfe.tar.gz podman-9abbe0728c5050914168a154622087a4dacd4dfe.tar.bz2 podman-9abbe0728c5050914168a154622087a4dacd4dfe.zip |
Merge pull request #8663 from vrothberg/run-950
archive endpoint massaging
Diffstat (limited to 'pkg/copy/parse.go')
-rw-r--r-- | pkg/copy/parse.go | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/pkg/copy/parse.go b/pkg/copy/parse.go new file mode 100644 index 000000000..39e0e1547 --- /dev/null +++ b/pkg/copy/parse.go @@ -0,0 +1,61 @@ +package copy + +import ( + "strings" + + "github.com/pkg/errors" +) + +// ParseSourceAndDestination parses the source and destination input into a +// possibly specified container and path. The input format is described in +// podman-cp(1) as "[nameOrID:]path". Colons in paths are supported as long +// they start with a dot or slash. +// +// It returns, in order, the source container and path, followed by the +// destination container and path, and an error. Note that exactly one +// container must be specified. +func ParseSourceAndDestination(source, destination string) (string, string, string, string, error) { + sourceContainer, sourcePath := parseUserInput(source) + destContainer, destPath := parseUserInput(destination) + + numContainers := 0 + if len(sourceContainer) > 0 { + numContainers++ + } + if len(destContainer) > 0 { + numContainers++ + } + + if numContainers != 1 { + return "", "", "", "", errors.Errorf("invalid arguments %q, %q: exactly 1 container expected but %d specified", source, destination, numContainers) + } + + if len(sourcePath) == 0 || len(destPath) == 0 { + return "", "", "", "", errors.Errorf("invalid arguments %q, %q: you must specify paths", source, destination) + } + + return sourceContainer, sourcePath, destContainer, destPath, nil +} + +// parseUserInput parses the input string and returns, if specified, the name +// or ID of the container and the path. The input format is described in +// podman-cp(1) as "[nameOrID:]path". Colons in paths are supported as long +// they start with a dot or slash. +func parseUserInput(input string) (container string, path string) { + if len(input) == 0 { + return + } + path = input + + // If the input starts with a dot or slash, it cannot refer to a + // container. + if input[0] == '.' || input[0] == '/' { + return + } + + if spl := strings.SplitN(path, ":", 2); len(spl) == 2 { + container = spl[0] + path = spl[1] + } + return +} |