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