aboutsummaryrefslogtreecommitdiff
path: root/cmd/podman
diff options
context:
space:
mode:
authorOpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com>2021-06-24 09:52:11 -0400
committerGitHub <noreply@github.com>2021-06-24 09:52:11 -0400
commitf29f6aafa10aaa28477014e8ee1b42fbe43c416d (patch)
treeb722db1891c051f7260192677effb9fbc7fc9f7c /cmd/podman
parentda33fc45b6628c1ac1a16e49790be2b4fbf502a5 (diff)
parentb1082696ebb3970ca0a67790fa9bb9955eff5fc2 (diff)
downloadpodman-f29f6aafa10aaa28477014e8ee1b42fbe43c416d.tar.gz
podman-f29f6aafa10aaa28477014e8ee1b42fbe43c416d.tar.bz2
podman-f29f6aafa10aaa28477014e8ee1b42fbe43c416d.zip
Merge pull request #10772 from vrothberg/fix-cp
cp: do not allow dir->file copying
Diffstat (limited to 'cmd/podman')
-rw-r--r--cmd/podman/containers/cp.go8
1 files changed, 8 insertions, 0 deletions
diff --git a/cmd/podman/containers/cp.go b/cmd/podman/containers/cp.go
index 2c7d72b20..0ad258824 100644
--- a/cmd/podman/containers/cp.go
+++ b/cmd/podman/containers/cp.go
@@ -177,6 +177,10 @@ func copyFromContainer(container string, containerPath string, hostPath string)
containerTarget = filepath.Dir(containerTarget)
}
+ if !isStdout && containerInfo.IsDir && !hostInfo.IsDir {
+ return errors.New("destination must be a directory when copying a directory")
+ }
+
reader, writer := io.Pipe()
hostCopy := func() error {
defer reader.Close()
@@ -334,6 +338,10 @@ func copyToContainer(container string, containerPath string, hostPath string) er
stdinFile = tmpFile.Name()
}
+ if hostInfo.IsDir && !containerInfo.IsDir {
+ return errors.New("destination must be a directory when copying a directory")
+ }
+
reader, writer := io.Pipe()
hostCopy := func() error {
defer writer.Close()