kpod must parse the crio configuration file or the storage is not set up correctly. By default it is not. We now read /etc/crio/crio.conf in as the configuration file unless it is overriden by the user and the global -c|--config switch. Signed-off-by: baude <bbaude@redhat.com>
		
			
				
	
	
		
			112 lines
		
	
	
	
		
			3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			112 lines
		
	
	
	
		
			3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package server
 | |
| 
 | |
| import (
 | |
| 	"bytes"
 | |
| 	"io/ioutil"
 | |
| 
 | |
| 	"github.com/BurntSushi/toml"
 | |
| 	"github.com/kubernetes-incubator/cri-o/libkpod"
 | |
| )
 | |
| 
 | |
| //CrioConfigPath is the default location for the conf file
 | |
| const CrioConfigPath = "/etc/crio/crio.conf"
 | |
| 
 | |
| // Config represents the entire set of configuration values that can be set for
 | |
| // the server. This is intended to be loaded from a toml-encoded config file.
 | |
| type Config struct {
 | |
| 	libkpod.Config
 | |
| 	APIConfig
 | |
| }
 | |
| 
 | |
| // APIConfig represents the "crio.api" TOML config table.
 | |
| type APIConfig struct {
 | |
| 	// Listen is the path to the AF_LOCAL socket on which cri-o will listen.
 | |
| 	// This may support proto://addr formats later, but currently this is just
 | |
| 	// a path.
 | |
| 	Listen string `toml:"listen"`
 | |
| 
 | |
| 	// StreamAddress is the IP address on which the stream server will listen.
 | |
| 	StreamAddress string `toml:"stream_address"`
 | |
| 
 | |
| 	// StreamPort is the port on which the stream server will listen.
 | |
| 	StreamPort string `toml:"stream_port"`
 | |
| }
 | |
| 
 | |
| // tomlConfig is another way of looking at a Config, which is
 | |
| // TOML-friendly (it has all of the explicit tables). It's just used for
 | |
| // conversions.
 | |
| type tomlConfig struct {
 | |
| 	Crio struct {
 | |
| 		libkpod.RootConfig
 | |
| 		API     struct{ APIConfig }             `toml:"api"`
 | |
| 		Runtime struct{ libkpod.RuntimeConfig } `toml:"runtime"`
 | |
| 		Image   struct{ libkpod.ImageConfig }   `toml:"image"`
 | |
| 		Network struct{ libkpod.NetworkConfig } `toml:"network"`
 | |
| 	} `toml:"crio"`
 | |
| }
 | |
| 
 | |
| func (t *tomlConfig) toConfig(c *Config) {
 | |
| 	c.RootConfig = t.Crio.RootConfig
 | |
| 	c.APIConfig = t.Crio.API.APIConfig
 | |
| 	c.RuntimeConfig = t.Crio.Runtime.RuntimeConfig
 | |
| 	c.ImageConfig = t.Crio.Image.ImageConfig
 | |
| 	c.NetworkConfig = t.Crio.Network.NetworkConfig
 | |
| }
 | |
| 
 | |
| func (t *tomlConfig) fromConfig(c *Config) {
 | |
| 	t.Crio.RootConfig = c.RootConfig
 | |
| 	t.Crio.API.APIConfig = c.APIConfig
 | |
| 	t.Crio.Runtime.RuntimeConfig = c.RuntimeConfig
 | |
| 	t.Crio.Image.ImageConfig = c.ImageConfig
 | |
| 	t.Crio.Network.NetworkConfig = c.NetworkConfig
 | |
| }
 | |
| 
 | |
| // UpdateFromFile populates the Config from the TOML-encoded file at the given path.
 | |
| // Returns errors encountered when reading or parsing the files, or nil
 | |
| // otherwise.
 | |
| func (c *Config) UpdateFromFile(path string) error {
 | |
| 	data, err := ioutil.ReadFile(path)
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	t := new(tomlConfig)
 | |
| 	t.fromConfig(c)
 | |
| 
 | |
| 	_, err = toml.Decode(string(data), t)
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	t.toConfig(c)
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // ToFile outputs the given Config as a TOML-encoded file at the given path.
 | |
| // Returns errors encountered when generating or writing the file, or nil
 | |
| // otherwise.
 | |
| func (c *Config) ToFile(path string) error {
 | |
| 	var w bytes.Buffer
 | |
| 	e := toml.NewEncoder(&w)
 | |
| 
 | |
| 	t := new(tomlConfig)
 | |
| 	t.fromConfig(c)
 | |
| 
 | |
| 	if err := e.Encode(*t); err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	return ioutil.WriteFile(path, w.Bytes(), 0644)
 | |
| }
 | |
| 
 | |
| // DefaultConfig returns the default configuration for crio.
 | |
| func DefaultConfig() *Config {
 | |
| 	return &Config{
 | |
| 		Config: *libkpod.DefaultConfig(),
 | |
| 		APIConfig: APIConfig{
 | |
| 			Listen:        "/var/run/crio.sock",
 | |
| 			StreamAddress: "",
 | |
| 			StreamPort:    "10010",
 | |
| 		},
 | |
| 	}
 | |
| }
 |