Skip to content

Commit

Permalink
Enable collabora billing
Browse files Browse the repository at this point in the history
  • Loading branch information
Gabriel Saratura committed Nov 29, 2024
1 parent 210c3ba commit 1ac1d24
Show file tree
Hide file tree
Showing 3 changed files with 48 additions and 13 deletions.
1 change: 1 addition & 0 deletions apis/vshn/v1/vshn_nextcloud.go
Original file line number Diff line number Diff line change
Expand Up @@ -179,6 +179,7 @@ func (v *VSHNNextcloud) SetInstanceNamespaceStatus() {
v.Status.InstanceNamespace = v.GetInstanceNamespace()
}

// CollaboraSpec defines the desired state of a Collabora.
type CollaboraSpec struct {
// Enabled enables the Collabora integration. It will autoconfigure the Collabora server URL in Your Nextcloud instance.
//+kubebuilder:default=false
Expand Down
53 changes: 40 additions & 13 deletions pkg/comp-functions/functions/common/billing.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,12 +14,18 @@ import (
controllerruntime "sigs.k8s.io/controller-runtime"
)

// ServiceAddOns describes an addOn for a services with necessary data for billing
type ServiceAddOns struct {
Name string
Instances int
}

var rawExpr = "vector({{.}})"

// CreateBillingRecord creates a new prometheus rule per each instance namespace
// The rule is skipped for any secondary service such as postgresql instance for nextcloud
// The skipping is based on whether label appuio.io/billing-name is set or not on instance namespace
func CreateBillingRecord(ctx context.Context, svc *runtime.ServiceRuntime, comp InfoGetter) *xfnproto.Result {
func CreateBillingRecord(ctx context.Context, svc *runtime.ServiceRuntime, comp InfoGetter, addOns ...ServiceAddOns) *xfnproto.Result {
log := controllerruntime.LoggerFrom(ctx)
log.Info("Enabling billing for service", "service", comp.GetName())

Expand Down Expand Up @@ -55,20 +61,34 @@ func CreateBillingRecord(ctx context.Context, svc *runtime.ServiceRuntime, comp
log.Info("secondary service, skipping billing", "service", comp.GetName())
return runtime.NewNormalResult(fmt.Sprintf("billing disabled for instance %s", comp.GetName()))
}
rg := v1.RuleGroup{
Name: "appcat-metering-rules",
Rules: []v1.Rule{
{
Record: "appcat:metering",
Expr: intstr.FromString(expr),
Labels: getLabels(svc, comp, org, ""),
},
},
}

for _, addOn := range addOns {
log.Info("Adding billing addOn for service", "service", comp.GetName(), "addOn", addOn.Name)
exprAddOn, err := getExprFromTemplate(addOn.Instances)
if err != nil {
return runtime.NewWarningResult(fmt.Sprintf("cannot add addOn %s billing to service %s", addOn.Name, comp.GetName()))
}
rg.Rules = append(rg.Rules, v1.Rule{
Record: "appcat:metering",
Expr: intstr.FromString(exprAddOn),
Labels: getLabels(svc, comp, org, addOn.Name),
})
}

p := &v1.PrometheusRule{
Spec: v1.PrometheusRuleSpec{
Groups: []v1.RuleGroup{
{
Name: "appcat-metering-rules",
Rules: []v1.Rule{
{
Record: "appcat:metering",
Expr: intstr.FromString(expr),
Labels: getLabels(org, comp, svc),
},
},
},
rg,
},
},
}
Expand All @@ -86,12 +106,12 @@ func CreateBillingRecord(ctx context.Context, svc *runtime.ServiceRuntime, comp
return runtime.NewNormalResult(fmt.Sprintf("billing enabled for instance %s", comp.GetName()))
}

func getLabels(org string, comp InfoGetter, svc *runtime.ServiceRuntime) map[string]string {
func getLabels(svc *runtime.ServiceRuntime, comp InfoGetter, org, addOnName string) map[string]string {
labels := map[string]string{
"label_appcat_vshn_io_claim_name": comp.GetClaimName(),
"label_appcat_vshn_io_claim_namespace": comp.GetClaimNamespace(),
"label_appcat_vshn_io_sla": comp.GetSLA(),
"label_appuio_io_billing_name": comp.GetBillingName(),
"label_appuio_io_billing_name": getFinalBillingName(comp.GetBillingName(), addOnName),
"label_appuio_io_organization": org,
}

Expand All @@ -103,6 +123,13 @@ func getLabels(org string, comp InfoGetter, svc *runtime.ServiceRuntime) map[str
return labels
}

func getFinalBillingName(billingName, addOn string) string {
if addOn == "" {
return billingName
}
return fmt.Sprintf("%s-%s", billingName, addOn)
}

func getExprFromTemplate(i int) (string, error) {
var buf bytes.Buffer
tmpl, err := template.New("billing").Parse(rawExpr)
Expand Down
7 changes: 7 additions & 0 deletions pkg/comp-functions/functions/vshnnextcloud/billing.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,5 +18,12 @@ func AddBilling(ctx context.Context, comp *v1.VSHNNextcloud, svc *runtime.Servic
return runtime.NewFatalResult(fmt.Errorf("can't get composite: %w", err))
}

if comp.Spec.Parameters.Service.Collabora.Enabled {
return common.CreateBillingRecord(ctx, svc, comp, common.ServiceAddOns{
Name: "office",
Instances: 1,
})
}

return common.CreateBillingRecord(ctx, svc, comp)
}

0 comments on commit 1ac1d24

Please sign in to comment.