Skip to content

Commit

Permalink
Add billing to services
Browse files Browse the repository at this point in the history
  • Loading branch information
Gabriel Saratura committed Oct 14, 2024
1 parent cbfb45d commit 2814d7b
Show file tree
Hide file tree
Showing 21 changed files with 307 additions and 6 deletions.
9 changes: 8 additions & 1 deletion apis/vshn/v1/dbaas_vshn_keycloak.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ package v1

import (
"fmt"

xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1"
corev1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
Expand Down Expand Up @@ -334,3 +333,11 @@ func (v *VSHNKeycloak) GetPDBLabels() map[string]string {
func (v *VSHNKeycloak) GetSecurity() *Security {
return &v.Spec.Parameters.Security
}

func (v *VSHNKeycloak) GetWorkloadPodTemplateLabelsManager() PodTemplateLabelsManager {
return &StatefulSetManager{}
}

func (v *VSHNKeycloak) GetWorkloadName() string {
return v.GetName() + "-keycloakx"
}
9 changes: 8 additions & 1 deletion apis/vshn/v1/dbaas_vshn_mariadb.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ package v1

import (
"fmt"

xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)
Expand Down Expand Up @@ -273,3 +272,11 @@ func (v *VSHNMariaDB) GetPDBLabels() map[string]string {
func (v *VSHNMariaDB) GetSecurity() *Security {
return &v.Spec.Parameters.Security
}

func (v *VSHNMariaDB) GetWorkloadPodTemplateLabelsManager() PodTemplateLabelsManager {
return &StatefulSetManager{}
}

func (v *VSHNMariaDB) GetWorkloadName() string {
return v.GetName()
}
9 changes: 8 additions & 1 deletion apis/vshn/v1/dbaas_vshn_postgresql.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ package v1

import (
"fmt"

xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1"
sgv1 "github.com/vshn/appcat/v4/apis/stackgres/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
Expand Down Expand Up @@ -397,3 +396,11 @@ func (v *VSHNPostgreSQL) GetPDBLabels() map[string]string {
func (v *VSHNPostgreSQL) GetSecurity() *Security {
return &v.Spec.Parameters.Security
}

func (v *VSHNPostgreSQL) GetWorkloadPodTemplateLabelsManager() PodTemplateLabelsManager {
return &StatefulSetManager{}
}

func (v *VSHNPostgreSQL) GetWorkloadName() string {
return v.GetName()
}
9 changes: 8 additions & 1 deletion apis/vshn/v1/dbaas_vshn_redis.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ package v1

import (
"fmt"

xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)
Expand Down Expand Up @@ -298,3 +297,11 @@ func (v *VSHNRedis) GetPDBLabels() map[string]string {
func (v *VSHNRedis) GetSecurity() *Security {
return &v.Spec.Parameters.Security
}

func (v *VSHNRedis) GetWorkloadPodTemplateLabelsManager() PodTemplateLabelsManager {
return &StatefulSetManager{}
}

func (v *VSHNRedis) GetWorkloadName() string {
return "redis-master"
}
57 changes: 57 additions & 0 deletions apis/vshn/v1/non_gen_types.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
package v1

import (
v1 "k8s.io/api/apps/v1"
"sigs.k8s.io/controller-runtime/pkg/client"
)

// +kubebuilder:skip
// +kubebuilder:skipclient
// +kubebuilder:skipdeepcopy
// +kubebuilder:object:generate=false
type PodTemplateLabelsManager interface {
SetPodTemplateLabels(map[string]string)
GetPodTemplateLabels() map[string]string
GetObject() client.Object
client.Object
}

// +kubebuilder:skip
// +kubebuilder:skipclient
// +kubebuilder:skipdeepcopy
// +kubebuilder:object:generate=false
type DeploymentManager struct {
v1.Deployment
}

// +kubebuilder:skip
// +kubebuilder:skipclient
// +kubebuilder:skipdeepcopy
// +kubebuilder:object:generate=false
type StatefulSetManager struct {
v1.StatefulSet
}

func (d *DeploymentManager) SetPodTemplateLabels(labels map[string]string) {
d.Spec.Template.SetLabels(labels)
}

func (s *StatefulSetManager) SetPodTemplateLabels(labels map[string]string) {
s.Spec.Template.SetLabels(labels)
}

func (d *DeploymentManager) GetPodTemplateLabels() map[string]string {
return d.Spec.Template.GetLabels()
}

func (s *StatefulSetManager) GetPodTemplateLabels() map[string]string {
return s.Spec.Template.GetLabels()
}

func (d *DeploymentManager) GetObject() client.Object {
return &d.Deployment
}

func (d *StatefulSetManager) GetObject() client.Object {
return &d.StatefulSet
}
12 changes: 11 additions & 1 deletion apis/vshn/v1/vshn_minio.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ package v1

import (
"fmt"

xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)
Expand Down Expand Up @@ -247,3 +246,14 @@ func (v *VSHNMinio) GetPDBLabels() map[string]string {
func (v *VSHNMinio) GetSecurity() *Security {
return &v.Spec.Parameters.Security
}

func (v *VSHNMinio) GetWorkloadPodTemplateLabelsManager() PodTemplateLabelsManager {
if v.GetInstances() == 1 {
return &DeploymentManager{}
}
return &StatefulSetManager{}
}

func (v *VSHNMinio) GetWorkloadName() string {
return v.GetName()
}
9 changes: 8 additions & 1 deletion apis/vshn/v1/vshn_nextcloud.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@ package v1

import (
"fmt"

xpv1 "github.com/crossplane/crossplane-runtime/apis/common/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)
Expand Down Expand Up @@ -304,3 +303,11 @@ func (v *VSHNNextcloud) GetPDBLabels() map[string]string {
func (v *VSHNNextcloud) GetSecurity() *Security {
return &v.Spec.Parameters.Security
}

func (v *VSHNNextcloud) GetWorkloadPodTemplateLabelsManager() PodTemplateLabelsManager {
return &DeploymentManager{}
}

func (v *VSHNNextcloud) GetWorkloadName() string {
return v.GetName()
}
53 changes: 53 additions & 0 deletions pkg/comp-functions/functions/common/billing.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
package common

import (
"context"
"fmt"
v12 "github.com/crossplane/crossplane-runtime/apis/common/v1"
xfnproto "github.com/crossplane/function-sdk-go/proto/v1beta1"
xkube "github.com/vshn/appcat/v4/apis/kubernetes/v1alpha2"
"github.com/vshn/appcat/v4/pkg/comp-functions/runtime"
"reflect"
controllerruntime "sigs.k8s.io/controller-runtime"
"strings"
)

const billingLabel = "appcat.io/billing"

// InjectBillingLabelToService adds billing label to a service (StatefulSet or Deployment).
// It uses a kube Object to achieve post provisioning labelling
func InjectBillingLabelToService(ctx context.Context, svc *runtime.ServiceRuntime, comp InfoGetter) *xfnproto.Result {
log := controllerruntime.LoggerFrom(ctx)
log.Info("Enabling billing for service", "service", comp.GetName())

s := comp.GetWorkloadPodTemplateLabelsManager()
s.SetName(comp.GetWorkloadName())
s.SetNamespace(comp.GetInstanceNamespace())
kubeName := comp.GetName() + "-" + getType(s)

_ = svc.GetObservedKubeObject(s, kubeName)
mp := v12.ManagementPolicies{v12.ManagementActionObserve}
labels := s.GetPodTemplateLabels()
_, exists := labels[billingLabel]
if !s.GetCreationTimestamp().Time.IsZero() {
if !exists {
labels[billingLabel] = "true"
s.SetPodTemplateLabels(labels)
mp = append(mp, v12.ManagementActionCreate, v12.ManagementActionUpdate)
}
}

err := svc.SetDesiredKubeObject(s.GetObject(), kubeName, func(obj *xkube.Object) {
obj.Spec.ManagementPolicies = mp
})

if err != nil && !exists {
runtime.NewWarningResult(fmt.Sprintf("cannot add billing to service object %s", s.GetName()))
}

return runtime.NewNormalResult("billing enabled")
}

func getType(myvar interface{}) (res string) {
return strings.ToLower(reflect.TypeOf(myvar).Elem().Field(0).Name)
}
2 changes: 2 additions & 0 deletions pkg/comp-functions/functions/common/interfaces.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,8 @@ type InfoGetter interface {
GetSecurity() *vshnv1.Security
InstanceNamespaceInfo
GetPDBLabels() map[string]string
GetWorkloadPodTemplateLabelsManager() vshnv1.PodTemplateLabelsManager
GetWorkloadName() string
}

// InstanceNamespaceInfo provides all the necessary information to create
Expand Down
20 changes: 20 additions & 0 deletions pkg/comp-functions/functions/vshnkeycloak/billing.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
package vshnkeycloak

import (
"context"
"fmt"
xfnproto "github.com/crossplane/function-sdk-go/proto/v1beta1"
v1 "github.com/vshn/appcat/v4/apis/vshn/v1"
"github.com/vshn/appcat/v4/pkg/comp-functions/functions/common"
"github.com/vshn/appcat/v4/pkg/comp-functions/runtime"
)

// AddServiceBillingLabel adds billingLabel to all the objects of a services that must be billed
func AddServiceBillingLabel(ctx context.Context, comp *v1.VSHNKeycloak, svc *runtime.ServiceRuntime) *xfnproto.Result {
err := svc.GetObservedComposite(comp)
if err != nil {
return runtime.NewFatalResult(fmt.Errorf("can't get composite: %w", err))
}

return common.InjectBillingLabelToService(ctx, svc, comp)
}
4 changes: 4 additions & 0 deletions pkg/comp-functions/functions/vshnkeycloak/register.go
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,10 @@ func init() {
Name: "pdb",
Execute: common.AddPDBSettings[*vshnv1.VSHNKeycloak],
},
{
Name: "billing",
Execute: AddServiceBillingLabel,
},
},
})
}
20 changes: 20 additions & 0 deletions pkg/comp-functions/functions/vshnmariadb/billing.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
package vshnmariadb

import (
"context"
"fmt"
xfnproto "github.com/crossplane/function-sdk-go/proto/v1beta1"
v1 "github.com/vshn/appcat/v4/apis/vshn/v1"
"github.com/vshn/appcat/v4/pkg/comp-functions/functions/common"
"github.com/vshn/appcat/v4/pkg/comp-functions/runtime"
)

// AddServiceBillingLabel adds billingLabel to all the objects of a services that must be billed
func AddServiceBillingLabel(ctx context.Context, comp *v1.VSHNMariaDB, svc *runtime.ServiceRuntime) *xfnproto.Result {
err := svc.GetObservedComposite(comp)
if err != nil {
return runtime.NewFatalResult(fmt.Errorf("can't get composite: %w", err))
}

return common.InjectBillingLabelToService(ctx, svc, comp)
}
4 changes: 4 additions & 0 deletions pkg/comp-functions/functions/vshnmariadb/register.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,10 @@ func init() {
Name: "non-sla-prometheus-rules",
Execute: nonsla.GenerateNonSLAPromRules[*vshnv1.VSHNMariaDB](nonsla.NewAlertSetBuilder("mariadb", "mariadb").AddAll().GetAlerts()),
},
{
Name: "billing",
Execute: AddServiceBillingLabel,
},
},
})
}
20 changes: 20 additions & 0 deletions pkg/comp-functions/functions/vshnminio/billing.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
package vshnminio

import (
"context"
"fmt"
xfnproto "github.com/crossplane/function-sdk-go/proto/v1beta1"
v1 "github.com/vshn/appcat/v4/apis/vshn/v1"
"github.com/vshn/appcat/v4/pkg/comp-functions/functions/common"
"github.com/vshn/appcat/v4/pkg/comp-functions/runtime"
)

// AddServiceBillingLabel adds billingLabel to all the objects of a services that must be billed
func AddServiceBillingLabel(ctx context.Context, comp *v1.VSHNMinio, svc *runtime.ServiceRuntime) *xfnproto.Result {
err := svc.GetObservedComposite(comp)
if err != nil {
return runtime.NewFatalResult(fmt.Errorf("can't get composite: %w", err))
}

return common.InjectBillingLabelToService(ctx, svc, comp)
}
4 changes: 4 additions & 0 deletions pkg/comp-functions/functions/vshnminio/register.go
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,10 @@ func init() {
Name: "pdb",
Execute: common.AddPDBSettings[*vshnv1.VSHNMinio],
},
{
Name: "billing",
Execute: AddServiceBillingLabel,
},
},
})
}
20 changes: 20 additions & 0 deletions pkg/comp-functions/functions/vshnnextcloud/billing.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
package vshnnextcloud

