mirror of
https://github.com/containers/podman.git
synced 2025-06-23 02:18:13 +08:00
Merge pull request #6743 from giuseppe/specify-mappings-to-storage
libpod: specify mappings to the storage
This commit is contained in:
@ -22,6 +22,7 @@ import (
|
|||||||
"github.com/containers/libpod/pkg/selinux"
|
"github.com/containers/libpod/pkg/selinux"
|
||||||
"github.com/containers/storage"
|
"github.com/containers/storage"
|
||||||
"github.com/containers/storage/pkg/archive"
|
"github.com/containers/storage/pkg/archive"
|
||||||
|
"github.com/containers/storage/pkg/idtools"
|
||||||
"github.com/containers/storage/pkg/mount"
|
"github.com/containers/storage/pkg/mount"
|
||||||
securejoin "github.com/cyphar/filepath-securejoin"
|
securejoin "github.com/cyphar/filepath-securejoin"
|
||||||
spec "github.com/opencontainers/runtime-spec/specs-go"
|
spec "github.com/opencontainers/runtime-spec/specs-go"
|
||||||
@ -360,6 +361,25 @@ func (c *Container) setupStorageMapping(dest, from *storage.IDMappingOptions) {
|
|||||||
}
|
}
|
||||||
dest.AutoUserNsOpts.InitialSize = initialSize + 1
|
dest.AutoUserNsOpts.InitialSize = initialSize + 1
|
||||||
}
|
}
|
||||||
|
} else if c.config.Spec.Linux != nil {
|
||||||
|
dest.UIDMap = nil
|
||||||
|
for _, r := range c.config.Spec.Linux.UIDMappings {
|
||||||
|
u := idtools.IDMap{
|
||||||
|
ContainerID: int(r.ContainerID),
|
||||||
|
HostID: int(r.HostID),
|
||||||
|
Size: int(r.Size),
|
||||||
|
}
|
||||||
|
dest.UIDMap = append(dest.UIDMap, u)
|
||||||
|
}
|
||||||
|
dest.GIDMap = nil
|
||||||
|
for _, r := range c.config.Spec.Linux.GIDMappings {
|
||||||
|
g := idtools.IDMap{
|
||||||
|
ContainerID: int(r.ContainerID),
|
||||||
|
HostID: int(r.HostID),
|
||||||
|
Size: int(r.Size),
|
||||||
|
}
|
||||||
|
dest.GIDMap = append(dest.GIDMap, g)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -89,6 +89,13 @@ var _ = Describe("Podman UserNS support", func() {
|
|||||||
Expect(ok).To(BeTrue())
|
Expect(ok).To(BeTrue())
|
||||||
})
|
})
|
||||||
|
|
||||||
|
It("podman --userns=keep-id root owns /usr", func() {
|
||||||
|
session := podmanTest.Podman([]string{"run", "--userns=keep-id", "alpine", "stat", "-c%u", "/usr"})
|
||||||
|
session.WaitWithDefaultTimeout()
|
||||||
|
Expect(session.ExitCode()).To(Equal(0))
|
||||||
|
Expect(session.OutputToString()).To(Equal("0"))
|
||||||
|
})
|
||||||
|
|
||||||
It("podman --userns=keep-id --user root:root", func() {
|
It("podman --userns=keep-id --user root:root", func() {
|
||||||
session := podmanTest.Podman([]string{"run", "--userns=keep-id", "--user", "root:root", "alpine", "id", "-u"})
|
session := podmanTest.Podman([]string{"run", "--userns=keep-id", "--user", "root:root", "alpine", "id", "-u"})
|
||||||
session.WaitWithDefaultTimeout()
|
session.WaitWithDefaultTimeout()
|
||||||
|
Reference in New Issue
Block a user