package config import ( "fmt" "runtime" "github.com/docker/engine-api/types" composeConfig "github.com/docker/libcompose/config" "github.com/rancher/os/config/cloudinit/config" "github.com/rancher/os/config/yaml" "github.com/rancher/os/netconf" ) const ( OEM = "/usr/share/ros/oem" DockerBin = "/usr/bin/docker" DockerDistBin = "/usr/bin/docker.dist" RosBin = "/usr/bin/ros" SysInitBin = "/usr/bin/ros-sysinit" SystemDockerHome = "/var/lib/system-docker" SystemDockerHost = "unix:///var/run/system-docker.sock" DockerHost = "unix:///var/run/docker.sock" ImagesPath = "/usr/share/ros" ImagesPattern = "images*.tar" ModulesArchive = "/modules.tar" Debug = false SystemDockerLog = "/var/log/system-docker.log" SystemDockerBin = "/usr/bin/system-docker" HashLabel = "io.rancher.os.hash" IDLabel = "io.rancher.os.id" DetachLabel = "io.rancher.os.detach" CreateOnlyLabel = "io.rancher.os.createonly" ReloadConfigLabel = "io.rancher.os.reloadconfig" ConsoleLabel = "io.rancher.os.console" ScopeLabel = "io.rancher.os.scope" RebuildLabel = "io.docker.compose.rebuild" System = "system" OsConfigFile = "/usr/share/ros/os-config.yml" VarRancherDir = "/var/lib/rancher" CloudConfigDir = "/var/lib/rancher/conf/cloud-config.d" CloudConfigInitFile = "/var/lib/rancher/conf/cloud-config.d/init.yml" CloudConfigBootFile = "/var/lib/rancher/conf/cloud-config.d/boot.yml" CloudConfigNetworkFile = "/var/lib/rancher/conf/cloud-config.d/network.yml" CloudConfigScriptFile = "/var/lib/rancher/conf/cloud-config-script" MetaDataFile = "/var/lib/rancher/conf/metadata" CloudConfigFile = "/var/lib/rancher/conf/cloud-config.yml" EtcResolvConfFile = "/etc/resolv.conf" ) var ( OemConfigFile = OEM + "/oem-config.yml" Version string BuildDate string Arch string Suffix string OsRepo string OsBase string PrivateKeys = []string{ "rancher.ssh", "rancher.docker.ca_key", "rancher.docker.ca_cert", "rancher.docker.server_key", "rancher.docker.server_cert", } ) func init() { if Version == "" { Version = "v0.0.0-dev" } if Arch == "" { Arch = runtime.GOARCH } if Suffix == "" && Arch != "amd64" { Suffix = "_" + Arch } if OsBase == "" { OsBase = fmt.Sprintf("%s/os-base:%s%s", OsRepo, Version, Suffix) } } type Repository struct { URL string `yaml:"url,omitempty"` } type Repositories map[string]Repository type CloudConfig struct { SSHAuthorizedKeys []string `yaml:"ssh_authorized_keys,omitempty"` WriteFiles []File `yaml:"write_files,omitempty"` Hostname string `yaml:"hostname,omitempty"` Mounts [][]string `yaml:"mounts,omitempty"` Rancher RancherConfig `yaml:"rancher,omitempty"` Runcmd []yaml.StringandSlice `yaml:"runcmd,omitempty"` Bootcmd []yaml.StringandSlice `yaml:"bootcmd,omitempty"` } type File struct { config.File Container string `yaml:"container,omitempty"` } type RancherConfig struct { Console string `yaml:"console,omitempty"` Environment map[string]string `yaml:"environment,omitempty"` Services map[string]*composeConfig.ServiceConfigV1 `yaml:"services,omitempty"` BootstrapContainers map[string]*composeConfig.ServiceConfigV1 `yaml:"bootstrap,omitempty"` CloudInitServices map[string]*composeConfig.ServiceConfigV1 `yaml:"cloud_init_services,omitempty"` BootstrapDocker DockerConfig `yaml:"bootstrap_docker,omitempty"` CloudInit CloudInit `yaml:"cloud_init,omitempty"` Debug bool `yaml:"debug,omitempty"` RmUsr bool `yaml:"rm_usr,omitempty"` NoSharedRoot bool `yaml:"no_sharedroot,omitempty"` Log bool `yaml:"log,omitempty"` ForceConsoleRebuild bool `yaml:"force_console_rebuild,omitempty"` Recovery bool `yaml:"recovery,omitempty"` Disable []string `yaml:"disable,omitempty"` ServicesInclude map[string]bool `yaml:"services_include,omitempty"` Modules []string `yaml:"modules,omitempty"` Network netconf.NetworkConfig `yaml:"network,omitempty"` DefaultNetwork netconf.NetworkConfig `yaml:"default_network,omitempty"` Repositories Repositories `yaml:"repositories,omitempty"` SSH SSHConfig `yaml:"ssh,omitempty"` State StateConfig `yaml:"state,omitempty"` SystemDocker DockerConfig `yaml:"system_docker,omitempty"` Upgrade UpgradeConfig `yaml:"upgrade,omitempty"` Docker DockerConfig `yaml:"docker,omitempty"` RegistryAuths map[string]types.AuthConfig `yaml:"registry_auths,omitempty"` Defaults Defaults `yaml:"defaults,omitempty"` ResizeDevice string `yaml:"resize_device,omitempty"` Sysctl map[string]string `yaml:"sysctl,omitempty"` RestartServices []string `yaml:"restart_services,omitempty"` HypervisorService bool `yaml:"hypervisor_service,omitempty"` ShutdownTimeout int `yaml:"shutdown_timeout,omitempty"` } type UpgradeConfig struct { URL string `yaml:"url,omitempty"` Image string `yaml:"image,omitempty"` Rollback string `yaml:"rollback,omitempty"` } type EngineOpts struct { Bridge string `yaml:"bridge,omitempty" opt:"bridge"` ConfigFile string `yaml:"config_file,omitempty" opt:"config-file"` Containerd string `yaml:"containerd,omitempty" opt:"containerd"` Debug *bool `yaml:"debug,omitempty" opt:"debug"` ExecRoot string `yaml:"exec_root,omitempty" opt:"exec-root"` Group string `yaml:"group,omitempty" opt:"group"` Graph string `yaml:"graph,omitempty" opt:"graph"` Host []string `yaml:"host,omitempty" opt:"host"` InsecureRegistry []string `yaml:"insecure_registry" opt:"insecure-registry"` LiveRestore *bool `yaml:"live_restore,omitempty" opt:"live-restore"` LogDriver string `yaml:"log_driver,omitempty" opt:"log-driver"` LogOpts map[string]string `yaml:"log_opts,omitempty" opt:"log-opt"` PidFile string `yaml:"pid_file,omitempty" opt:"pidfile"` RegistryMirror string `yaml:"registry_mirror,omitempty" opt:"registry-mirror"` Restart *bool `yaml:"restart,omitempty" opt:"restart"` SelinuxEnabled *bool `yaml:"selinux_enabled,omitempty" opt:"selinux-enabled"` StorageDriver string `yaml:"storage_driver,omitempty" opt:"storage-driver"` UserlandProxy *bool `yaml:"userland_proxy,omitempty" opt:"userland-proxy"` } type DockerConfig struct { EngineOpts Engine string `yaml:"engine,omitempty"` TLS bool `yaml:"tls,omitempty"` TLSArgs []string `yaml:"tls_args,flow,omitempty"` ExtraArgs []string `yaml:"extra_args,flow,omitempty"` ServerCert string `yaml:"server_cert,omitempty"` ServerKey string `yaml:"server_key,omitempty"` CACert string `yaml:"ca_cert,omitempty"` CAKey string `yaml:"ca_key,omitempty"` Environment []string `yaml:"environment,omitempty"` StorageContext string `yaml:"storage_context,omitempty"` Exec bool `yaml:"exec,omitempty"` } type SSHConfig struct { Keys map[string]string `yaml:"keys,omitempty"` Daemon bool `yaml:"daemon,omitempty"` } type StateConfig struct { Directory string `yaml:"directory,omitempty"` FsType string `yaml:"fstype,omitempty"` Dev string `yaml:"dev,omitempty"` Wait bool `yaml:"wait,omitempty"` Required bool `yaml:"required,omitempty"` Autoformat []string `yaml:"autoformat,omitempty"` MdadmScan bool `yaml:"mdadm_scan,omitempty"` Script string `yaml:"script,omitempty"` OemFsType string `yaml:"oem_fstype,omitempty"` OemDev string `yaml:"oem_dev,omitempty"` } type CloudInit struct { Datasources []string `yaml:"datasources,omitempty"` } type Defaults struct { Hostname string `yaml:"hostname,omitempty"` Docker DockerConfig `yaml:"docker,omitempty"` Network netconf.NetworkConfig `yaml:"network,omitempty"` } func (r Repositories) ToArray() []string { result := make([]string, 0, len(r)) for _, repo := range r { if repo.URL != "" { result = append(result, repo.URL) } } return result }