Documentation ¶
Index ¶
- Constants
- Variables
- func CloudConfigDirFiles(dirPrefix string) []string
- func ConvertKeysToStrings(item interface{}) interface{}
- func Export(private, full bool) (string, error)
- func Get(key string) (interface{}, error)
- func GetKernelVersion() string
- func Insert(m interface{}, args ...interface{}) interface{}
- func Merge(bytes []byte) error
- func SaveInitCmdline(cmdLineArgs string)
- func Set(key string, value interface{}) error
- func ValidateBytes(bytes []byte) (*gojsonschema.Result, error)
- func ValidateRawCfg(rawCfg interface{}) (*gojsonschema.Result, error)
- func WriteToFile(data interface{}, filename string) error
- type CfgFunc
- type CfgFuncData
- type CfgFuncs
- type CloudConfig
- func ChainCfgFuncs(cfg *CloudConfig, cfgFuncs CfgFuncs) (*CloudConfig, error)
- func LoadConfig() *CloudConfig
- func LoadConfigWithError() (*CloudConfig, *gojsonschema.Result, error)
- func LoadConfigWithPrefix(dirPrefix string) *CloudConfig
- func ReadConfig(bytes []byte, substituteMetadataVars bool, files ...string) (*CloudConfig, error)
- type CloudInit
- type Defaults
- type DockerConfig
- type EngineOpts
- type File
- type RancherConfig
- type Repositories
- type Repository
- type SSHConfig
- type StateConfig
- type UpgradeConfig
Constants ¶
View Source
const ( OemDir = "/usr/share/ros/oem" BootDir = "/boot" StateDir = "/state" RosBin = "/usr/bin/ros" SysInitBin = "/usr/bin/ros-sysinit" SystemDockerHost = "unix:///var/run/system-docker.sock" DockerHost = "unix:///var/run/docker.sock" ImagesPath = "/usr/share/ros" InitImages = "images-init.tar" SystemImages = "images-system.tar" UserImages = "images-user.tar" Debug = false SystemDockerBin = "/usr/bin/system-dockerd" DefaultDind = "maxive/os-dind:17.12.1" DetachLabel = "io.maxive.os.detach" CreateOnlyLabel = "io.maxive.os.createonly" ReloadConfigLabel = "io.maxive.os.reloadconfig" ConsoleLabel = "io.maxive.os.console" ScopeLabel = "io.maxive.os.scope" RebuildLabel = "io.docker.compose.rebuild" UserDockerLabel = "io.maxive.user_docker.name" UserDockerNetLabel = "io.maxive.user_docker.net" UserDockerFIPLabel = "io.maxive.user_docker.fix_ip" System = "system" OsConfigFile = "/usr/share/ros/os-config.yml" VarRancherDir = "/var/lib/maxive" CloudConfigDir = "/var/lib/maxive/conf/cloud-config.d" CloudConfigInitFile = "/var/lib/maxive/conf/cloud-config.d/init.yml" CloudConfigBootFile = "/var/lib/maxive/conf/cloud-config.d/boot.yml" CloudConfigNetworkFile = "/var/lib/maxive/conf/cloud-config.d/network.yml" CloudConfigScriptFile = "/var/lib/maxive/conf/cloud-config-script" MetaDataFile = "/var/lib/maxive/conf/metadata" CloudConfigFile = "/var/lib/maxive/conf/cloud-config.yml" EtcResolvConfFile = "/etc/resolv.conf" WPAConfigFile = "/etc/wpa_supplicant-%s.conf" WPATemplateFile = "/etc/wpa_supplicant.conf.tpl" DHCPCDConfigFile = "/etc/dhcpcd.conf" DHCPCDTemplateFile = "/etc/dhcpcd.conf.tpl" MultiDockerConfFile = "/var/lib/maxive/conf.d/m-user-docker.yml" MultiDockerDataDir = "/var/lib/m-user-docker" UdevRulesDir = "/etc/udev/rules.d" UdevRulesExtrasDir = "/lib/udev/rules-extras.d" )
View Source
const Banner = `` /* 209-byte string literal not displayed */
Variables ¶
View Source
var ( OemConfigFile = OemDir + "/oem-config.yml" Version string BuildDate string Arch string Suffix string OsRepo string OsBase string PrivateKeys = []string{ "maxive.ssh", "maxive.docker.ca_key", "maxive.docker.ca_cert", "maxive.docker.server_key", "maxive.docker.server_cert", } Additional = []string{ "maxive.password", "maxive.autologin", "EXTRA_CMDLINE", } SupportedDinds = []string{ "maxive/os-dind:17.12.1", "maxive/os-dind:18.03.1", } )
Functions ¶
func CloudConfigDirFiles ¶
func ConvertKeysToStrings ¶
func ConvertKeysToStrings(item interface{}) interface{}
ConvertKeysToStrings is temporarily copied from libcompose TODO: just import this in the future
func GetKernelVersion ¶
func GetKernelVersion() string
func SaveInitCmdline ¶
func SaveInitCmdline(cmdLineArgs string)
func ValidateBytes ¶
func ValidateBytes(bytes []byte) (*gojsonschema.Result, error)
func ValidateRawCfg ¶
func ValidateRawCfg(rawCfg interface{}) (*gojsonschema.Result, error)
func WriteToFile ¶
Types ¶
type CfgFunc ¶
type CfgFunc func(*CloudConfig) (*CloudConfig, error)
type CfgFuncData ¶
type CfgFuncs ¶
type CfgFuncs []CfgFuncData
type CloudConfig ¶
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"` Maxive RancherConfig `yaml:"maxive,omitempty"` Runcmd []yaml.StringandSlice `yaml:"runcmd,omitempty"` Bootcmd []yaml.StringandSlice `yaml:"bootcmd,omitempty"` }
func ChainCfgFuncs ¶
func ChainCfgFuncs(cfg *CloudConfig, cfgFuncs CfgFuncs) (*CloudConfig, error)
func LoadConfig ¶
func LoadConfig() *CloudConfig
func LoadConfigWithError ¶
func LoadConfigWithError() (*CloudConfig, *gojsonschema.Result, error)
func LoadConfigWithPrefix ¶
func LoadConfigWithPrefix(dirPrefix string) *CloudConfig
func ReadConfig ¶
func ReadConfig(bytes []byte, substituteMetadataVars bool, files ...string) (*CloudConfig, error)
type Defaults ¶
type Defaults struct { Hostname string `yaml:"hostname,omitempty"` Docker DockerConfig `yaml:"docker,omitempty"` Network netconf.NetworkConfig `yaml:"network,omitempty"` SystemDockerLogs string `yaml:"system_docker_logs,omitempty"` }
type DockerConfig ¶
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"` }
func (*DockerConfig) AppendEnv ¶
func (d *DockerConfig) AppendEnv() []string
func (*DockerConfig) FullArgs ¶
func (d *DockerConfig) FullArgs() []string
type EngineOpts ¶
type EngineOpts struct { Bridge string `yaml:"bridge,omitempty" opt:"bridge"` BIP string `yaml:"bip,omitempty" opt:"bip"` 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 RancherConfig ¶
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"` 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"` 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"` HTTPLoadRetries int `yaml:"http_load_retries,omitempty"` PreloadWait bool `yaml:"preload_wait,omitempty"` }
type Repositories ¶
type Repositories map[string]Repository
func (Repositories) ToArray ¶
func (r Repositories) ToArray() []string
type Repository ¶
type Repository struct {
URL string `yaml:"url,omitempty"`
}
type StateConfig ¶
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"` LvmScan bool `yaml:"lvm_scan,omitempty"` Cryptsetup bool `yaml:"cryptsetup,omitempty"` Rngd bool `yaml:"rngd,omitempty"` Script string `yaml:"script,omitempty"` OemFsType string `yaml:"oem_fstype,omitempty"` OemDev string `yaml:"oem_dev,omitempty"` BootFsType string `yaml:"boot_fstype,omitempty"` BootDev string `yaml:"boot_dev,omitempty"` }
Source Files ¶
Click to show internal directories.
Click to hide internal directories.