Files
dokku/plugins/scheduler-k3s/scheduler_k3s.go

204 lines
5.4 KiB
Go
Raw Permalink Normal View History

2023-12-19 00:17:56 -05:00
package scheduler_k3s
import (
"embed"
"sync"
certmanagerv1 "github.com/cert-manager/cert-manager/pkg/apis/certmanager/v1"
kedav1alpha1 "github.com/kedacore/keda/v2/apis/keda/v1alpha1"
traefikv1alpha1 "github.com/traefik/traefik/v2/pkg/provider/kubernetes/crd/traefikio/v1alpha1"
appsv1 "k8s.io/api/apps/v1"
batchv1 "k8s.io/api/batch/v1"
corev1 "k8s.io/api/core/v1"
"k8s.io/apimachinery/pkg/runtime"
"k8s.io/apimachinery/pkg/runtime/serializer"
kjson "k8s.io/apimachinery/pkg/runtime/serializer/json"
)
2023-12-19 00:17:56 -05:00
var (
// DefaultProperties is a map of all valid k3s properties with corresponding default property values
DefaultProperties = map[string]string{
"deploy-timeout": "",
"letsencrypt-server": "",
"kustomize-root-path": "",
"image-pull-secrets": "",
"namespace": "",
"rollback-on-failure": "",
"shm-size": "",
}
2023-12-19 00:17:56 -05:00
// GlobalProperties is a map of all valid global k3s properties
2023-12-19 00:17:56 -05:00
GlobalProperties = map[string]bool{
"deploy-timeout": true,
"image-pull-secrets": true,
"ingress-class": true,
"kube-context": true,
"kubeconfig-path": true,
"kustomize-root-path": true,
"letsencrypt-server": true,
"letsencrypt-email-prod": true,
"letsencrypt-email-stag": true,
"namespace": true,
"network-interface": true,
"rollback-on-failure": true,
"shm-size": true,
"token": true,
2023-12-19 00:17:56 -05:00
}
)
const DefaultIngressClass = "nginx"
const GlobalProcessType = "--global"
const KubeConfigPath = "/etc/rancher/k3s/k3s.yaml"
const DefaultKubeContext = ""
2024-02-28 11:44:02 -05:00
const TriggerAuthPropertyPrefix = "trigger-auth."
2024-01-18 18:55:03 -05:00
var (
runtimeScheme = runtime.NewScheme()
codecs = serializer.NewCodecFactory(runtimeScheme)
deserializer = codecs.UniversalDeserializer()
jsonSerializer = kjson.NewSerializerWithOptions(kjson.DefaultMetaFactory, runtimeScheme, runtimeScheme, kjson.SerializerOptions{})
)
var k8sNativeSchemeOnce sync.Once
type Manifest struct {
Name string
Version string
Path string
}
var KubernetesManifests = []Manifest{
{
Name: "system-upgrader",
Version: "0.13.2",
Path: "https://github.com/rancher/system-upgrade-controller/releases/download/v0.13.2/system-upgrade-controller.yaml",
},
}
type HelmChart struct {
ChartPath string
CreateNamespace bool
Namespace string
Path string
ReleaseName string
RepoURL string
Version string
}
var HelmCharts = []HelmChart{
2024-01-22 01:30:41 -05:00
{
ChartPath: "cert-manager",
CreateNamespace: true,
Namespace: "cert-manager",
ReleaseName: "cert-manager",
RepoURL: "https://charts.jetstack.io",
Version: "v1.13.3",
},
{
ChartPath: "longhorn",
CreateNamespace: true,
Namespace: "longhorn-system",
ReleaseName: "longhorn",
RepoURL: "https://charts.longhorn.io",
Version: "1.5.3",
2024-01-22 01:30:41 -05:00
},
{
ChartPath: "traefik",
CreateNamespace: true,
Namespace: "traefik",
ReleaseName: "traefik",
RepoURL: "https://helm.traefik.io/traefik",
Version: "26.0.0",
},
{
ChartPath: "ingress-nginx",
CreateNamespace: true,
Namespace: "ingress-nginx",
ReleaseName: "ingress-nginx",
RepoURL: "https://kubernetes.github.io/ingress-nginx",
2024-03-12 21:07:19 -04:00
Version: "4.10.0",
},
{
ChartPath: "keda",
CreateNamespace: true,
Namespace: "keda",
ReleaseName: "keda",
RepoURL: "https://kedacore.github.io/charts",
Version: "2.16.0",
},
2024-11-13 02:15:47 -05:00
{
ChartPath: "keda-add-ons-http",
CreateNamespace: true,
Namespace: "keda",
ReleaseName: "keda-add-ons-http",
RepoURL: "https://kedacore.github.io/charts",
Version: "0.8.0",
},
{
ChartPath: "vector",
CreateNamespace: true,
Namespace: "vector",
ReleaseName: "vector",
RepoURL: "https://helm.vector.dev",
Version: "0.42.0",
},
}
type HelmRepository struct {
Name string
URL string
}
var HelmRepositories = []HelmRepository{
{
Name: "jetstack",
URL: "https://charts.jetstack.io",
},
{
Name: "longhorn",
URL: "https://charts.longhorn.io",
},
{
Name: "traefik",
URL: "https://helm.traefik.io/traefik",
},
}
// NodeProfile is a profile for a node in the k3s cluster
type NodeProfile struct {
// Name is the name of the node profile
Name string `json:"name"`
// Role is the role of the node
Role string `json:"role"`
// AllowUknownHosts is whether to allow unknown hosts
AllowUknownHosts bool `json:"allow_unknown_hosts,omitempty"`
// TaintScheduling is whether to taint the node for scheduling
TaintScheduling bool `json:"taint_scheduling,omitempty"`
// KubeletArgs is a list of kubelet arguments
KubeletArgs []string `json:"kubelet_args,omitempty"`
}
// ServerLabels are the labels for a server node
var ServerLabels = map[string]string{
"svccontroller.k3s.cattle.io/enablelb": "true",
}
// WorkerLabels are the labels for a worker node
var WorkerLabels = map[string]string{
"node-role.kubernetes.io/worker": "worker",
}
//go:embed all:templates
var templates embed.FS
func init() {
k8sNativeSchemeOnce.Do(func() {
_ = appsv1.AddToScheme(runtimeScheme)
_ = batchv1.AddToScheme(runtimeScheme)
_ = certmanagerv1.AddToScheme(runtimeScheme)
_ = corev1.AddToScheme(runtimeScheme)
_ = traefikv1alpha1.AddToScheme(runtimeScheme)
_ = kedav1alpha1.AddToScheme(runtimeScheme)
})
}