diff options
author | cdoern <cdoern@redhat.com> | 2022-06-03 11:01:22 -0400 |
---|---|---|
committer | cdoern <cdoern@redhat.com> | 2022-06-09 10:30:48 -0400 |
commit | b13fc1bf983860d0627155ddbbbf28bf09e29a9e (patch) | |
tree | b527f316d0a1cca506a3a6cbc6e508705aa40ea6 /libpod/pod.go | |
parent | 0dda4681927b3428a113c81d851d962da8dd7302 (diff) | |
download | podman-b13fc1bf983860d0627155ddbbbf28bf09e29a9e.tar.gz podman-b13fc1bf983860d0627155ddbbbf28bf09e29a9e.tar.bz2 podman-b13fc1bf983860d0627155ddbbbf28bf09e29a9e.zip |
patch for pod host networking & other host namespace handling
this patch included additonal host namespace checks when creating a ctr as well
as fixing of the tests to check /proc/self/ns/net
see #14461
Signed-off-by: cdoern <cdoern@redhat.com>
Diffstat (limited to 'libpod/pod.go')
-rw-r--r-- | libpod/pod.go | 27 |
1 files changed, 3 insertions, 24 deletions
diff --git a/libpod/pod.go b/libpod/pod.go index 3c8dc43d4..108317637 100644 --- a/libpod/pod.go +++ b/libpod/pod.go @@ -178,8 +178,8 @@ func (p *Pod) NetworkMode() string { return infra.NetworkMode() } -// PidMode returns the PID mode given by the user ex: pod, private... -func (p *Pod) PidMode() string { +// Namespace Mode returns the given NS mode provided by the user ex: host, private... +func (p *Pod) NamespaceMode(kind specs.LinuxNamespaceType) string { infra, err := p.runtime.GetContainer(p.state.InfraContainerID) if err != nil { return "" @@ -187,28 +187,7 @@ func (p *Pod) PidMode() string { ctrSpec := infra.config.Spec if ctrSpec != nil && ctrSpec.Linux != nil { for _, ns := range ctrSpec.Linux.Namespaces { - if ns.Type == specs.PIDNamespace { - if ns.Path != "" { - return fmt.Sprintf("ns:%s", ns.Path) - } - return "private" - } - } - return "host" - } - return "" -} - -// PidMode returns the PID mode given by the user ex: pod, private... -func (p *Pod) UserNSMode() string { - infra, err := p.infraContainer() - if err != nil { - return "" - } - ctrSpec := infra.config.Spec - if ctrSpec != nil && ctrSpec.Linux != nil { - for _, ns := range ctrSpec.Linux.Namespaces { - if ns.Type == specs.UserNamespace { + if ns.Type == kind { if ns.Path != "" { return fmt.Sprintf("ns:%s", ns.Path) } |