diff options
author | OpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com> | 2020-02-12 18:46:35 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-02-12 18:46:35 +0100 |
commit | dd5df42be94ee6df9351a45eea563df146e9212e (patch) | |
tree | d70fdf10764daa90f94612a323c53053d2cf24aa /libpod/container_internal.go | |
parent | 0e9c637c42c881588c5a648654dfce42a1e980ee (diff) | |
parent | c140ecdc9b416ab4efd4d21d14acd63b6adbdd42 (diff) | |
download | podman-dd5df42be94ee6df9351a45eea563df146e9212e.tar.gz podman-dd5df42be94ee6df9351a45eea563df146e9212e.tar.bz2 podman-dd5df42be94ee6df9351a45eea563df146e9212e.zip |
Merge pull request #5168 from mheon/do_not_overwrite_volumes
Do not copy up when volume is not empty
Diffstat (limited to 'libpod/container_internal.go')
-rw-r--r-- | libpod/container_internal.go | 28 |
1 files changed, 22 insertions, 6 deletions
diff --git a/libpod/container_internal.go b/libpod/container_internal.go index 78ec09f29..216bbe669 100644 --- a/libpod/container_internal.go +++ b/libpod/container_internal.go @@ -1383,18 +1383,34 @@ func (c *Container) mountNamedVolume(v *ContainerNamedVolume, mountpoint string) } if vol.state.NeedsCopyUp { logrus.Debugf("Copying up contents from container %s to volume %s", c.ID(), vol.Name()) + + // Set NeedsCopyUp to false immediately, so we don't try this + // again when there are already files copied. + vol.state.NeedsCopyUp = false + if err := vol.save(); err != nil { + return nil, err + } + + // If the volume is not empty, we should not copy up. + volMount := vol.MountPoint() + contents, err := ioutil.ReadDir(volMount) + if err != nil { + return nil, errors.Wrapf(err, "error listing contents of volume %s mountpoint when copying up from container %s", vol.Name(), c.ID()) + } + if len(contents) > 0 { + // The volume is not empty. It was likely modified + // outside of Podman. For safety, let's not copy up into + // it. Fixes CVE-2020-1726. + return vol, nil + } + srcDir, err := securejoin.SecureJoin(mountpoint, v.Dest) if err != nil { return nil, errors.Wrapf(err, "error calculating destination path to copy up container %s volume %s", c.ID(), vol.Name()) } - if err := c.copyWithTarFromImage(srcDir, vol.MountPoint()); err != nil && !os.IsNotExist(err) { + if err := c.copyWithTarFromImage(srcDir, volMount); err != nil && !os.IsNotExist(err) { return nil, errors.Wrapf(err, "error copying content from container %s into volume %s", c.ID(), vol.Name()) } - - vol.state.NeedsCopyUp = false - if err := vol.save(); err != nil { - return nil, err - } } return vol, nil } |