rootless: copy some settings from the global configuration
if some paths are overriden in the global configuration file, be sure that rootless podman honors them. Closes: https://github.com/containers/libpod/issues/2174 Signed-off-by: Giuseppe Scrivano <gscrivan@redhat.com>
This commit is contained in:
parent
778f9867fd
commit
61979d8ac2
|
@ -385,6 +385,28 @@ func NewRuntime(options ...RuntimeOption) (runtime *Runtime, err error) {
|
|||
if _, err := toml.Decode(string(contents), runtime.config); err != nil {
|
||||
return nil, errors.Wrapf(err, "error decoding configuration file %s", configPath)
|
||||
}
|
||||
} else if rootless.IsRootless() {
|
||||
// If the configuration file was not found but we are running in rootless, a subset of the
|
||||
// global config file is used.
|
||||
for _, path := range []string{OverrideConfigPath, ConfigPath} {
|
||||
contents, err := ioutil.ReadFile(OverrideConfigPath)
|
||||
if err != nil {
|
||||
// Ignore any error, the file might not be readable by us.
|
||||
continue
|
||||
}
|
||||
tmpConfig := new(RuntimeConfig)
|
||||
if _, err := toml.Decode(string(contents), tmpConfig); err != nil {
|
||||
return nil, errors.Wrapf(err, "error decoding configuration file %s", path)
|
||||
}
|
||||
|
||||
// Cherry pick the settings we want from the global configuration
|
||||
runtime.config.ConmonPath = tmpConfig.ConmonPath
|
||||
runtime.config.ConmonEnvVars = tmpConfig.ConmonEnvVars
|
||||
runtime.config.OCIRuntimes = tmpConfig.OCIRuntimes
|
||||
runtime.config.CNIPluginDir = tmpConfig.CNIPluginDir
|
||||
runtime.config.NoPivotRoot = tmpConfig.NoPivotRoot
|
||||
break
|
||||
}
|
||||
}
|
||||
|
||||
// Overwrite config with user-given configuration options
|
||||
|
|
Loading…
Reference in New Issue