|
| 1 | +package multigateway |
| 2 | + |
| 3 | +import ( |
| 4 | + "fmt" |
| 5 | + |
| 6 | + appsv1 "k8s.io/api/apps/v1" |
| 7 | + corev1 "k8s.io/api/core/v1" |
| 8 | + metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" |
| 9 | + "k8s.io/apimachinery/pkg/runtime" |
| 10 | + ctrl "sigs.k8s.io/controller-runtime" |
| 11 | + |
| 12 | + multigresv1alpha1 "github.com/numtide/multigres-operator/api/v1alpha1" |
| 13 | + "github.com/numtide/multigres-operator/pkg/resource-handler/controller/metadata" |
| 14 | +) |
| 15 | + |
| 16 | +const ( |
| 17 | + // ComponentName is the component label value for MultiGateway resources |
| 18 | + ComponentName = "multigateway" |
| 19 | + |
| 20 | + // DefaultReplicas is the default number of MultiGateway replicas |
| 21 | + DefaultReplicas int32 = 2 |
| 22 | + |
| 23 | + // DefaultImage is the default etcd container image |
| 24 | + DefaultImage = "numtide/multigres-operator:latest" |
| 25 | +) |
| 26 | + |
| 27 | +// BuildDeployment creates a Deployment for the Etcd cluster. |
| 28 | +// Returns a deterministic Deployment based on the Etcd spec. |
| 29 | +func BuildDeployment( |
| 30 | + mg *multigresv1alpha1.MultiGateway, |
| 31 | + scheme *runtime.Scheme, |
| 32 | +) (*appsv1.Deployment, error) { |
| 33 | + replicas := DefaultReplicas |
| 34 | + // TODO: Debatable whether this defaulting makes sense. |
| 35 | + if mg.Spec.Replicas != nil { |
| 36 | + replicas = *mg.Spec.Replicas |
| 37 | + } |
| 38 | + |
| 39 | + image := DefaultImage |
| 40 | + if mg.Spec.Image != "" { |
| 41 | + image = mg.Spec.Image |
| 42 | + } |
| 43 | + |
| 44 | + labels := metadata.BuildStandardLabels(mg.Name, ComponentName, mg.Spec.CellName) |
| 45 | + podLabels := metadata.MergeLabels(labels, mg.Spec.PodLabels) |
| 46 | + |
| 47 | + deployment := &appsv1.Deployment{ |
| 48 | + ObjectMeta: metav1.ObjectMeta{ |
| 49 | + Name: mg.Name, |
| 50 | + Namespace: mg.Namespace, |
| 51 | + Labels: labels, |
| 52 | + }, |
| 53 | + Spec: appsv1.DeploymentSpec{ |
| 54 | + Replicas: &replicas, |
| 55 | + Selector: &metav1.LabelSelector{ |
| 56 | + MatchLabels: labels, |
| 57 | + }, |
| 58 | + Template: corev1.PodTemplateSpec{ |
| 59 | + ObjectMeta: metav1.ObjectMeta{ |
| 60 | + Labels: podLabels, |
| 61 | + Annotations: mg.Spec.PodAnnotations, |
| 62 | + }, |
| 63 | + Spec: corev1.PodSpec{ |
| 64 | + ServiceAccountName: mg.Spec.ServiceAccountName, |
| 65 | + ImagePullSecrets: mg.Spec.ImagePullSecrets, |
| 66 | + Containers: []corev1.Container{ |
| 67 | + { |
| 68 | + Name: "multigateway", |
| 69 | + Image: image, |
| 70 | + Resources: mg.Spec.Resources, |
| 71 | + Env: buildContainerEnv(), |
| 72 | + Ports: buildContainerPorts(mg), |
| 73 | + }, |
| 74 | + }, |
| 75 | + Affinity: mg.Spec.Affinity, |
| 76 | + Tolerations: mg.Spec.Tolerations, |
| 77 | + NodeSelector: mg.Spec.NodeSelector, |
| 78 | + TopologySpreadConstraints: mg.Spec.TopologySpreadConstraints, |
| 79 | + }, |
| 80 | + }, |
| 81 | + }, |
| 82 | + } |
| 83 | + |
| 84 | + if err := ctrl.SetControllerReference(mg, deployment, scheme); err != nil { |
| 85 | + return nil, fmt.Errorf("failed to set controller reference: %w", err) |
| 86 | + } |
| 87 | + |
| 88 | + return deployment, nil |
| 89 | +} |
0 commit comments