diff options
author | Matthew Heon <mheon@redhat.com> | 2020-12-07 11:50:47 -0500 |
---|---|---|
committer | Matthew Heon <mheon@redhat.com> | 2020-12-07 11:50:47 -0500 |
commit | c050fad958fb86a2647bf318671e348fb2fa1904 (patch) | |
tree | d691fef44ba265f51c72fa341326c4938f797f97 | |
parent | dc5da90523f35146f5368a31be7edf39be13beb4 (diff) | |
download | podman-c050fad958fb86a2647bf318671e348fb2fa1904.tar.gz podman-c050fad958fb86a2647bf318671e348fb2fa1904.tar.bz2 podman-c050fad958fb86a2647bf318671e348fb2fa1904.zip |
Change name of imageVolumes in container config JSON
Podman pre-1.8 also included a field with this name, which was a
String. Podman 2.2.0 added a new field reusing the name but as a
Struct. This completely broke JSON decode for pre-1.8 containers
in Podman 2.2, resulting in completely broken behavior.
Re-name the JSON field and add a note that the old name should
not be re-used to prevent this problem from re-occurring. This
will still result in containers from 2.2.0 being broken
(specifically, containers with image volumes will have them
disappear) but this is the lesser of two evils.
Fixes #8613
Signed-off-by: Matthew Heon <mheon@redhat.com>
-rw-r--r-- | libpod/container_config.go | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/libpod/container_config.go b/libpod/container_config.go index cc3ad25ea..c95be9b55 100644 --- a/libpod/container_config.go +++ b/libpod/container_config.go @@ -135,7 +135,13 @@ type ContainerRootFSConfig struct { // OverlayVolumes lists the overlay volumes to mount into the container. OverlayVolumes []*ContainerOverlayVolume `json:"overlayVolumes,omitempty"` // ImageVolumes lists the image volumes to mount into the container. - ImageVolumes []*ContainerImageVolume `json:"imageVolumes,omitempty"` + // Please note that this is named ctrImageVolumes in JSON to + // distinguish between these and the old `imageVolumes` field in Podman + // pre-1.8, which was used in very old Podman versions to determine how + // image volumes were handled in Libpod (support for these eventually + // moved out of Libpod into pkg/specgen). + // Please DO NOT re-use the `imageVolumes` name in container JSON again. + ImageVolumes []*ContainerImageVolume `json:"ctrImageVolumes,omitempty"` // CreateWorkingDir indicates that Libpod should create the container's // working directory if it does not exist. Some OCI runtimes do this by // default, but others do not. |