mirror of
https://github.com/containers/podman.git
synced 2025-06-03 12:17:13 +08:00
set process labels in pkg/spec
Set the (default) process labels in `pkg/spec`. This way, we can also query libpod.conf and disable labeling if needed. Fixes: #5087 Signed-off-by: Valentin Rothberg <rothberg@redhat.com>
This commit is contained in:
@ -241,14 +241,6 @@ func (config *CreateConfig) createConfigToOCISpec(runtime *libpod.Runtime, userM
|
||||
}
|
||||
|
||||
// SECURITY OPTS
|
||||
g.SetProcessNoNewPrivileges(config.Security.NoNewPrivs)
|
||||
|
||||
if !config.Security.Privileged {
|
||||
g.SetProcessApparmorProfile(config.Security.ApparmorProfile)
|
||||
}
|
||||
|
||||
blockAccessToKernelFilesystems(config, &g)
|
||||
|
||||
var runtimeConfig *libpodconfig.Config
|
||||
|
||||
if runtime != nil {
|
||||
@ -258,6 +250,26 @@ func (config *CreateConfig) createConfigToOCISpec(runtime *libpod.Runtime, userM
|
||||
}
|
||||
}
|
||||
|
||||
g.SetProcessNoNewPrivileges(config.Security.NoNewPrivs)
|
||||
|
||||
if !config.Security.Privileged {
|
||||
g.SetProcessApparmorProfile(config.Security.ApparmorProfile)
|
||||
}
|
||||
|
||||
// Unless already set via the CLI, check if we need to disable process
|
||||
// labels or set the defaults.
|
||||
if len(config.Security.LabelOpts) == 0 && runtimeConfig != nil {
|
||||
if !runtimeConfig.EnableLabeling {
|
||||
// Disabled in the config.
|
||||
config.Security.LabelOpts = append(config.Security.LabelOpts, "disable")
|
||||
} else if err := config.Security.SetLabelOpts(runtime, &config.Pid, &config.Ipc); err != nil {
|
||||
// Defaults!
|
||||
return nil, err
|
||||
}
|
||||
}
|
||||
|
||||
blockAccessToKernelFilesystems(config, &g)
|
||||
|
||||
// RESOURCES - PIDS
|
||||
if config.Resources.PidsLimit > 0 {
|
||||
// if running on rootless on a cgroupv1 machine or using the cgroupfs manager, pids
|
||||
|
Reference in New Issue
Block a user