import (
"context"
"fmt"
xfnproto "github.com/crossplane/function-sdk-go/proto/v1beta1"
v1 "github.com/vshn/appcat/v4/apis/vshn/v1"
"github.com/vshn/appcat/v4/pkg/comp-functions/functions/common"
"github.com/vshn/appcat/v4/pkg/comp-functions/runtime"
)

// AddServiceBillingLabel adds billingLabel to all the objects of a services that must be billed
func AddServiceBillingLabel(ctx context.Context, comp *v1.VSHNNextcloud, svc *runtime.ServiceRuntime) *xfnproto.Result {
err := svc.GetObservedComposite(comp)
if err != nil {
return runtime.NewFatalResult(fmt.Errorf("can't get composite: %w", err))
}

return common.InjectBillingLabelToService(ctx, svc, comp)
}
4 changes: 4 additions & 0 deletions pkg/comp-functions/functions/vshnnextcloud/register.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,10 @@ func init() {
Name: "backup",
Execute: AddBackup,
},
{
Name: "billing",
Execute: AddServiceBillingLabel,
},
},
})
}
20 changes: 20 additions & 0 deletions pkg/comp-functions/functions/vshnpostgres/billing.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
package vshnpostgres

import (
"context"
"fmt"
xfnproto "github.com/crossplane/function-sdk-go/proto/v1beta1"
v1 "github.com/vshn/appcat/v4/apis/vshn/v1"
"github.com/vshn/appcat/v4/pkg/comp-functions/functions/common"
"github.com/vshn/appcat/v4/pkg/comp-functions/runtime"
)

// AddServiceBillingLabel adds billingLabel to all the objects of a services that must be billed
func AddServiceBillingLabel(ctx context.Context, comp *v1.VSHNPostgreSQL, svc *runtime.ServiceRuntime) *xfnproto.Result {
err := svc.GetObservedComposite(comp)
if err != nil {
return runtime.NewFatalResult(fmt.Errorf("can't get composite: %w", err))
}

return common.InjectBillingLabelToService(ctx, svc, comp)
}
Loading

0 comments on commit 2814d7b

Please sign in to comment.