mirror of
https://github.com/kairos-io/kairos-sdk.git
synced 2025-04-27 19:15:23 +00:00
77 lines
2.9 KiB
Go
77 lines
2.9 KiB
Go
package clusterplugin
|
|
|
|
type Role string
|
|
|
|
func (n *Role) MarshalYAML() (interface{}, error) {
|
|
return string(*n), nil
|
|
}
|
|
|
|
func (n *Role) UnmarshalYAML(unmarshal func(interface{}) error) error {
|
|
var val string
|
|
if err := unmarshal(&val); err != nil {
|
|
return err
|
|
}
|
|
|
|
*n = Role(val)
|
|
|
|
return nil
|
|
}
|
|
|
|
func (n *Role) MarshalJSON() ([]byte, error) {
|
|
return []byte(*n), nil
|
|
}
|
|
|
|
func (n *Role) UnmarshalJSON(val []byte) error {
|
|
*n = Role(val)
|
|
|
|
return nil
|
|
}
|
|
|
|
const (
|
|
// RoleInit denotes a special `RoleControlPlane` that can run special tasks to initialize the cluster. There will only ever be one node with this role in a cluster.
|
|
RoleInit = "init"
|
|
|
|
// RoleControlPlane denotes nodes that persist cluster information and host the kubernetes control plane.
|
|
RoleControlPlane = "controlplane"
|
|
|
|
// RoleWorker denotes a node that runs workloads in the cluster.
|
|
RoleWorker = "worker"
|
|
)
|
|
|
|
type Cluster struct {
|
|
// ClusterToken is a unique string that can be used to distinguish different clusters on networks with multiple clusters.
|
|
ClusterToken string `yaml:"cluster_token,omitempty" json:"cluster_token,omitempty"`
|
|
|
|
// ControlPlaneHost is a host that all nodes can resolve and use for node registration.
|
|
ControlPlaneHost string `yaml:"control_plane_host,omitempty" json:"control_plane_host,omitempty"`
|
|
|
|
// Role informs the sdk what kind of installation to manage on this device.
|
|
Role Role `yaml:"role,omitempty" json:"role,omitempty"`
|
|
|
|
// Options are arbitrary values the sdk may be interested in. These values are not validated by Kairos and are simply forwarded to the sdk.
|
|
Options string `yaml:"config,omitempty" json:"config,omitempty"`
|
|
|
|
// ProviderOptions are arbitrary, provider-specific values the sdk may be interested in. These values are not validated by Kairos and are simply forwarded to the sdk.
|
|
// ProviderOptions are meant to handle non-cluster values, while Options can be used for cluster-specific configuration values.
|
|
ProviderOptions map[string]string `yaml:"providerConfig,omitempty" json:"providerConfig,omitempty"`
|
|
|
|
// Env contains the list of environment variables to be set on the cluster
|
|
Env map[string]string `yaml:"env,omitempty" json:"env,omitempty"`
|
|
|
|
// CACerts list of trust certificates.
|
|
CACerts []string `yaml:"ca_certs,omitempty" json:"ca_certs,omitempty"`
|
|
|
|
// ImportLocalImages import local archive images to containerd on start.
|
|
ImportLocalImages bool `yaml:"import_local_images,omitempty" json:"import_local_images,omitempty"`
|
|
|
|
// LocalImagesPath path to local archive images to load into containerd from the filesystem start
|
|
LocalImagesPath string `yaml:"local_images_path,omitempty" json:"local_images_path,omitempty"`
|
|
|
|
// ClusterConfigPath path to the file where the final init config will be generated
|
|
ClusterConfigPath string `yaml:"cluster_config_path,omitempty" json:"clusterConfigPath,omitempty"`
|
|
}
|
|
|
|
type Config struct {
|
|
Cluster *Cluster `yaml:"cluster,omitempty" json:"cluster,omitempty"`
|
|
}
|