2022-09-05 03:06:08 -04:00
|
|
|
/*
|
|
|
|
Copyright (c) Edgeless Systems GmbH
|
|
|
|
|
|
|
|
SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
*/
|
|
|
|
|
2022-08-04 10:15:52 -04:00
|
|
|
package resources
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
2022-09-21 07:47:57 -04:00
|
|
|
"github.com/edgelesssys/constellation/v2/internal/kubernetes"
|
|
|
|
"github.com/edgelesssys/constellation/v2/internal/versions"
|
2022-08-04 10:15:52 -04:00
|
|
|
operatorsv1 "github.com/operator-framework/api/pkg/operators/v1"
|
|
|
|
operatorsv1alpha1 "github.com/operator-framework/api/pkg/operators/v1alpha1"
|
|
|
|
corev1 "k8s.io/api/core/v1"
|
|
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
nodeOperatorNamespace = "kube-system"
|
|
|
|
nodeOperatorCatalogNamespace = "olm"
|
|
|
|
)
|
|
|
|
|
|
|
|
// NodeOperatorCRDNames are the names of the custom resource definitions that are used by the node operator.
|
|
|
|
var NodeOperatorCRDNames = []string{
|
|
|
|
"autoscalingstrategies.update.edgeless.systems",
|
|
|
|
"nodeimages.update.edgeless.systems",
|
|
|
|
"pendingnodes.update.edgeless.systems",
|
|
|
|
"scalinggroups.update.edgeless.systems",
|
|
|
|
}
|
|
|
|
|
2022-11-09 09:57:54 -05:00
|
|
|
// NodeOperatorDeployment groups all deployments for node operator.
|
2022-10-05 09:02:46 -04:00
|
|
|
type NodeOperatorDeployment struct {
|
2022-08-28 09:57:08 -04:00
|
|
|
CatalogSource operatorsv1alpha1.CatalogSource
|
|
|
|
OperatorGroup operatorsv1.OperatorGroup
|
|
|
|
Subscription operatorsv1alpha1.Subscription
|
2022-08-04 10:15:52 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// NewNodeOperatorDeployment creates a new constellation node operator deployment.
|
|
|
|
// See /operators/constellation-node-operator for more information.
|
2022-10-05 09:02:46 -04:00
|
|
|
func NewNodeOperatorDeployment(cloudProvider string, uid string) *NodeOperatorDeployment {
|
|
|
|
return &NodeOperatorDeployment{
|
2022-08-04 10:15:52 -04:00
|
|
|
CatalogSource: operatorsv1alpha1.CatalogSource{
|
|
|
|
TypeMeta: metav1.TypeMeta{APIVersion: "operators.coreos.com/v1alpha1", Kind: "CatalogSource"},
|
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: "constellation-node-operator-catalog",
|
|
|
|
Namespace: nodeOperatorCatalogNamespace,
|
|
|
|
},
|
|
|
|
Spec: operatorsv1alpha1.CatalogSourceSpec{
|
|
|
|
SourceType: "grpc",
|
2022-10-06 06:58:56 -04:00
|
|
|
Image: versions.NodeOperatorCatalogImage,
|
2022-08-04 10:15:52 -04:00
|
|
|
DisplayName: "Constellation Node Operator",
|
|
|
|
Publisher: "Edgeless Systems",
|
|
|
|
UpdateStrategy: &operatorsv1alpha1.UpdateStrategy{
|
|
|
|
RegistryPoll: &operatorsv1alpha1.RegistryPoll{
|
|
|
|
RawInterval: "1m0s",
|
|
|
|
Interval: &metav1.Duration{Duration: 1 * time.Minute},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
OperatorGroup: operatorsv1.OperatorGroup{
|
|
|
|
TypeMeta: metav1.TypeMeta{APIVersion: "operators.coreos.com/v1", Kind: "OperatorGroup"},
|
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: "constellation-og",
|
|
|
|
Namespace: nodeOperatorNamespace,
|
|
|
|
},
|
|
|
|
Spec: operatorsv1.OperatorGroupSpec{
|
|
|
|
UpgradeStrategy: operatorsv1.UpgradeStrategyDefault,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Subscription: operatorsv1alpha1.Subscription{
|
|
|
|
TypeMeta: metav1.TypeMeta{APIVersion: "operators.coreos.com/v1alpha1", Kind: "Subscription"},
|
|
|
|
ObjectMeta: metav1.ObjectMeta{
|
|
|
|
Name: "constellation-node-operator-sub",
|
|
|
|
Namespace: nodeOperatorNamespace,
|
|
|
|
},
|
|
|
|
Spec: &operatorsv1alpha1.SubscriptionSpec{
|
|
|
|
Channel: "alpha",
|
|
|
|
Package: "node-operator",
|
|
|
|
CatalogSource: "constellation-node-operator-catalog",
|
|
|
|
CatalogSourceNamespace: "olm",
|
|
|
|
InstallPlanApproval: operatorsv1alpha1.ApprovalAutomatic,
|
|
|
|
StartingCSV: "node-operator." + versions.NodeOperatorVersion,
|
|
|
|
Config: &operatorsv1alpha1.SubscriptionConfig{
|
|
|
|
Env: []corev1.EnvVar{
|
|
|
|
{Name: "CONSTEL_CSP", Value: cloudProvider},
|
|
|
|
{Name: "constellation-uid", Value: uid},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-11-09 09:57:54 -05:00
|
|
|
// Marshal to Kubernetes YAML.
|
2022-10-05 09:02:46 -04:00
|
|
|
func (c *NodeOperatorDeployment) Marshal() ([]byte, error) {
|
2022-08-29 08:30:20 -04:00
|
|
|
return kubernetes.MarshalK8SResources(c)
|
2022-08-04 10:15:52 -04:00
|
|
|
}
|