[TOML ConfigSource] add support for executing fallback CLI commands

Signed-off-by: Tariq Ibrahim <tibrahim@nvidia.com>
Co-authored-by: Evan Lezar <elezar@nvidia.com>
This commit is contained in:
Tariq Ibrahim 2024-10-22 18:20:52 -07:00
parent 3c07ea0b17
commit 0f7aba9c3c
No known key found for this signature in database
GPG Key ID: 8367AA3C6B8DF06D
4 changed files with 50 additions and 8 deletions

View File

@ -128,8 +128,7 @@ func (c *Config) GetRuntimeConfig(name string) (engine.RuntimeConfig, error) {
// CommandLineSource returns the CLI-based containerd config loader // CommandLineSource returns the CLI-based containerd config loader
func CommandLineSource(hostRoot string) toml.Loader { func CommandLineSource(hostRoot string) toml.Loader {
commandLine := chrootIfRequired(hostRoot, "containerd", "config", "dump") return toml.FromCommandLine(chrootIfRequired(hostRoot, "containerd", "config", "dump")...)
return toml.FromCommandLine(commandLine[0], commandLine[1:]...)
} }
func chrootIfRequired(hostRoot string, commandLine ...string) []string { func chrootIfRequired(hostRoot string, commandLine ...string) []string {

View File

@ -155,8 +155,10 @@ func (c *Config) GetRuntimeConfig(name string) (engine.RuntimeConfig, error) {
// CommandLineSource returns the CLI-based crio config loader // CommandLineSource returns the CLI-based crio config loader
func CommandLineSource(hostRoot string) toml.Loader { func CommandLineSource(hostRoot string) toml.Loader {
commandLine := chrootIfRequired(hostRoot, "crio", "status", "config") return toml.LoadFirst(
return toml.FromCommandLine(commandLine[0], commandLine[1:]...) toml.FromCommandLine(chrootIfRequired(hostRoot, "crio", "status", "config")...),
toml.FromCommandLine(chrootIfRequired(hostRoot, "crio-status", "config")...),
)
} }
func chrootIfRequired(hostRoot string, commandLine ...string) []string { func chrootIfRequired(hostRoot string, commandLine ...string) []string {

41
pkg/config/toml/list.go Normal file
View File

@ -0,0 +1,41 @@
/**
# Copyright 2024 NVIDIA CORPORATION
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
**/
package toml
import "errors"
type firstOf []Loader
func LoadFirst(loaders ...Loader) Loader {
return firstOf(loaders)
}
func (loaders firstOf) Load() (*Tree, error) {
var errs error
for _, loader := range loaders {
if loader == nil {
continue
}
tree, err := loader.Load()
if err != nil {
errs = errors.Join(errs, err)
continue
}
return tree, nil
}
return nil, errs
}

View File

@ -36,12 +36,12 @@ func FromFile(path string) Loader {
// FromCommandLine creates a TOML source from the output of a shell command and its corresponding args. // FromCommandLine creates a TOML source from the output of a shell command and its corresponding args.
// If the command is empty, an empty config is returned. // If the command is empty, an empty config is returned.
func FromCommandLine(cmd string, args ...string) Loader { func FromCommandLine(cmds ...string) Loader {
if len(cmd) == 0 { if len(cmds) == 0 {
return Empty return Empty
} }
return &tomlCliSource{ return &tomlCliSource{
command: cmd, command: cmds[0],
args: args, args: cmds[1:],
} }
} }