Some checks failed
Build and Publish / build-release (push) Failing after 26s
52 lines
1.7 KiB
Go
52 lines
1.7 KiB
Go
package builder
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
zitadelv1alpha1 "gitea.corredorconect.com/software-engineering/zitadel-k8s-operator/api/v1alpha1"
|
|
metadata "gitea.corredorconect.com/software-engineering/zitadel-k8s-operator/pkg/builder/metadata"
|
|
zitadelresourcesv1alpha1 "gitea.corredorconect.com/software-engineering/zitadel-resources-operator/api/v1alpha1"
|
|
corev1 "k8s.io/api/core/v1"
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
|
"k8s.io/apimachinery/pkg/types"
|
|
"sigs.k8s.io/controller-runtime/pkg/controller/controllerutil"
|
|
)
|
|
|
|
type MachineUserOpts struct {
|
|
Instance *zitadelv1alpha1.Instance
|
|
Authorizations []zitadelresourcesv1alpha1.Authorization
|
|
InternalPermissions []zitadelresourcesv1alpha1.InternalPermissions
|
|
Username string
|
|
}
|
|
|
|
func (b *Builder) BuildMachineUser(
|
|
key types.NamespacedName,
|
|
opts MachineUserOpts, owner metav1.Object) (*zitadelresourcesv1alpha1.MachineUser, error) {
|
|
objMeta :=
|
|
metadata.NewMetadataBuilder(key).
|
|
Build()
|
|
|
|
mu := &zitadelresourcesv1alpha1.MachineUser{
|
|
ObjectMeta: objMeta,
|
|
Spec: zitadelresourcesv1alpha1.MachineUserSpec{
|
|
OrganizationRef: zitadelresourcesv1alpha1.OrganizationRef{
|
|
ObjectReference: corev1.ObjectReference{
|
|
Kind: "Organization",
|
|
Namespace: opts.Instance.Namespace,
|
|
Name: opts.Instance.FirstOrgObjectName(),
|
|
},
|
|
},
|
|
AccessTokenType: "ACCESS_TOKEN_TYPE_BEARER",
|
|
Authorizations: opts.Authorizations,
|
|
InternalPermissions: opts.InternalPermissions,
|
|
Metadata: []map[string]string{},
|
|
Username: opts.Username,
|
|
},
|
|
}
|
|
|
|
if err := controllerutil.SetControllerReference(owner, mu, b.scheme); err != nil {
|
|
return nil, fmt.Errorf("error setting controller reference in Machine User manifest: %v", err)
|
|
}
|
|
return mu, nil
|
|
}
|