You've already forked kubernetes-operator
mirror of
https://github.com/netbirdio/kubernetes-operator.git
synced 2026-05-22 17:11:40 -07:00
69afe3aade
This change adds SPDX license headers to all files and eforces it with the linter. Signed-off-by: Philip Laine <philip.laine@gmail.com>
115 lines
3.2 KiB
Go
115 lines
3.2 KiB
Go
// SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
package controller
|
|
|
|
import (
|
|
"context"
|
|
"time"
|
|
|
|
"github.com/fluxcd/pkg/runtime/conditions"
|
|
"github.com/fluxcd/pkg/runtime/patch"
|
|
ctrl "sigs.k8s.io/controller-runtime"
|
|
"sigs.k8s.io/controller-runtime/pkg/client"
|
|
"sigs.k8s.io/controller-runtime/pkg/controller/controllerutil"
|
|
|
|
netbird "github.com/netbirdio/netbird/shared/management/client/rest"
|
|
"github.com/netbirdio/netbird/shared/management/http/api"
|
|
|
|
nbv1alpha1 "github.com/netbirdio/kubernetes-operator/api/v1alpha1"
|
|
"github.com/netbirdio/kubernetes-operator/internal/k8sutil"
|
|
)
|
|
|
|
type GroupReconciler struct {
|
|
client.Client
|
|
|
|
Netbird *netbird.Client
|
|
}
|
|
|
|
// +kubebuilder:rbac:groups=netbird.io,resources=groups,verbs=get;list;watch;create;update;patch;delete
|
|
// +kubebuilder:rbac:groups=netbird.io,resources=groups/status,verbs=get;update;patch
|
|
// +kubebuilder:rbac:groups=netbird.io,resources=groups/finalizers,verbs=update
|
|
|
|
func (r *GroupReconciler) Reconcile(ctx context.Context, req ctrl.Request) (ctrl.Result, error) {
|
|
group := &nbv1alpha1.Group{}
|
|
err := r.Get(ctx, req.NamespacedName, group)
|
|
if err != nil {
|
|
return ctrl.Result{}, client.IgnoreNotFound(err)
|
|
}
|
|
sp := patch.NewSerialPatcher(group, r.Client)
|
|
|
|
if !group.DeletionTimestamp.IsZero() {
|
|
return r.reconcileDelete(ctx, sp, group)
|
|
}
|
|
|
|
controllerutil.AddFinalizer(group, k8sutil.Finalizer("group"))
|
|
err = sp.Patch(ctx, group)
|
|
if err != nil {
|
|
return ctrl.Result{}, err
|
|
}
|
|
|
|
groupID, err := func() (string, error) {
|
|
if group.Status.GroupID != "" {
|
|
groupResp, err := r.Netbird.Groups.Get(ctx, group.Status.GroupID)
|
|
if err == nil {
|
|
peers := []string{}
|
|
for _, peer := range groupResp.Peers {
|
|
peers = append(peers, peer.Id)
|
|
}
|
|
groupReq := api.GroupRequest{
|
|
Name: group.Spec.Name,
|
|
Peers: &peers,
|
|
Resources: &groupResp.Resources,
|
|
}
|
|
resp, err := r.Netbird.Groups.Update(ctx, group.Status.GroupID, groupReq)
|
|
if err != nil && !netbird.IsNotFound(err) {
|
|
return "", err
|
|
}
|
|
if err == nil {
|
|
return resp.Id, nil
|
|
}
|
|
}
|
|
}
|
|
groupReq := api.GroupRequest{
|
|
Name: group.Spec.Name,
|
|
}
|
|
resp, err := r.Netbird.Groups.Create(ctx, groupReq)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
return resp.Id, nil
|
|
}()
|
|
if err != nil {
|
|
return ctrl.Result{}, err
|
|
}
|
|
group.Status.GroupID = groupID
|
|
|
|
conditions.MarkTrue(group, nbv1alpha1.ReadyCondition, nbv1alpha1.ReconciledReason, "")
|
|
err = sp.Patch(ctx, group, patch.WithStatusObservedGeneration{})
|
|
if err != nil {
|
|
return ctrl.Result{}, err
|
|
}
|
|
return ctrl.Result{RequeueAfter: 15 * time.Minute}, nil
|
|
}
|
|
|
|
func (r *GroupReconciler) reconcileDelete(ctx context.Context, sp *patch.SerialPatcher, group *nbv1alpha1.Group) (ctrl.Result, error) {
|
|
if group.Status.GroupID != "" {
|
|
err := r.Netbird.Groups.Delete(ctx, group.Status.GroupID)
|
|
if err != nil && !netbird.IsNotFound(err) {
|
|
return ctrl.Result{}, err
|
|
}
|
|
}
|
|
|
|
controllerutil.RemoveFinalizer(group, k8sutil.Finalizer("group"))
|
|
err := sp.Patch(ctx, group)
|
|
if err != nil {
|
|
return ctrl.Result{}, err
|
|
}
|
|
return ctrl.Result{}, nil
|
|
}
|
|
|
|
func (r *GroupReconciler) SetupWithManager(mgr ctrl.Manager) error {
|
|
return ctrl.NewControllerManagedBy(mgr).
|
|
For(&nbv1alpha1.Group{}).
|
|
Complete(r)
|
|
}
|