From 882fba017db7860629d92cfa09753c99c6ede0b2 Mon Sep 17 00:00:00 2001 From: ajanikow <12255597+ajanikow@users.noreply.github.com> Date: Tue, 7 May 2024 09:48:30 +0000 Subject: [PATCH] [Feature] [Analytics] GAE Integration --- .golangci.yaml | 2 + CHANGELOG.md | 1 + Makefile | 17 +- .../crds/analytics-graphanalyticsengine.yaml | 22 ++ .../cluster-role-binding.yaml | 26 +++ .../analytics-operator/cluster-role.yaml | 22 ++ .../analytics-operator/role-binding.yaml | 25 +++ .../templates/analytics-operator/role.yaml | 36 ++++ chart/kube-arangodb/templates/deployment.yaml | 3 + chart/kube-arangodb/values.yaml | 1 + cmd/cmd.go | 19 +- docs/api/GraphAnalyticsEngine.V1Alpha1.md | 56 +++++ internal/cr_validation_test.go | 8 + internal/docs_test.go | 14 ++ pkg/apis/analytics/definitions.go | 29 +++ pkg/apis/analytics/v1alpha1/conditions.go | 30 +++ pkg/apis/analytics/v1alpha1/doc.go | 23 ++ pkg/apis/analytics/v1alpha1/gae.go | 69 ++++++ pkg/apis/analytics/v1alpha1/gae_spec.go | 47 +++++ pkg/apis/analytics/v1alpha1/gae_status.go | 35 +++ pkg/apis/analytics/v1alpha1/register.go | 54 +++++ .../v1alpha1/zz_generated.deepcopy.go | 142 +++++++++++++ pkg/crd/analytics.go | 39 ++++ .../crds/analytics-graphanalyticsengine.go | 61 ++++++ ...graphanalyticsengine.schema.generated.yaml | 11 + .../crds/analytics-graphanalyticsengine.yaml | 22 ++ pkg/crd/crds/crds.go | 3 + pkg/crd/crds/crds_test.go | 1 + pkg/debug_package/generator.go | 1 + .../generators/kubernetes/analytics.go | 47 +++++ .../generators/kubernetes/analytics_gae.go | 73 +++++++ .../clientset/versioned/clientset.go | 13 ++ .../versioned/fake/clientset_generated.go | 7 + .../clientset/versioned/fake/register.go | 2 + .../clientset/versioned/scheme/register.go | 2 + .../analytics/v1alpha1/analytics_client.go | 111 ++++++++++ .../versioned/typed/analytics/v1alpha1/doc.go | 24 +++ .../typed/analytics/v1alpha1/fake/doc.go | 24 +++ .../v1alpha1/fake/fake_analytics_client.go | 44 ++++ .../fake/fake_graphanalyticsengine.go | 145 +++++++++++++ .../analytics/v1alpha1/generated_expansion.go | 25 +++ .../v1alpha1/graphanalyticsengine.go | 199 ++++++++++++++++++ .../externalversions/analytics/interface.go | 50 +++++ .../v1alpha1/graphanalyticsengine.go | 94 +++++++++ .../analytics/v1alpha1/interface.go | 49 +++++ .../informers/externalversions/factory.go | 6 + .../informers/externalversions/generic.go | 17 +- .../analytics/v1alpha1/expansion_generated.go | 31 +++ .../v1alpha1/graphanalyticsengine.go | 103 +++++++++ pkg/operator/operator.community.go | 11 +- pkg/operator/operator.go | 22 +- pkg/operatorV2/update_wraps.go | 5 + pkg/server/server.go | 5 + pkg/util/constants/constants.go | 1 + pkg/util/tests/kubernetes.go | 48 +++++ pkg/util/tests/kubernetes_test.go | 2 + 56 files changed, 1959 insertions(+), 20 deletions(-) create mode 100644 chart/kube-arangodb/crds/analytics-graphanalyticsengine.yaml create mode 100644 chart/kube-arangodb/templates/analytics-operator/cluster-role-binding.yaml create mode 100644 chart/kube-arangodb/templates/analytics-operator/cluster-role.yaml create mode 100644 chart/kube-arangodb/templates/analytics-operator/role-binding.yaml create mode 100644 chart/kube-arangodb/templates/analytics-operator/role.yaml create mode 100644 docs/api/GraphAnalyticsEngine.V1Alpha1.md create mode 100644 pkg/apis/analytics/definitions.go create mode 100644 pkg/apis/analytics/v1alpha1/conditions.go create mode 100644 pkg/apis/analytics/v1alpha1/doc.go create mode 100644 pkg/apis/analytics/v1alpha1/gae.go create mode 100644 pkg/apis/analytics/v1alpha1/gae_spec.go create mode 100644 pkg/apis/analytics/v1alpha1/gae_status.go create mode 100644 pkg/apis/analytics/v1alpha1/register.go create mode 100644 pkg/apis/analytics/v1alpha1/zz_generated.deepcopy.go create mode 100644 pkg/crd/analytics.go create mode 100644 pkg/crd/crds/analytics-graphanalyticsengine.go create mode 100644 pkg/crd/crds/analytics-graphanalyticsengine.schema.generated.yaml create mode 100644 pkg/crd/crds/analytics-graphanalyticsengine.yaml create mode 100644 pkg/debug_package/generators/kubernetes/analytics.go create mode 100644 pkg/debug_package/generators/kubernetes/analytics_gae.go create mode 100644 pkg/generated/clientset/versioned/typed/analytics/v1alpha1/analytics_client.go create mode 100644 pkg/generated/clientset/versioned/typed/analytics/v1alpha1/doc.go create mode 100644 pkg/generated/clientset/versioned/typed/analytics/v1alpha1/fake/doc.go create mode 100644 pkg/generated/clientset/versioned/typed/analytics/v1alpha1/fake/fake_analytics_client.go create mode 100644 pkg/generated/clientset/versioned/typed/analytics/v1alpha1/fake/fake_graphanalyticsengine.go create mode 100644 pkg/generated/clientset/versioned/typed/analytics/v1alpha1/generated_expansion.go create mode 100644 pkg/generated/clientset/versioned/typed/analytics/v1alpha1/graphanalyticsengine.go create mode 100644 pkg/generated/informers/externalversions/analytics/interface.go create mode 100644 pkg/generated/informers/externalversions/analytics/v1alpha1/graphanalyticsengine.go create mode 100644 pkg/generated/informers/externalversions/analytics/v1alpha1/interface.go create mode 100644 pkg/generated/listers/analytics/v1alpha1/expansion_generated.go create mode 100644 pkg/generated/listers/analytics/v1alpha1/graphanalyticsengine.go diff --git a/.golangci.yaml b/.golangci.yaml index fcae6231e..65679941c 100644 --- a/.golangci.yaml +++ b/.golangci.yaml @@ -71,6 +71,8 @@ linters-settings: alias: mlShared - pkg: github.com/arangodb/kube-arangodb/pkg/handlers/enterprise/ml/shared/test alias: mlSharedTests + - pkg: github.com/arangodb/kube-arangodb/pkg/apis/analytics/v1alpha1 + alias: analyticsApi - pkg: github.com/arangodb/kube-arangodb/pkg/apis/ml/v1beta1 alias: mlApi - pkg: github.com/arangodb/kube-arangodb/pkg/apis/ml/v1alpha1 diff --git a/CHANGELOG.md b/CHANGELOG.md index 0af49ff15..8dbb4e5dc 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -12,6 +12,7 @@ - (Feature) (ML) Enable TLS - (Feature) (ML) Release V1Beta1 API - (Maintenance) Update Go to 1.22.3 +- (Feature) (Analytics) GAE Integration ## [1.2.40](https://github.com/arangodb/kube-arangodb/tree/1.2.40) (2024-04-10) - (Feature) Add Core fields to the Scheduler Container Spec diff --git a/Makefile b/Makefile index 2102ae6c2..8cf6b7355 100644 --- a/Makefile +++ b/Makefile @@ -431,15 +431,23 @@ update-generated: "client lister informer deepcopy" \ "github.com/arangodb/kube-arangodb/pkg/generated" \ "github.com/arangodb/kube-arangodb/pkg/apis" \ - "deployment:v1 replication:v1 storage:v1alpha backup:v1 deployment:v2alpha1 replication:v2alpha1 apps:v1 ml:v1alpha1 ml:v1beta1 scheduler:v1alpha1 scheduler:v1beta1" \ + "deployment:v1 deployment:v2alpha1 \ + replication:v1 replication:v2alpha1 \ + storage:v1alpha \ + backup:v1 \ + apps:v1 \ + ml:v1alpha1 ml:v1beta1 \ + scheduler:v1alpha1 scheduler:v1beta1 \ + analytics:v1alpha1" \ --go-header-file "./tools/codegen/boilerplate.go.txt" \ $(VERIFYARGS) GOPATH=$(GOBUILDDIR) $(VENDORDIR)/k8s.io/code-generator/generate-groups.sh \ "deepcopy" \ "github.com/arangodb/kube-arangodb/pkg/generated" \ "github.com/arangodb/kube-arangodb/pkg/apis" \ - "shared:v1 scheduler:v1alpha1/container scheduler:v1alpha1/container/resources scheduler:v1alpha1/pod scheduler:v1alpha1/pod/resources\ - shared:v1 scheduler:v1beta1/container scheduler:v1beta1/container/resources scheduler:v1beta1/pod scheduler:v1beta1/pod/resources" \ + "shared:v1 \ + scheduler:v1alpha1/container scheduler:v1alpha1/container/resources scheduler:v1alpha1/pod scheduler:v1alpha1/pod/resources \ + scheduler:v1beta1/container scheduler:v1beta1/container/resources scheduler:v1beta1/pod scheduler:v1beta1/pod/resources" \ --go-header-file "./tools/codegen/boilerplate.go.txt" \ $(VERIFYARGS) @@ -858,7 +866,8 @@ CRDS:=apps-job \ database-clustersynchronization database-deployment database-member database-task \ replication-deploymentreplication \ ml-storage ml-extension ml-job-batch ml-job-cron \ - scheduler-profile + scheduler-profile \ + analytics-graphanalyticsengine .PHONY: sync-crds sync-crds: diff --git a/chart/kube-arangodb/crds/analytics-graphanalyticsengine.yaml b/chart/kube-arangodb/crds/analytics-graphanalyticsengine.yaml new file mode 100644 index 000000000..cac5e6f51 --- /dev/null +++ b/chart/kube-arangodb/crds/analytics-graphanalyticsengine.yaml @@ -0,0 +1,22 @@ +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: graphanalyticsengines.analytics.arangodb.com +spec: + group: analytics.arangodb.com + names: + kind: GraphAnalyticsEngine + listKind: GraphAnalyticsEngineList + plural: graphanalyticsengines + singular: graphanalyticsengine + scope: Namespaced + versions: + - name: v1alpha1 + schema: + openAPIV3Schema: + type: object + x-kubernetes-preserve-unknown-fields: true + served: true + storage: true + subresources: + status: {} diff --git a/chart/kube-arangodb/templates/analytics-operator/cluster-role-binding.yaml b/chart/kube-arangodb/templates/analytics-operator/cluster-role-binding.yaml new file mode 100644 index 000000000..201c4915b --- /dev/null +++ b/chart/kube-arangodb/templates/analytics-operator/cluster-role-binding.yaml @@ -0,0 +1,26 @@ +{{ if .Values.rbac.enabled -}} +{{ if not (eq .Values.operator.scope "namespaced") -}} +{{ if .Values.operator.features.analytics -}} + +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: {{ template "kube-arangodb.rbac-cluster" . }}-analytics + labels: + app.kubernetes.io/name: {{ template "kube-arangodb.name" . }} + helm.sh/chart: {{ .Chart.Name }}-{{ .Chart.Version }} + app.kubernetes.io/managed-by: {{ .Release.Service }} + app.kubernetes.io/instance: {{ .Release.Name }} + release: {{ .Release.Name }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: {{ template "kube-arangodb.rbac-cluster" . }}-analytics +subjects: + - kind: ServiceAccount + name: {{ template "kube-arangodb.operatorName" . }} + namespace: {{ .Release.Namespace }} + +{{- end }} +{{- end }} +{{- end }} \ No newline at end of file diff --git a/chart/kube-arangodb/templates/analytics-operator/cluster-role.yaml b/chart/kube-arangodb/templates/analytics-operator/cluster-role.yaml new file mode 100644 index 000000000..76ac5ee99 --- /dev/null +++ b/chart/kube-arangodb/templates/analytics-operator/cluster-role.yaml @@ -0,0 +1,22 @@ +{{ if .Values.rbac.enabled -}} +{{ if not (eq .Values.operator.scope "namespaced") -}} +{{ if .Values.operator.features.analytics -}} + +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + name: {{ template "kube-arangodb.rbac-cluster" . }}-analytics + labels: + app.kubernetes.io/name: {{ template "kube-arangodb.name" . }} + helm.sh/chart: {{ .Chart.Name }}-{{ .Chart.Version }} + app.kubernetes.io/managed-by: {{ .Release.Service }} + app.kubernetes.io/instance: {{ .Release.Name }} + release: {{ .Release.Name }} +rules: + - apiGroups: ["apiextensions.k8s.io"] + resources: ["customresourcedefinitions"] + verbs: ["get", "list", "watch"] + +{{- end }} +{{- end }} +{{- end }} \ No newline at end of file diff --git a/chart/kube-arangodb/templates/analytics-operator/role-binding.yaml b/chart/kube-arangodb/templates/analytics-operator/role-binding.yaml new file mode 100644 index 000000000..9fd0877f4 --- /dev/null +++ b/chart/kube-arangodb/templates/analytics-operator/role-binding.yaml @@ -0,0 +1,25 @@ +{{ if .Values.rbac.enabled -}} +{{ if .Values.operator.features.analytics -}} + +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: {{ template "kube-arangodb.rbac" . }}-analytics + namespace: {{ .Release.Namespace }} + labels: + app.kubernetes.io/name: {{ template "kube-arangodb.name" . }} + helm.sh/chart: {{ .Chart.Name }}-{{ .Chart.Version }} + app.kubernetes.io/managed-by: {{ .Release.Service }} + app.kubernetes.io/instance: {{ .Release.Name }} + release: {{ .Release.Name }} +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: {{ template "kube-arangodb.rbac" . }}-analytics +subjects: + - kind: ServiceAccount + name: {{ template "kube-arangodb.operatorName" . }} + namespace: {{ .Release.Namespace }} + +{{- end }} +{{- end }} \ No newline at end of file diff --git a/chart/kube-arangodb/templates/analytics-operator/role.yaml b/chart/kube-arangodb/templates/analytics-operator/role.yaml new file mode 100644 index 000000000..2c7813f23 --- /dev/null +++ b/chart/kube-arangodb/templates/analytics-operator/role.yaml @@ -0,0 +1,36 @@ +{{ if .Values.rbac.enabled -}} +{{ if .Values.operator.features.analytics -}} + +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: {{ template "kube-arangodb.rbac" . }}-analytics + namespace: {{ .Release.Namespace }} + labels: + app.kubernetes.io/name: {{ template "kube-arangodb.name" . }} + helm.sh/chart: {{ .Chart.Name }}-{{ .Chart.Version }} + app.kubernetes.io/managed-by: {{ .Release.Service }} + app.kubernetes.io/instance: {{ .Release.Name }} + release: {{ .Release.Name }} +rules: + - apiGroups: + - "analytics.arangodb.com" + resources: + - "graphanalyticsengines" + - "graphanalyticsengines/status" + verbs: + - "*" + - apiGroups: + - "database.arangodb.com" + resources: + - "arangodeployments" + verbs: + - "get" + - "list" + - "watch" + - apiGroups: [ "" ] + resources: + - "secrets" + verbs: [ "*" ] +{{- end }} +{{- end }} \ No newline at end of file diff --git a/chart/kube-arangodb/templates/deployment.yaml b/chart/kube-arangodb/templates/deployment.yaml index 1350ce98e..51b35d9a7 100644 --- a/chart/kube-arangodb/templates/deployment.yaml +++ b/chart/kube-arangodb/templates/deployment.yaml @@ -114,6 +114,9 @@ spec: {{ if .Values.operator.features.ml }} - --operator.ml {{- end }} +{{ if .Values.operator.features.analytics }} + - --operator.analytics +{{- end }} {{ if .Values.operator.features.k8sToK8sClusterSync }} - --operator.k2k-cluster-sync {{- end }} diff --git a/chart/kube-arangodb/values.yaml b/chart/kube-arangodb/values.yaml index f8870e155..3dbac69eb 100644 --- a/chart/kube-arangodb/values.yaml +++ b/chart/kube-arangodb/values.yaml @@ -33,6 +33,7 @@ operator: apps: false k8sToK8sClusterSync: false ml: false + analytics: false tolerations: [] rbac: enabled: true diff --git a/cmd/cmd.go b/cmd/cmd.go index f2a2bffce..f2c146966 100644 --- a/cmd/cmd.go +++ b/cmd/cmd.go @@ -118,6 +118,7 @@ var ( enableBackup bool // Run backup operator enableApps bool // Run apps operator enableML bool // Run ml operator + enableAnalytics bool // Run analytics operator versionOnly bool // Run only version endpoint, explicitly disabled with other enableK2KClusterSync bool // Run k2kClusterSync operator @@ -181,6 +182,7 @@ var ( backupProbe probe.ReadyProbe appsProbe probe.ReadyProbe mlProbe probe.ReadyProbe + analyticsProbe probe.ReadyProbe k2KClusterSyncProbe probe.ReadyProbe ) @@ -206,6 +208,7 @@ func init() { f.BoolVar(&operatorOptions.enableBackup, "operator.backup", false, "Enable to run the ArangoBackup operator") f.BoolVar(&operatorOptions.enableApps, "operator.apps", false, "Enable to run the ArangoApps operator") f.BoolVar(&operatorOptions.enableML, "operator.ml", false, "Enable to run the ArangoML operator") + f.BoolVar(&operatorOptions.enableAnalytics, "operator.analytics", false, "Enable to run the Analytics operator") f.BoolVar(&operatorOptions.enableK2KClusterSync, "operator.k2k-cluster-sync", false, "Enable to run the ListSimple operator") f.MarkDeprecated("operator.k2k-cluster-sync", "Enabled within deployment operator") f.BoolVar(&operatorOptions.versionOnly, "operator.version", false, "Enable only version endpoint in Operator") @@ -333,19 +336,19 @@ func executeMain(cmd *cobra.Command, args []string) { // Check operating mode if !operatorOptions.enableDeployment && !operatorOptions.enableDeploymentReplication && !operatorOptions.enableStorage && - !operatorOptions.enableBackup && !operatorOptions.enableApps && !operatorOptions.enableK2KClusterSync && !operatorOptions.enableML { + !operatorOptions.enableBackup && !operatorOptions.enableApps && !operatorOptions.enableK2KClusterSync && !operatorOptions.enableML && !operatorOptions.enableAnalytics { if !operatorOptions.versionOnly { if version.GetVersionV1().IsEnterprise() { - logger.Fatal("Turn on --operator.deployment, --operator.deployment-replication, --operator.storage, --operator.backup, --operator.apps, --operator.k2k-cluster-sync, --operator.ml or any combination of these") + logger.Fatal("Turn on --operator.deployment, --operator.deployment-replication, --operator.storage, --operator.backup, --operator.apps, --operator.k2k-cluster-sync, --operator.ml, --operator.analytics or any combination of these") } else { logger.Fatal("Turn on --operator.deployment, --operator.deployment-replication, --operator.storage, --operator.backup, --operator.apps, --operator.k2k-cluster-sync or any combination of these") } } } else if operatorOptions.versionOnly { - logger.Fatal("Options --operator.deployment, --operator.deployment-replication, --operator.storage, --operator.backup, --operator.apps, --operator.k2k-cluster-sync, --operator.ml cannot be enabled together with --operator.version") + logger.Fatal("Options --operator.deployment, --operator.deployment-replication, --operator.storage, --operator.backup, --operator.apps, --operator.k2k-cluster-sync, --operator.ml, --operator.analytics cannot be enabled together with --operator.version") } else if !version.GetVersionV1().IsEnterprise() { - if operatorOptions.enableML { - logger.Fatal("Options --operator.ml can be enabled only on the Enterprise Operator") + if operatorOptions.enableML || operatorOptions.enableAnalytics { + logger.Fatal("Options --operator.ml, --operator.analytics can be enabled only on the Enterprise Operator") } } @@ -476,6 +479,10 @@ func executeMain(cmd *cobra.Command, args []string) { Enabled: cfg.EnableML, Probe: &mlProbe, }, + Analytics: server.OperatorDependency{ + Enabled: cfg.EnableAnalytics, + Probe: &analyticsProbe, + }, ClusterSync: server.OperatorDependency{ Enabled: cfg.EnableK2KClusterSync, Probe: &k2KClusterSyncProbe, @@ -559,6 +566,7 @@ func newOperatorConfigAndDeps(id, namespace, name string) (operator.Config, oper EnableBackup: operatorOptions.enableBackup, EnableApps: operatorOptions.enableApps, EnableML: operatorOptions.enableML, + EnableAnalytics: operatorOptions.enableAnalytics, EnableK2KClusterSync: operatorOptions.enableK2KClusterSync, AllowChaos: chaosOptions.allowed, ScalingIntegrationEnabled: operatorOptions.scalingIntegrationEnabled, @@ -578,6 +586,7 @@ func newOperatorConfigAndDeps(id, namespace, name string) (operator.Config, oper BackupProbe: &backupProbe, AppsProbe: &appsProbe, MlProbe: &mlProbe, + AnalyticsProbe: &analyticsProbe, K2KClusterSyncProbe: &k2KClusterSyncProbe, } diff --git a/docs/api/GraphAnalyticsEngine.V1Alpha1.md b/docs/api/GraphAnalyticsEngine.V1Alpha1.md new file mode 100644 index 000000000..dd79dfcb5 --- /dev/null +++ b/docs/api/GraphAnalyticsEngine.V1Alpha1.md @@ -0,0 +1,56 @@ +--- +layout: page +parent: CRD reference +title: GraphAnalyticsEngine V1Alpha1 +--- + +# API Reference for GraphAnalyticsEngine V1Alpha1 + +## Spec + +### .spec.deploymentName + +Type: `string` [\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.40/pkg/apis/analytics/v1alpha1/gae_spec.go#L30) + +DeploymentName define deployment name used in the object. Immutable + +## Status + +### .status.conditions + +Type: `api.Conditions` [\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.40/pkg/apis/analytics/v1alpha1/gae_status.go#L31) + +Conditions specific to the entire extension + +*** + +### .status.deployment.checksum + +Type: `string` [\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.40/pkg/apis/shared/v1/object.go#L61) + +UID keeps the information about object Checksum + +*** + +### .status.deployment.name + +Type: `string` [\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.40/pkg/apis/shared/v1/object.go#L52) + +Name of the object + +*** + +### .status.deployment.namespace + +Type: `string` [\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.40/pkg/apis/shared/v1/object.go#L55) + +Namespace of the object. Should default to the namespace of the parent object + +*** + +### .status.deployment.uid + +Type: `string` [\[ref\]](https://github.com/arangodb/kube-arangodb/blob/1.2.40/pkg/apis/shared/v1/object.go#L58) + +UID keeps the information about object UID + diff --git a/internal/cr_validation_test.go b/internal/cr_validation_test.go index 1b17b6203..719088a5d 100644 --- a/internal/cr_validation_test.go +++ b/internal/cr_validation_test.go @@ -33,6 +33,7 @@ import ( apiextensions "k8s.io/apiextensions-apiserver/pkg/apis/apiextensions/v1" "sigs.k8s.io/yaml" + analyticsApi "github.com/arangodb/kube-arangodb/pkg/apis/analytics/v1alpha1" appsv1 "github.com/arangodb/kube-arangodb/pkg/apis/apps/v1" backupv1 "github.com/arangodb/kube-arangodb/pkg/apis/backup/v1" deploymentv1 "github.com/arangodb/kube-arangodb/pkg/apis/deployment/v1" @@ -226,6 +227,13 @@ func Test_GenerateCRValidationSchemas(t *testing.T) { }, }, }, + "analytics-graphanalyticsengine": { + fmt.Sprintf("%s/pkg/apis/analytics/v1alpha1", root): { + "v1alpha1": { + analyticsApi.GraphAnalyticsEngine{}.Spec, + }, + }, + }, } for filePrefix, packagesToVersion := range input { diff --git a/internal/docs_test.go b/internal/docs_test.go index dc33a7cc5..bcb911be0 100644 --- a/internal/docs_test.go +++ b/internal/docs_test.go @@ -36,6 +36,7 @@ import ( "github.com/coreos/go-semver/semver" "github.com/stretchr/testify/require" + analyticsApi "github.com/arangodb/kube-arangodb/pkg/apis/analytics/v1alpha1" appsApi "github.com/arangodb/kube-arangodb/pkg/apis/apps/v1" backupApi "github.com/arangodb/kube-arangodb/pkg/apis/backup/v1" deploymentApi "github.com/arangodb/kube-arangodb/pkg/apis/deployment/v1" @@ -248,6 +249,19 @@ func Test_GenerateAPIDocs(t *testing.T) { }, }, }, + "analytics": map[string]inputPackage{ + "v1alpha1": { + Types: inputPackageTypes{ + "GraphAnalyticsEngine.V1Alpha1": { + "Spec": analyticsApi.GraphAnalyticsEngine{}.Spec, + "Status": analyticsApi.GraphAnalyticsEngine{}.Status, + }, + }, + Shared: []string{ + "shared/v1", + }, + }, + }, "replication": map[string]inputPackage{ "v1": { Types: inputPackageTypes{ diff --git a/pkg/apis/analytics/definitions.go b/pkg/apis/analytics/definitions.go new file mode 100644 index 000000000..e63cde2ee --- /dev/null +++ b/pkg/apis/analytics/definitions.go @@ -0,0 +1,29 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +package analytics + +const ( + GraphAnalyticsEngineCRDName = GraphAnalyticsEngineResourcePlural + "." + ArangoAnalyticsGroupName + GraphAnalyticsEngineResourceKind = "GraphAnalyticsEngine" + GraphAnalyticsEngineResourcePlural = "graphanalyticsengines" + + ArangoAnalyticsGroupName = "analytics.arangodb.com" +) diff --git a/pkg/apis/analytics/v1alpha1/conditions.go b/pkg/apis/analytics/v1alpha1/conditions.go new file mode 100644 index 000000000..1e7909ab3 --- /dev/null +++ b/pkg/apis/analytics/v1alpha1/conditions.go @@ -0,0 +1,30 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +package v1alpha1 + +import api "github.com/arangodb/kube-arangodb/pkg/apis/deployment/v1" + +const ( + LicenseValidCondition api.ConditionType = "LicenseValid" + DeploymentFoundCondition api.ConditionType = "DeploymentFound" + ReadyCondition api.ConditionType = "Ready" + SpecValidCondition api.ConditionType = "SpecValid" +) diff --git a/pkg/apis/analytics/v1alpha1/doc.go b/pkg/apis/analytics/v1alpha1/doc.go new file mode 100644 index 000000000..4a2eb716f --- /dev/null +++ b/pkg/apis/analytics/v1alpha1/doc.go @@ -0,0 +1,23 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +// +k8s:deepcopy-gen=package +// +groupName=analytics.arangodb.com +package v1alpha1 diff --git a/pkg/apis/analytics/v1alpha1/gae.go b/pkg/apis/analytics/v1alpha1/gae.go new file mode 100644 index 000000000..3d0a4b739 --- /dev/null +++ b/pkg/apis/analytics/v1alpha1/gae.go @@ -0,0 +1,69 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +package v1alpha1 + +import ( + meta "k8s.io/apimachinery/pkg/apis/meta/v1" + + "github.com/arangodb/kube-arangodb/pkg/apis/analytics" +) + +// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object + +// GraphAnalyticsEngineList is a list of Arango Analytics GraphAnalyticsEngine. +type GraphAnalyticsEngineList struct { + meta.TypeMeta `json:",inline"` + meta.ListMeta `json:"metadata,omitempty"` + + Items []GraphAnalyticsEngine `json:"items"` +} + +// +genclient +// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object + +// GraphAnalyticsEngine contains definition and status of the Arango Analytics GraphAnalyticsEngine. +type GraphAnalyticsEngine struct { + meta.TypeMeta `json:",inline"` + meta.ObjectMeta `json:"metadata,omitempty"` + + Spec GraphAnalyticsEngineSpec `json:"spec"` + Status GraphAnalyticsEngineStatus `json:"status"` +} + +// AsOwner creates an OwnerReference for the given Extension +func (g *GraphAnalyticsEngine) AsOwner() meta.OwnerReference { + trueVar := true + return meta.OwnerReference{ + APIVersion: SchemeGroupVersion.String(), + Kind: analytics.GraphAnalyticsEngineCRDName, + Name: g.Name, + UID: g.UID, + Controller: &trueVar, + } +} + +func (g *GraphAnalyticsEngine) GetStatus() GraphAnalyticsEngineStatus { + return g.Status +} + +func (g *GraphAnalyticsEngine) SetStatus(status GraphAnalyticsEngineStatus) { + g.Status = status +} diff --git a/pkg/apis/analytics/v1alpha1/gae_spec.go b/pkg/apis/analytics/v1alpha1/gae_spec.go new file mode 100644 index 000000000..d550ab5a6 --- /dev/null +++ b/pkg/apis/analytics/v1alpha1/gae_spec.go @@ -0,0 +1,47 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +package v1alpha1 + +import ( + shared "github.com/arangodb/kube-arangodb/pkg/apis/shared" + "github.com/arangodb/kube-arangodb/pkg/util/errors" +) + +type GraphAnalyticsEngineSpec struct { + // DeploymentName define deployment name used in the object. Immutable + DeploymentName *string `json:"deploymentName,omitempty"` +} + +func (g *GraphAnalyticsEngineSpec) Validate() error { + if g == nil { + g = &GraphAnalyticsEngineSpec{} + } + + return shared.WithErrors(shared.PrefixResourceErrors("spec", + shared.PrefixResourceErrors("deploymentName", shared.ValidateRequired(g.DeploymentName, func(s string) error { + if s == "" { + return errors.Errorf("DeploymentName should be not empty") + } + + return nil + })), + )) +} diff --git a/pkg/apis/analytics/v1alpha1/gae_status.go b/pkg/apis/analytics/v1alpha1/gae_status.go new file mode 100644 index 000000000..b4d7090c3 --- /dev/null +++ b/pkg/apis/analytics/v1alpha1/gae_status.go @@ -0,0 +1,35 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +package v1alpha1 + +import ( + api "github.com/arangodb/kube-arangodb/pkg/apis/deployment/v1" + sharedApi "github.com/arangodb/kube-arangodb/pkg/apis/shared/v1" +) + +type GraphAnalyticsEngineStatus struct { + // Conditions specific to the entire extension + // +doc/type: api.Conditions + Conditions api.ConditionList `json:"conditions,omitempty"` + + // Deployment keeps the ArangoDeployment reference + Deployment *sharedApi.Object `json:"deployment,omitempty"` +} diff --git a/pkg/apis/analytics/v1alpha1/register.go b/pkg/apis/analytics/v1alpha1/register.go new file mode 100644 index 000000000..d71036b13 --- /dev/null +++ b/pkg/apis/analytics/v1alpha1/register.go @@ -0,0 +1,54 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +package v1alpha1 + +import ( + meta "k8s.io/apimachinery/pkg/apis/meta/v1" + "k8s.io/apimachinery/pkg/runtime" + "k8s.io/apimachinery/pkg/runtime/schema" + + "github.com/arangodb/kube-arangodb/pkg/apis/analytics" +) + +const ( + ArangoAnalyticsVersion = "v1alpha1" +) + +var ( + SchemeBuilder = runtime.NewSchemeBuilder(addKnownTypes) + AddToScheme = SchemeBuilder.AddToScheme + + SchemeGroupVersion = schema.GroupVersion{Group: analytics.ArangoAnalyticsGroupName, Version: ArangoAnalyticsVersion} +) + +// Resource gets an ArangoCluster GroupResource for a specified resource +func Resource(resource string) schema.GroupResource { + return SchemeGroupVersion.WithResource(resource).GroupResource() +} + +// addKnownTypes adds the set of types defined in this package to the supplied scheme. +func addKnownTypes(s *runtime.Scheme) error { + s.AddKnownTypes(SchemeGroupVersion, + &GraphAnalyticsEngine{}, + &GraphAnalyticsEngineList{}) + meta.AddToGroupVersion(s, SchemeGroupVersion) + return nil +} diff --git a/pkg/apis/analytics/v1alpha1/zz_generated.deepcopy.go b/pkg/apis/analytics/v1alpha1/zz_generated.deepcopy.go new file mode 100644 index 000000000..4cb2181a9 --- /dev/null +++ b/pkg/apis/analytics/v1alpha1/zz_generated.deepcopy.go @@ -0,0 +1,142 @@ +//go:build !ignore_autogenerated +// +build !ignore_autogenerated + +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +// Code generated by deepcopy-gen. DO NOT EDIT. + +package v1alpha1 + +import ( + v1 "github.com/arangodb/kube-arangodb/pkg/apis/deployment/v1" + sharedv1 "github.com/arangodb/kube-arangodb/pkg/apis/shared/v1" + runtime "k8s.io/apimachinery/pkg/runtime" +) + +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *GraphAnalyticsEngine) DeepCopyInto(out *GraphAnalyticsEngine) { + *out = *in + out.TypeMeta = in.TypeMeta + in.ObjectMeta.DeepCopyInto(&out.ObjectMeta) + in.Spec.DeepCopyInto(&out.Spec) + in.Status.DeepCopyInto(&out.Status) + return +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new GraphAnalyticsEngine. +func (in *GraphAnalyticsEngine) DeepCopy() *GraphAnalyticsEngine { + if in == nil { + return nil + } + out := new(GraphAnalyticsEngine) + in.DeepCopyInto(out) + return out +} + +// DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. +func (in *GraphAnalyticsEngine) DeepCopyObject() runtime.Object { + if c := in.DeepCopy(); c != nil { + return c + } + return nil +} + +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *GraphAnalyticsEngineList) DeepCopyInto(out *GraphAnalyticsEngineList) { + *out = *in + out.TypeMeta = in.TypeMeta + in.ListMeta.DeepCopyInto(&out.ListMeta) + if in.Items != nil { + in, out := &in.Items, &out.Items + *out = make([]GraphAnalyticsEngine, len(*in)) + for i := range *in { + (*in)[i].DeepCopyInto(&(*out)[i]) + } + } + return +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new GraphAnalyticsEngineList. +func (in *GraphAnalyticsEngineList) DeepCopy() *GraphAnalyticsEngineList { + if in == nil { + return nil + } + out := new(GraphAnalyticsEngineList) + in.DeepCopyInto(out) + return out +} + +// DeepCopyObject is an autogenerated deepcopy function, copying the receiver, creating a new runtime.Object. +func (in *GraphAnalyticsEngineList) DeepCopyObject() runtime.Object { + if c := in.DeepCopy(); c != nil { + return c + } + return nil +} + +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *GraphAnalyticsEngineSpec) DeepCopyInto(out *GraphAnalyticsEngineSpec) { + *out = *in + if in.DeploymentName != nil { + in, out := &in.DeploymentName, &out.DeploymentName + *out = new(string) + **out = **in + } + return +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new GraphAnalyticsEngineSpec. +func (in *GraphAnalyticsEngineSpec) DeepCopy() *GraphAnalyticsEngineSpec { + if in == nil { + return nil + } + out := new(GraphAnalyticsEngineSpec) + in.DeepCopyInto(out) + return out +} + +// DeepCopyInto is an autogenerated deepcopy function, copying the receiver, writing into out. in must be non-nil. +func (in *GraphAnalyticsEngineStatus) DeepCopyInto(out *GraphAnalyticsEngineStatus) { + *out = *in + if in.Conditions != nil { + in, out := &in.Conditions, &out.Conditions + *out = make(v1.ConditionList, len(*in)) + for i := range *in { + (*in)[i].DeepCopyInto(&(*out)[i]) + } + } + if in.Deployment != nil { + in, out := &in.Deployment, &out.Deployment + *out = new(sharedv1.Object) + (*in).DeepCopyInto(*out) + } + return +} + +// DeepCopy is an autogenerated deepcopy function, copying the receiver, creating a new GraphAnalyticsEngineStatus. +func (in *GraphAnalyticsEngineStatus) DeepCopy() *GraphAnalyticsEngineStatus { + if in == nil { + return nil + } + out := new(GraphAnalyticsEngineStatus) + in.DeepCopyInto(out) + return out +} diff --git a/pkg/crd/analytics.go b/pkg/crd/analytics.go new file mode 100644 index 000000000..bfc2bca5f --- /dev/null +++ b/pkg/crd/analytics.go @@ -0,0 +1,39 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +package crd + +import ( + "github.com/arangodb/kube-arangodb/pkg/crd/crds" +) + +func init() { + defs := []func(...func(options *crds.CRDOptions)) crds.Definition{ + crds.AnalyticsGAEDefinitionWithOptions, + } + for _, getDef := range defs { + defFn := getDef // bring into scope + registerCRDWithPanic(func(opts *crds.CRDOptions) crds.Definition { + return defFn(opts.AsFunc()) + }, &crds.CRDOptions{ + WithSchema: true, + }) + } +} diff --git a/pkg/crd/crds/analytics-graphanalyticsengine.go b/pkg/crd/crds/analytics-graphanalyticsengine.go new file mode 100644 index 000000000..8ad590ede --- /dev/null +++ b/pkg/crd/crds/analytics-graphanalyticsengine.go @@ -0,0 +1,61 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +package crds + +import ( + _ "embed" + + apiextensions "k8s.io/apiextensions-apiserver/pkg/apis/apiextensions/v1" +) + +// Deprecated: use AnalyticsGAEWithOptions instead +func AnalyticsGAE() *apiextensions.CustomResourceDefinition { + return AnalyticsGAEWithOptions() +} + +func AnalyticsGAEWithOptions(opts ...func(*CRDOptions)) *apiextensions.CustomResourceDefinition { + return getCRD(AnalyticsGAEDefinitionData(), opts...) +} + +// Deprecated: use AnalyticsGAEDefinitionWithOptions instead +func AnalyticsGAEDefinition() Definition { + return AnalyticsGAEDefinitionWithOptions() +} + +func AnalyticsGAEDefinitionWithOptions(opts ...func(*CRDOptions)) Definition { + return Definition{ + DefinitionData: AnalyticsGAEDefinitionData(), + CRD: AnalyticsGAEWithOptions(opts...), + } +} + +func AnalyticsGAEDefinitionData() DefinitionData { + return DefinitionData{ + definition: analyticsGAEs, + schemaDefinition: analyticsGAEsSchemaRaw, + } +} + +//go:embed analytics-graphanalyticsengine.yaml +var analyticsGAEs []byte + +//go:embed analytics-graphanalyticsengine.schema.generated.yaml +var analyticsGAEsSchemaRaw []byte diff --git a/pkg/crd/crds/analytics-graphanalyticsengine.schema.generated.yaml b/pkg/crd/crds/analytics-graphanalyticsengine.schema.generated.yaml new file mode 100644 index 000000000..b2777f63d --- /dev/null +++ b/pkg/crd/crds/analytics-graphanalyticsengine.schema.generated.yaml @@ -0,0 +1,11 @@ +v1alpha1: + openAPIV3Schema: + properties: + spec: + properties: + deploymentName: + description: DeploymentName define deployment name used in the object. Immutable + type: string + type: object + type: object + x-kubernetes-preserve-unknown-fields: true diff --git a/pkg/crd/crds/analytics-graphanalyticsengine.yaml b/pkg/crd/crds/analytics-graphanalyticsengine.yaml new file mode 100644 index 000000000..cac5e6f51 --- /dev/null +++ b/pkg/crd/crds/analytics-graphanalyticsengine.yaml @@ -0,0 +1,22 @@ +apiVersion: apiextensions.k8s.io/v1 +kind: CustomResourceDefinition +metadata: + name: graphanalyticsengines.analytics.arangodb.com +spec: + group: analytics.arangodb.com + names: + kind: GraphAnalyticsEngine + listKind: GraphAnalyticsEngineList + plural: graphanalyticsengines + singular: graphanalyticsengine + scope: Namespaced + versions: + - name: v1alpha1 + schema: + openAPIV3Schema: + type: object + x-kubernetes-preserve-unknown-fields: true + served: true + storage: true + subresources: + status: {} diff --git a/pkg/crd/crds/crds.go b/pkg/crd/crds/crds.go index ea7519ced..573186e20 100644 --- a/pkg/crd/crds/crds.go +++ b/pkg/crd/crds/crds.go @@ -87,6 +87,9 @@ func AllDefinitions() []Definition { // Scheduler SchedulerProfileDefinitionWithOptions(), + + // Analytics + AnalyticsGAEDefinitionWithOptions(), } } diff --git a/pkg/crd/crds/crds_test.go b/pkg/crd/crds/crds_test.go index 2eba7131c..c1ed38baa 100644 --- a/pkg/crd/crds/crds_test.go +++ b/pkg/crd/crds/crds_test.go @@ -123,6 +123,7 @@ func Test_CRDGetters(t *testing.T) { ReplicationDeploymentReplicationWithOptions, StorageLocalStorageWithOptions, SchedulerProfileWithOptions, + AnalyticsGAEWithOptions, } require.Equal(t, len(AllDefinitions()), len(getters)) diff --git a/pkg/debug_package/generator.go b/pkg/debug_package/generator.go index bb0105be6..d8c24a0eb 100644 --- a/pkg/debug_package/generator.go +++ b/pkg/debug_package/generator.go @@ -43,6 +43,7 @@ var rootFactories = []shared.Factory{ kubernetes.Deployments(), kubernetes.AgencyDump(), kubernetes.ML(), + kubernetes.Analytics(), kubernetes.Backup(), kubernetes.Scheduler(), } diff --git a/pkg/debug_package/generators/kubernetes/analytics.go b/pkg/debug_package/generators/kubernetes/analytics.go new file mode 100644 index 000000000..2b0317721 --- /dev/null +++ b/pkg/debug_package/generators/kubernetes/analytics.go @@ -0,0 +1,47 @@ +// +// DISCLAIMER +// +// Copyright 2023-2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +package kubernetes + +import ( + "github.com/rs/zerolog" + + "github.com/arangodb/kube-arangodb/pkg/debug_package/shared" + "github.com/arangodb/kube-arangodb/pkg/util/errors" + "github.com/arangodb/kube-arangodb/pkg/util/kclient" +) + +func Analytics() shared.Factory { + return shared.NewFactory("analytics", true, analytics) +} + +func analytics(logger zerolog.Logger, files chan<- shared.File) error { + k, ok := kclient.GetDefaultFactory().Client() + if !ok { + return errors.Errorf("Client is not initialised") + } + + if err := analyticsGAEs(logger, files, k); err != nil { + logger.Err(err).Msgf("Error while collecting arango analytics engines") + return err + } + + return nil +} diff --git a/pkg/debug_package/generators/kubernetes/analytics_gae.go b/pkg/debug_package/generators/kubernetes/analytics_gae.go new file mode 100644 index 000000000..6937d332b --- /dev/null +++ b/pkg/debug_package/generators/kubernetes/analytics_gae.go @@ -0,0 +1,73 @@ +// +// DISCLAIMER +// +// Copyright 2023-2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +package kubernetes + +import ( + "context" + "fmt" + + "github.com/rs/zerolog" + + analyticsApi "github.com/arangodb/kube-arangodb/pkg/apis/analytics/v1alpha1" + "github.com/arangodb/kube-arangodb/pkg/debug_package/cli" + "github.com/arangodb/kube-arangodb/pkg/debug_package/shared" + "github.com/arangodb/kube-arangodb/pkg/util/errors" + "github.com/arangodb/kube-arangodb/pkg/util/k8sutil/kerrors" + "github.com/arangodb/kube-arangodb/pkg/util/kclient" +) + +func analyticsGAEs(logger zerolog.Logger, files chan<- shared.File, client kclient.Client) error { + extensions, err := listAnalyticsGAEs(client) + if err != nil { + if kerrors.IsForbiddenOrNotFound(err) { + return nil + } + + return err + } + + if err := errors.ExecuteWithErrorArrayP2(analyticsGAE, client, files, extensions...); err != nil { + logger.Err(err).Msgf("Error while collecting arango ml extensions") + return err + } + + return nil +} + +func analyticsGAE(client kclient.Client, files chan<- shared.File, ext *analyticsApi.GraphAnalyticsEngine) error { + files <- shared.NewYAMLFile(fmt.Sprintf("kubernetes/arango/analytics/gaes/%s.yaml", ext.GetName()), func() ([]interface{}, error) { + return []interface{}{ext}, nil + }) + + return nil +} + +func listAnalyticsGAEs(client kclient.Client) ([]*analyticsApi.GraphAnalyticsEngine, error) { + return ListObjects[*analyticsApi.GraphAnalyticsEngineList, *analyticsApi.GraphAnalyticsEngine](context.Background(), client.Arango().AnalyticsV1alpha1().GraphAnalyticsEngines(cli.GetInput().Namespace), func(result *analyticsApi.GraphAnalyticsEngineList) []*analyticsApi.GraphAnalyticsEngine { + q := make([]*analyticsApi.GraphAnalyticsEngine, len(result.Items)) + + for id, e := range result.Items { + q[id] = e.DeepCopy() + } + + return q + }) +} diff --git a/pkg/generated/clientset/versioned/clientset.go b/pkg/generated/clientset/versioned/clientset.go index 84b582636..d2f139f70 100644 --- a/pkg/generated/clientset/versioned/clientset.go +++ b/pkg/generated/clientset/versioned/clientset.go @@ -26,6 +26,7 @@ import ( "fmt" "net/http" + analyticsv1alpha1 "github.com/arangodb/kube-arangodb/pkg/generated/clientset/versioned/typed/analytics/v1alpha1" appsv1 "github.com/arangodb/kube-arangodb/pkg/generated/clientset/versioned/typed/apps/v1" backupv1 "github.com/arangodb/kube-arangodb/pkg/generated/clientset/versioned/typed/backup/v1" databasev1 "github.com/arangodb/kube-arangodb/pkg/generated/clientset/versioned/typed/deployment/v1" @@ -44,6 +45,7 @@ import ( type Interface interface { Discovery() discovery.DiscoveryInterface + AnalyticsV1alpha1() analyticsv1alpha1.AnalyticsV1alpha1Interface AppsV1() appsv1.AppsV1Interface BackupV1() backupv1.BackupV1Interface DatabaseV1() databasev1.DatabaseV1Interface @@ -60,6 +62,7 @@ type Interface interface { // Clientset contains the clients for groups. type Clientset struct { *discovery.DiscoveryClient + analyticsV1alpha1 *analyticsv1alpha1.AnalyticsV1alpha1Client appsV1 *appsv1.AppsV1Client backupV1 *backupv1.BackupV1Client databaseV1 *databasev1.DatabaseV1Client @@ -73,6 +76,11 @@ type Clientset struct { storageV1alpha *storagev1alpha.StorageV1alphaClient } +// AnalyticsV1alpha1 retrieves the AnalyticsV1alpha1Client +func (c *Clientset) AnalyticsV1alpha1() analyticsv1alpha1.AnalyticsV1alpha1Interface { + return c.analyticsV1alpha1 +} + // AppsV1 retrieves the AppsV1Client func (c *Clientset) AppsV1() appsv1.AppsV1Interface { return c.appsV1 @@ -172,6 +180,10 @@ func NewForConfigAndClient(c *rest.Config, httpClient *http.Client) (*Clientset, var cs Clientset var err error + cs.analyticsV1alpha1, err = analyticsv1alpha1.NewForConfigAndClient(&configShallowCopy, httpClient) + if err != nil { + return nil, err + } cs.appsV1, err = appsv1.NewForConfigAndClient(&configShallowCopy, httpClient) if err != nil { return nil, err @@ -237,6 +249,7 @@ func NewForConfigOrDie(c *rest.Config) *Clientset { // New creates a new Clientset for the given RESTClient. func New(c rest.Interface) *Clientset { var cs Clientset + cs.analyticsV1alpha1 = analyticsv1alpha1.New(c) cs.appsV1 = appsv1.New(c) cs.backupV1 = backupv1.New(c) cs.databaseV1 = databasev1.New(c) diff --git a/pkg/generated/clientset/versioned/fake/clientset_generated.go b/pkg/generated/clientset/versioned/fake/clientset_generated.go index 1ad16d4fa..499793aa7 100644 --- a/pkg/generated/clientset/versioned/fake/clientset_generated.go +++ b/pkg/generated/clientset/versioned/fake/clientset_generated.go @@ -24,6 +24,8 @@ package fake import ( clientset "github.com/arangodb/kube-arangodb/pkg/generated/clientset/versioned" + analyticsv1alpha1 "github.com/arangodb/kube-arangodb/pkg/generated/clientset/versioned/typed/analytics/v1alpha1" + fakeanalyticsv1alpha1 "github.com/arangodb/kube-arangodb/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/fake" appsv1 "github.com/arangodb/kube-arangodb/pkg/generated/clientset/versioned/typed/apps/v1" fakeappsv1 "github.com/arangodb/kube-arangodb/pkg/generated/clientset/versioned/typed/apps/v1/fake" backupv1 "github.com/arangodb/kube-arangodb/pkg/generated/clientset/versioned/typed/backup/v1" @@ -103,6 +105,11 @@ var ( _ testing.FakeClient = &Clientset{} ) +// AnalyticsV1alpha1 retrieves the AnalyticsV1alpha1Client +func (c *Clientset) AnalyticsV1alpha1() analyticsv1alpha1.AnalyticsV1alpha1Interface { + return &fakeanalyticsv1alpha1.FakeAnalyticsV1alpha1{Fake: &c.Fake} +} + // AppsV1 retrieves the AppsV1Client func (c *Clientset) AppsV1() appsv1.AppsV1Interface { return &fakeappsv1.FakeAppsV1{Fake: &c.Fake} diff --git a/pkg/generated/clientset/versioned/fake/register.go b/pkg/generated/clientset/versioned/fake/register.go index a95fee35e..2f65785ee 100644 --- a/pkg/generated/clientset/versioned/fake/register.go +++ b/pkg/generated/clientset/versioned/fake/register.go @@ -23,6 +23,7 @@ package fake import ( + analyticsv1alpha1 "github.com/arangodb/kube-arangodb/pkg/apis/analytics/v1alpha1" appsv1 "github.com/arangodb/kube-arangodb/pkg/apis/apps/v1" backupv1 "github.com/arangodb/kube-arangodb/pkg/apis/backup/v1" databasev1 "github.com/arangodb/kube-arangodb/pkg/apis/deployment/v1" @@ -45,6 +46,7 @@ var scheme = runtime.NewScheme() var codecs = serializer.NewCodecFactory(scheme) var localSchemeBuilder = runtime.SchemeBuilder{ + analyticsv1alpha1.AddToScheme, appsv1.AddToScheme, backupv1.AddToScheme, databasev1.AddToScheme, diff --git a/pkg/generated/clientset/versioned/scheme/register.go b/pkg/generated/clientset/versioned/scheme/register.go index 0f069075e..cdaeb9465 100644 --- a/pkg/generated/clientset/versioned/scheme/register.go +++ b/pkg/generated/clientset/versioned/scheme/register.go @@ -23,6 +23,7 @@ package scheme import ( + analyticsv1alpha1 "github.com/arangodb/kube-arangodb/pkg/apis/analytics/v1alpha1" appsv1 "github.com/arangodb/kube-arangodb/pkg/apis/apps/v1" backupv1 "github.com/arangodb/kube-arangodb/pkg/apis/backup/v1" databasev1 "github.com/arangodb/kube-arangodb/pkg/apis/deployment/v1" @@ -45,6 +46,7 @@ var Scheme = runtime.NewScheme() var Codecs = serializer.NewCodecFactory(Scheme) var ParameterCodec = runtime.NewParameterCodec(Scheme) var localSchemeBuilder = runtime.SchemeBuilder{ + analyticsv1alpha1.AddToScheme, appsv1.AddToScheme, backupv1.AddToScheme, databasev1.AddToScheme, diff --git a/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/analytics_client.go b/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/analytics_client.go new file mode 100644 index 000000000..e6143718f --- /dev/null +++ b/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/analytics_client.go @@ -0,0 +1,111 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +// Code generated by client-gen. DO NOT EDIT. + +package v1alpha1 + +import ( + "net/http" + + v1alpha1 "github.com/arangodb/kube-arangodb/pkg/apis/analytics/v1alpha1" + "github.com/arangodb/kube-arangodb/pkg/generated/clientset/versioned/scheme" + rest "k8s.io/client-go/rest" +) + +type AnalyticsV1alpha1Interface interface { + RESTClient() rest.Interface + GraphAnalyticsEnginesGetter +} + +// AnalyticsV1alpha1Client is used to interact with features provided by the analytics.arangodb.com group. +type AnalyticsV1alpha1Client struct { + restClient rest.Interface +} + +func (c *AnalyticsV1alpha1Client) GraphAnalyticsEngines(namespace string) GraphAnalyticsEngineInterface { + return newGraphAnalyticsEngines(c, namespace) +} + +// NewForConfig creates a new AnalyticsV1alpha1Client for the given config. +// NewForConfig is equivalent to NewForConfigAndClient(c, httpClient), +// where httpClient was generated with rest.HTTPClientFor(c). +func NewForConfig(c *rest.Config) (*AnalyticsV1alpha1Client, error) { + config := *c + if err := setConfigDefaults(&config); err != nil { + return nil, err + } + httpClient, err := rest.HTTPClientFor(&config) + if err != nil { + return nil, err + } + return NewForConfigAndClient(&config, httpClient) +} + +// NewForConfigAndClient creates a new AnalyticsV1alpha1Client for the given config and http client. +// Note the http client provided takes precedence over the configured transport values. +func NewForConfigAndClient(c *rest.Config, h *http.Client) (*AnalyticsV1alpha1Client, error) { + config := *c + if err := setConfigDefaults(&config); err != nil { + return nil, err + } + client, err := rest.RESTClientForConfigAndClient(&config, h) + if err != nil { + return nil, err + } + return &AnalyticsV1alpha1Client{client}, nil +} + +// NewForConfigOrDie creates a new AnalyticsV1alpha1Client for the given config and +// panics if there is an error in the config. +func NewForConfigOrDie(c *rest.Config) *AnalyticsV1alpha1Client { + client, err := NewForConfig(c) + if err != nil { + panic(err) + } + return client +} + +// New creates a new AnalyticsV1alpha1Client for the given RESTClient. +func New(c rest.Interface) *AnalyticsV1alpha1Client { + return &AnalyticsV1alpha1Client{c} +} + +func setConfigDefaults(config *rest.Config) error { + gv := v1alpha1.SchemeGroupVersion + config.GroupVersion = &gv + config.APIPath = "/apis" + config.NegotiatedSerializer = scheme.Codecs.WithoutConversion() + + if config.UserAgent == "" { + config.UserAgent = rest.DefaultKubernetesUserAgent() + } + + return nil +} + +// RESTClient returns a RESTClient that is used to communicate +// with API server by this client implementation. +func (c *AnalyticsV1alpha1Client) RESTClient() rest.Interface { + if c == nil { + return nil + } + return c.restClient +} diff --git a/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/doc.go b/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/doc.go new file mode 100644 index 000000000..f45dab6c5 --- /dev/null +++ b/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/doc.go @@ -0,0 +1,24 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +// Code generated by client-gen. DO NOT EDIT. + +// This package has the automatically generated typed clients. +package v1alpha1 diff --git a/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/fake/doc.go b/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/fake/doc.go new file mode 100644 index 000000000..cc487d814 --- /dev/null +++ b/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/fake/doc.go @@ -0,0 +1,24 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +// Code generated by client-gen. DO NOT EDIT. + +// Package fake has the automatically generated clients. +package fake diff --git a/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/fake/fake_analytics_client.go b/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/fake/fake_analytics_client.go new file mode 100644 index 000000000..44ddf3e43 --- /dev/null +++ b/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/fake/fake_analytics_client.go @@ -0,0 +1,44 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +// Code generated by client-gen. DO NOT EDIT. + +package fake + +import ( + v1alpha1 "github.com/arangodb/kube-arangodb/pkg/generated/clientset/versioned/typed/analytics/v1alpha1" + rest "k8s.io/client-go/rest" + testing "k8s.io/client-go/testing" +) + +type FakeAnalyticsV1alpha1 struct { + *testing.Fake +} + +func (c *FakeAnalyticsV1alpha1) GraphAnalyticsEngines(namespace string) v1alpha1.GraphAnalyticsEngineInterface { + return &FakeGraphAnalyticsEngines{c, namespace} +} + +// RESTClient returns a RESTClient that is used to communicate +// with API server by this client implementation. +func (c *FakeAnalyticsV1alpha1) RESTClient() rest.Interface { + var ret *rest.RESTClient + return ret +} diff --git a/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/fake/fake_graphanalyticsengine.go b/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/fake/fake_graphanalyticsengine.go new file mode 100644 index 000000000..b10ff47e3 --- /dev/null +++ b/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/fake/fake_graphanalyticsengine.go @@ -0,0 +1,145 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +// Code generated by client-gen. DO NOT EDIT. + +package fake + +import ( + "context" + + v1alpha1 "github.com/arangodb/kube-arangodb/pkg/apis/analytics/v1alpha1" + v1 "k8s.io/apimachinery/pkg/apis/meta/v1" + labels "k8s.io/apimachinery/pkg/labels" + types "k8s.io/apimachinery/pkg/types" + watch "k8s.io/apimachinery/pkg/watch" + testing "k8s.io/client-go/testing" +) + +// FakeGraphAnalyticsEngines implements GraphAnalyticsEngineInterface +type FakeGraphAnalyticsEngines struct { + Fake *FakeAnalyticsV1alpha1 + ns string +} + +var graphanalyticsenginesResource = v1alpha1.SchemeGroupVersion.WithResource("graphanalyticsengines") + +var graphanalyticsenginesKind = v1alpha1.SchemeGroupVersion.WithKind("GraphAnalyticsEngine") + +// Get takes name of the graphAnalyticsEngine, and returns the corresponding graphAnalyticsEngine object, and an error if there is any. +func (c *FakeGraphAnalyticsEngines) Get(ctx context.Context, name string, options v1.GetOptions) (result *v1alpha1.GraphAnalyticsEngine, err error) { + obj, err := c.Fake. + Invokes(testing.NewGetAction(graphanalyticsenginesResource, c.ns, name), &v1alpha1.GraphAnalyticsEngine{}) + + if obj == nil { + return nil, err + } + return obj.(*v1alpha1.GraphAnalyticsEngine), err +} + +// List takes label and field selectors, and returns the list of GraphAnalyticsEngines that match those selectors. +func (c *FakeGraphAnalyticsEngines) List(ctx context.Context, opts v1.ListOptions) (result *v1alpha1.GraphAnalyticsEngineList, err error) { + obj, err := c.Fake. + Invokes(testing.NewListAction(graphanalyticsenginesResource, graphanalyticsenginesKind, c.ns, opts), &v1alpha1.GraphAnalyticsEngineList{}) + + if obj == nil { + return nil, err + } + + label, _, _ := testing.ExtractFromListOptions(opts) + if label == nil { + label = labels.Everything() + } + list := &v1alpha1.GraphAnalyticsEngineList{ListMeta: obj.(*v1alpha1.GraphAnalyticsEngineList).ListMeta} + for _, item := range obj.(*v1alpha1.GraphAnalyticsEngineList).Items { + if label.Matches(labels.Set(item.Labels)) { + list.Items = append(list.Items, item) + } + } + return list, err +} + +// Watch returns a watch.Interface that watches the requested graphAnalyticsEngines. +func (c *FakeGraphAnalyticsEngines) Watch(ctx context.Context, opts v1.ListOptions) (watch.Interface, error) { + return c.Fake. + InvokesWatch(testing.NewWatchAction(graphanalyticsenginesResource, c.ns, opts)) + +} + +// Create takes the representation of a graphAnalyticsEngine and creates it. Returns the server's representation of the graphAnalyticsEngine, and an error, if there is any. +func (c *FakeGraphAnalyticsEngines) Create(ctx context.Context, graphAnalyticsEngine *v1alpha1.GraphAnalyticsEngine, opts v1.CreateOptions) (result *v1alpha1.GraphAnalyticsEngine, err error) { + obj, err := c.Fake. + Invokes(testing.NewCreateAction(graphanalyticsenginesResource, c.ns, graphAnalyticsEngine), &v1alpha1.GraphAnalyticsEngine{}) + + if obj == nil { + return nil, err + } + return obj.(*v1alpha1.GraphAnalyticsEngine), err +} + +// Update takes the representation of a graphAnalyticsEngine and updates it. Returns the server's representation of the graphAnalyticsEngine, and an error, if there is any. +func (c *FakeGraphAnalyticsEngines) Update(ctx context.Context, graphAnalyticsEngine *v1alpha1.GraphAnalyticsEngine, opts v1.UpdateOptions) (result *v1alpha1.GraphAnalyticsEngine, err error) { + obj, err := c.Fake. + Invokes(testing.NewUpdateAction(graphanalyticsenginesResource, c.ns, graphAnalyticsEngine), &v1alpha1.GraphAnalyticsEngine{}) + + if obj == nil { + return nil, err + } + return obj.(*v1alpha1.GraphAnalyticsEngine), err +} + +// UpdateStatus was generated because the type contains a Status member. +// Add a +genclient:noStatus comment above the type to avoid generating UpdateStatus(). +func (c *FakeGraphAnalyticsEngines) UpdateStatus(ctx context.Context, graphAnalyticsEngine *v1alpha1.GraphAnalyticsEngine, opts v1.UpdateOptions) (*v1alpha1.GraphAnalyticsEngine, error) { + obj, err := c.Fake. + Invokes(testing.NewUpdateSubresourceAction(graphanalyticsenginesResource, "status", c.ns, graphAnalyticsEngine), &v1alpha1.GraphAnalyticsEngine{}) + + if obj == nil { + return nil, err + } + return obj.(*v1alpha1.GraphAnalyticsEngine), err +} + +// Delete takes name of the graphAnalyticsEngine and deletes it. Returns an error if one occurs. +func (c *FakeGraphAnalyticsEngines) Delete(ctx context.Context, name string, opts v1.DeleteOptions) error { + _, err := c.Fake. + Invokes(testing.NewDeleteActionWithOptions(graphanalyticsenginesResource, c.ns, name, opts), &v1alpha1.GraphAnalyticsEngine{}) + + return err +} + +// DeleteCollection deletes a collection of objects. +func (c *FakeGraphAnalyticsEngines) DeleteCollection(ctx context.Context, opts v1.DeleteOptions, listOpts v1.ListOptions) error { + action := testing.NewDeleteCollectionAction(graphanalyticsenginesResource, c.ns, listOpts) + + _, err := c.Fake.Invokes(action, &v1alpha1.GraphAnalyticsEngineList{}) + return err +} + +// Patch applies the patch and returns the patched graphAnalyticsEngine. +func (c *FakeGraphAnalyticsEngines) Patch(ctx context.Context, name string, pt types.PatchType, data []byte, opts v1.PatchOptions, subresources ...string) (result *v1alpha1.GraphAnalyticsEngine, err error) { + obj, err := c.Fake. + Invokes(testing.NewPatchSubresourceAction(graphanalyticsenginesResource, c.ns, name, pt, data, subresources...), &v1alpha1.GraphAnalyticsEngine{}) + + if obj == nil { + return nil, err + } + return obj.(*v1alpha1.GraphAnalyticsEngine), err +} diff --git a/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/generated_expansion.go b/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/generated_expansion.go new file mode 100644 index 000000000..7cdfc22bf --- /dev/null +++ b/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/generated_expansion.go @@ -0,0 +1,25 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +// Code generated by client-gen. DO NOT EDIT. + +package v1alpha1 + +type GraphAnalyticsEngineExpansion interface{} diff --git a/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/graphanalyticsengine.go b/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/graphanalyticsengine.go new file mode 100644 index 000000000..2ca7273b5 --- /dev/null +++ b/pkg/generated/clientset/versioned/typed/analytics/v1alpha1/graphanalyticsengine.go @@ -0,0 +1,199 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +// Code generated by client-gen. DO NOT EDIT. + +package v1alpha1 + +import ( + "context" + "time" + + v1alpha1 "github.com/arangodb/kube-arangodb/pkg/apis/analytics/v1alpha1" + scheme "github.com/arangodb/kube-arangodb/pkg/generated/clientset/versioned/scheme" + v1 "k8s.io/apimachinery/pkg/apis/meta/v1" + types "k8s.io/apimachinery/pkg/types" + watch "k8s.io/apimachinery/pkg/watch" + rest "k8s.io/client-go/rest" +) + +// GraphAnalyticsEnginesGetter has a method to return a GraphAnalyticsEngineInterface. +// A group's client should implement this interface. +type GraphAnalyticsEnginesGetter interface { + GraphAnalyticsEngines(namespace string) GraphAnalyticsEngineInterface +} + +// GraphAnalyticsEngineInterface has methods to work with GraphAnalyticsEngine resources. +type GraphAnalyticsEngineInterface interface { + Create(ctx context.Context, graphAnalyticsEngine *v1alpha1.GraphAnalyticsEngine, opts v1.CreateOptions) (*v1alpha1.GraphAnalyticsEngine, error) + Update(ctx context.Context, graphAnalyticsEngine *v1alpha1.GraphAnalyticsEngine, opts v1.UpdateOptions) (*v1alpha1.GraphAnalyticsEngine, error) + UpdateStatus(ctx context.Context, graphAnalyticsEngine *v1alpha1.GraphAnalyticsEngine, opts v1.UpdateOptions) (*v1alpha1.GraphAnalyticsEngine, error) + Delete(ctx context.Context, name string, opts v1.DeleteOptions) error + DeleteCollection(ctx context.Context, opts v1.DeleteOptions, listOpts v1.ListOptions) error + Get(ctx context.Context, name string, opts v1.GetOptions) (*v1alpha1.GraphAnalyticsEngine, error) + List(ctx context.Context, opts v1.ListOptions) (*v1alpha1.GraphAnalyticsEngineList, error) + Watch(ctx context.Context, opts v1.ListOptions) (watch.Interface, error) + Patch(ctx context.Context, name string, pt types.PatchType, data []byte, opts v1.PatchOptions, subresources ...string) (result *v1alpha1.GraphAnalyticsEngine, err error) + GraphAnalyticsEngineExpansion +} + +// graphAnalyticsEngines implements GraphAnalyticsEngineInterface +type graphAnalyticsEngines struct { + client rest.Interface + ns string +} + +// newGraphAnalyticsEngines returns a GraphAnalyticsEngines +func newGraphAnalyticsEngines(c *AnalyticsV1alpha1Client, namespace string) *graphAnalyticsEngines { + return &graphAnalyticsEngines{ + client: c.RESTClient(), + ns: namespace, + } +} + +// Get takes name of the graphAnalyticsEngine, and returns the corresponding graphAnalyticsEngine object, and an error if there is any. +func (c *graphAnalyticsEngines) Get(ctx context.Context, name string, options v1.GetOptions) (result *v1alpha1.GraphAnalyticsEngine, err error) { + result = &v1alpha1.GraphAnalyticsEngine{} + err = c.client.Get(). + Namespace(c.ns). + Resource("graphanalyticsengines"). + Name(name). + VersionedParams(&options, scheme.ParameterCodec). + Do(ctx). + Into(result) + return +} + +// List takes label and field selectors, and returns the list of GraphAnalyticsEngines that match those selectors. +func (c *graphAnalyticsEngines) List(ctx context.Context, opts v1.ListOptions) (result *v1alpha1.GraphAnalyticsEngineList, err error) { + var timeout time.Duration + if opts.TimeoutSeconds != nil { + timeout = time.Duration(*opts.TimeoutSeconds) * time.Second + } + result = &v1alpha1.GraphAnalyticsEngineList{} + err = c.client.Get(). + Namespace(c.ns). + Resource("graphanalyticsengines"). + VersionedParams(&opts, scheme.ParameterCodec). + Timeout(timeout). + Do(ctx). + Into(result) + return +} + +// Watch returns a watch.Interface that watches the requested graphAnalyticsEngines. +func (c *graphAnalyticsEngines) Watch(ctx context.Context, opts v1.ListOptions) (watch.Interface, error) { + var timeout time.Duration + if opts.TimeoutSeconds != nil { + timeout = time.Duration(*opts.TimeoutSeconds) * time.Second + } + opts.Watch = true + return c.client.Get(). + Namespace(c.ns). + Resource("graphanalyticsengines"). + VersionedParams(&opts, scheme.ParameterCodec). + Timeout(timeout). + Watch(ctx) +} + +// Create takes the representation of a graphAnalyticsEngine and creates it. Returns the server's representation of the graphAnalyticsEngine, and an error, if there is any. +func (c *graphAnalyticsEngines) Create(ctx context.Context, graphAnalyticsEngine *v1alpha1.GraphAnalyticsEngine, opts v1.CreateOptions) (result *v1alpha1.GraphAnalyticsEngine, err error) { + result = &v1alpha1.GraphAnalyticsEngine{} + err = c.client.Post(). + Namespace(c.ns). + Resource("graphanalyticsengines"). + VersionedParams(&opts, scheme.ParameterCodec). + Body(graphAnalyticsEngine). + Do(ctx). + Into(result) + return +} + +// Update takes the representation of a graphAnalyticsEngine and updates it. Returns the server's representation of the graphAnalyticsEngine, and an error, if there is any. +func (c *graphAnalyticsEngines) Update(ctx context.Context, graphAnalyticsEngine *v1alpha1.GraphAnalyticsEngine, opts v1.UpdateOptions) (result *v1alpha1.GraphAnalyticsEngine, err error) { + result = &v1alpha1.GraphAnalyticsEngine{} + err = c.client.Put(). + Namespace(c.ns). + Resource("graphanalyticsengines"). + Name(graphAnalyticsEngine.Name). + VersionedParams(&opts, scheme.ParameterCodec). + Body(graphAnalyticsEngine). + Do(ctx). + Into(result) + return +} + +// UpdateStatus was generated because the type contains a Status member. +// Add a +genclient:noStatus comment above the type to avoid generating UpdateStatus(). +func (c *graphAnalyticsEngines) UpdateStatus(ctx context.Context, graphAnalyticsEngine *v1alpha1.GraphAnalyticsEngine, opts v1.UpdateOptions) (result *v1alpha1.GraphAnalyticsEngine, err error) { + result = &v1alpha1.GraphAnalyticsEngine{} + err = c.client.Put(). + Namespace(c.ns). + Resource("graphanalyticsengines"). + Name(graphAnalyticsEngine.Name). + SubResource("status"). + VersionedParams(&opts, scheme.ParameterCodec). + Body(graphAnalyticsEngine). + Do(ctx). + Into(result) + return +} + +// Delete takes name of the graphAnalyticsEngine and deletes it. Returns an error if one occurs. +func (c *graphAnalyticsEngines) Delete(ctx context.Context, name string, opts v1.DeleteOptions) error { + return c.client.Delete(). + Namespace(c.ns). + Resource("graphanalyticsengines"). + Name(name). + Body(&opts). + Do(ctx). + Error() +} + +// DeleteCollection deletes a collection of objects. +func (c *graphAnalyticsEngines) DeleteCollection(ctx context.Context, opts v1.DeleteOptions, listOpts v1.ListOptions) error { + var timeout time.Duration + if listOpts.TimeoutSeconds != nil { + timeout = time.Duration(*listOpts.TimeoutSeconds) * time.Second + } + return c.client.Delete(). + Namespace(c.ns). + Resource("graphanalyticsengines"). + VersionedParams(&listOpts, scheme.ParameterCodec). + Timeout(timeout). + Body(&opts). + Do(ctx). + Error() +} + +// Patch applies the patch and returns the patched graphAnalyticsEngine. +func (c *graphAnalyticsEngines) Patch(ctx context.Context, name string, pt types.PatchType, data []byte, opts v1.PatchOptions, subresources ...string) (result *v1alpha1.GraphAnalyticsEngine, err error) { + result = &v1alpha1.GraphAnalyticsEngine{} + err = c.client.Patch(pt). + Namespace(c.ns). + Resource("graphanalyticsengines"). + Name(name). + SubResource(subresources...). + VersionedParams(&opts, scheme.ParameterCodec). + Body(data). + Do(ctx). + Into(result) + return +} diff --git a/pkg/generated/informers/externalversions/analytics/interface.go b/pkg/generated/informers/externalversions/analytics/interface.go new file mode 100644 index 000000000..6f7d6b64c --- /dev/null +++ b/pkg/generated/informers/externalversions/analytics/interface.go @@ -0,0 +1,50 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +// Code generated by informer-gen. DO NOT EDIT. + +package analytics + +import ( + v1alpha1 "github.com/arangodb/kube-arangodb/pkg/generated/informers/externalversions/analytics/v1alpha1" + internalinterfaces "github.com/arangodb/kube-arangodb/pkg/generated/informers/externalversions/internalinterfaces" +) + +// Interface provides access to each of this group's versions. +type Interface interface { + // V1alpha1 provides access to shared informers for resources in V1alpha1. + V1alpha1() v1alpha1.Interface +} + +type group struct { + factory internalinterfaces.SharedInformerFactory + namespace string + tweakListOptions internalinterfaces.TweakListOptionsFunc +} + +// New returns a new Interface. +func New(f internalinterfaces.SharedInformerFactory, namespace string, tweakListOptions internalinterfaces.TweakListOptionsFunc) Interface { + return &group{factory: f, namespace: namespace, tweakListOptions: tweakListOptions} +} + +// V1alpha1 returns a new v1alpha1.Interface. +func (g *group) V1alpha1() v1alpha1.Interface { + return v1alpha1.New(g.factory, g.namespace, g.tweakListOptions) +} diff --git a/pkg/generated/informers/externalversions/analytics/v1alpha1/graphanalyticsengine.go b/pkg/generated/informers/externalversions/analytics/v1alpha1/graphanalyticsengine.go new file mode 100644 index 000000000..0f1762e69 --- /dev/null +++ b/pkg/generated/informers/externalversions/analytics/v1alpha1/graphanalyticsengine.go @@ -0,0 +1,94 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +// Code generated by informer-gen. DO NOT EDIT. + +package v1alpha1 + +import ( + "context" + time "time" + + analyticsv1alpha1 "github.com/arangodb/kube-arangodb/pkg/apis/analytics/v1alpha1" + versioned "github.com/arangodb/kube-arangodb/pkg/generated/clientset/versioned" + internalinterfaces "github.com/arangodb/kube-arangodb/pkg/generated/informers/externalversions/internalinterfaces" + v1alpha1 "github.com/arangodb/kube-arangodb/pkg/generated/listers/analytics/v1alpha1" + v1 "k8s.io/apimachinery/pkg/apis/meta/v1" + runtime "k8s.io/apimachinery/pkg/runtime" + watch "k8s.io/apimachinery/pkg/watch" + cache "k8s.io/client-go/tools/cache" +) + +// GraphAnalyticsEngineInformer provides access to a shared informer and lister for +// GraphAnalyticsEngines. +type GraphAnalyticsEngineInformer interface { + Informer() cache.SharedIndexInformer + Lister() v1alpha1.GraphAnalyticsEngineLister +} + +type graphAnalyticsEngineInformer struct { + factory internalinterfaces.SharedInformerFactory + tweakListOptions internalinterfaces.TweakListOptionsFunc + namespace string +} + +// NewGraphAnalyticsEngineInformer constructs a new informer for GraphAnalyticsEngine type. +// Always prefer using an informer factory to get a shared informer instead of getting an independent +// one. This reduces memory footprint and number of connections to the server. +func NewGraphAnalyticsEngineInformer(client versioned.Interface, namespace string, resyncPeriod time.Duration, indexers cache.Indexers) cache.SharedIndexInformer { + return NewFilteredGraphAnalyticsEngineInformer(client, namespace, resyncPeriod, indexers, nil) +} + +// NewFilteredGraphAnalyticsEngineInformer constructs a new informer for GraphAnalyticsEngine type. +// Always prefer using an informer factory to get a shared informer instead of getting an independent +// one. This reduces memory footprint and number of connections to the server. +func NewFilteredGraphAnalyticsEngineInformer(client versioned.Interface, namespace string, resyncPeriod time.Duration, indexers cache.Indexers, tweakListOptions internalinterfaces.TweakListOptionsFunc) cache.SharedIndexInformer { + return cache.NewSharedIndexInformer( + &cache.ListWatch{ + ListFunc: func(options v1.ListOptions) (runtime.Object, error) { + if tweakListOptions != nil { + tweakListOptions(&options) + } + return client.AnalyticsV1alpha1().GraphAnalyticsEngines(namespace).List(context.TODO(), options) + }, + WatchFunc: func(options v1.ListOptions) (watch.Interface, error) { + if tweakListOptions != nil { + tweakListOptions(&options) + } + return client.AnalyticsV1alpha1().GraphAnalyticsEngines(namespace).Watch(context.TODO(), options) + }, + }, + &analyticsv1alpha1.GraphAnalyticsEngine{}, + resyncPeriod, + indexers, + ) +} + +func (f *graphAnalyticsEngineInformer) defaultInformer(client versioned.Interface, resyncPeriod time.Duration) cache.SharedIndexInformer { + return NewFilteredGraphAnalyticsEngineInformer(client, f.namespace, resyncPeriod, cache.Indexers{cache.NamespaceIndex: cache.MetaNamespaceIndexFunc}, f.tweakListOptions) +} + +func (f *graphAnalyticsEngineInformer) Informer() cache.SharedIndexInformer { + return f.factory.InformerFor(&analyticsv1alpha1.GraphAnalyticsEngine{}, f.defaultInformer) +} + +func (f *graphAnalyticsEngineInformer) Lister() v1alpha1.GraphAnalyticsEngineLister { + return v1alpha1.NewGraphAnalyticsEngineLister(f.Informer().GetIndexer()) +} diff --git a/pkg/generated/informers/externalversions/analytics/v1alpha1/interface.go b/pkg/generated/informers/externalversions/analytics/v1alpha1/interface.go new file mode 100644 index 000000000..85661b57c --- /dev/null +++ b/pkg/generated/informers/externalversions/analytics/v1alpha1/interface.go @@ -0,0 +1,49 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +// Code generated by informer-gen. DO NOT EDIT. + +package v1alpha1 + +import ( + internalinterfaces "github.com/arangodb/kube-arangodb/pkg/generated/informers/externalversions/internalinterfaces" +) + +// Interface provides access to all the informers in this group version. +type Interface interface { + // GraphAnalyticsEngines returns a GraphAnalyticsEngineInformer. + GraphAnalyticsEngines() GraphAnalyticsEngineInformer +} + +type version struct { + factory internalinterfaces.SharedInformerFactory + namespace string + tweakListOptions internalinterfaces.TweakListOptionsFunc +} + +// New returns a new Interface. +func New(f internalinterfaces.SharedInformerFactory, namespace string, tweakListOptions internalinterfaces.TweakListOptionsFunc) Interface { + return &version{factory: f, namespace: namespace, tweakListOptions: tweakListOptions} +} + +// GraphAnalyticsEngines returns a GraphAnalyticsEngineInformer. +func (v *version) GraphAnalyticsEngines() GraphAnalyticsEngineInformer { + return &graphAnalyticsEngineInformer{factory: v.factory, namespace: v.namespace, tweakListOptions: v.tweakListOptions} +} diff --git a/pkg/generated/informers/externalversions/factory.go b/pkg/generated/informers/externalversions/factory.go index 3c63d2075..484ba4ea1 100644 --- a/pkg/generated/informers/externalversions/factory.go +++ b/pkg/generated/informers/externalversions/factory.go @@ -28,6 +28,7 @@ import ( time "time" versioned "github.com/arangodb/kube-arangodb/pkg/generated/clientset/versioned" + analytics "github.com/arangodb/kube-arangodb/pkg/generated/informers/externalversions/analytics" apps "github.com/arangodb/kube-arangodb/pkg/generated/informers/externalversions/apps" backup "github.com/arangodb/kube-arangodb/pkg/generated/informers/externalversions/backup" deployment "github.com/arangodb/kube-arangodb/pkg/generated/informers/externalversions/deployment" @@ -263,6 +264,7 @@ type SharedInformerFactory interface { // client. InformerFor(obj runtime.Object, newFunc internalinterfaces.NewInformerFunc) cache.SharedIndexInformer + Analytics() analytics.Interface Apps() apps.Interface Backup() backup.Interface Database() deployment.Interface @@ -272,6 +274,10 @@ type SharedInformerFactory interface { Storage() storage.Interface } +func (f *sharedInformerFactory) Analytics() analytics.Interface { + return analytics.New(f, f.namespace, f.tweakListOptions) +} + func (f *sharedInformerFactory) Apps() apps.Interface { return apps.New(f, f.namespace, f.tweakListOptions) } diff --git a/pkg/generated/informers/externalversions/generic.go b/pkg/generated/informers/externalversions/generic.go index 59c6826ac..108f70a45 100644 --- a/pkg/generated/informers/externalversions/generic.go +++ b/pkg/generated/informers/externalversions/generic.go @@ -25,11 +25,12 @@ package externalversions import ( "fmt" + v1alpha1 "github.com/arangodb/kube-arangodb/pkg/apis/analytics/v1alpha1" v1 "github.com/arangodb/kube-arangodb/pkg/apis/apps/v1" backupv1 "github.com/arangodb/kube-arangodb/pkg/apis/backup/v1" deploymentv1 "github.com/arangodb/kube-arangodb/pkg/apis/deployment/v1" v2alpha1 "github.com/arangodb/kube-arangodb/pkg/apis/deployment/v2alpha1" - v1alpha1 "github.com/arangodb/kube-arangodb/pkg/apis/ml/v1alpha1" + mlv1alpha1 "github.com/arangodb/kube-arangodb/pkg/apis/ml/v1alpha1" v1beta1 "github.com/arangodb/kube-arangodb/pkg/apis/ml/v1beta1" replicationv1 "github.com/arangodb/kube-arangodb/pkg/apis/replication/v1" replicationv2alpha1 "github.com/arangodb/kube-arangodb/pkg/apis/replication/v2alpha1" @@ -66,7 +67,11 @@ func (f *genericInformer) Lister() cache.GenericLister { // TODO extend this to unknown resources with a client pool func (f *sharedInformerFactory) ForResource(resource schema.GroupVersionResource) (GenericInformer, error) { switch resource { - // Group=apps.arangodb.com, Version=v1 + // Group=analytics.arangodb.com, Version=v1alpha1 + case v1alpha1.SchemeGroupVersion.WithResource("graphanalyticsengines"): + return &genericInformer{resource: resource.GroupResource(), informer: f.Analytics().V1alpha1().GraphAnalyticsEngines().Informer()}, nil + + // Group=apps.arangodb.com, Version=v1 case v1.SchemeGroupVersion.WithResource("arangojobs"): return &genericInformer{resource: resource.GroupResource(), informer: f.Apps().V1().ArangoJobs().Informer()}, nil @@ -97,13 +102,13 @@ func (f *sharedInformerFactory) ForResource(resource schema.GroupVersionResource return &genericInformer{resource: resource.GroupResource(), informer: f.Database().V2alpha1().ArangoTasks().Informer()}, nil // Group=ml.arangodb.com, Version=v1alpha1 - case v1alpha1.SchemeGroupVersion.WithResource("arangomlbatchjobs"): + case mlv1alpha1.SchemeGroupVersion.WithResource("arangomlbatchjobs"): return &genericInformer{resource: resource.GroupResource(), informer: f.Ml().V1alpha1().ArangoMLBatchJobs().Informer()}, nil - case v1alpha1.SchemeGroupVersion.WithResource("arangomlcronjobs"): + case mlv1alpha1.SchemeGroupVersion.WithResource("arangomlcronjobs"): return &genericInformer{resource: resource.GroupResource(), informer: f.Ml().V1alpha1().ArangoMLCronJobs().Informer()}, nil - case v1alpha1.SchemeGroupVersion.WithResource("arangomlextensions"): + case mlv1alpha1.SchemeGroupVersion.WithResource("arangomlextensions"): return &genericInformer{resource: resource.GroupResource(), informer: f.Ml().V1alpha1().ArangoMLExtensions().Informer()}, nil - case v1alpha1.SchemeGroupVersion.WithResource("arangomlstorages"): + case mlv1alpha1.SchemeGroupVersion.WithResource("arangomlstorages"): return &genericInformer{resource: resource.GroupResource(), informer: f.Ml().V1alpha1().ArangoMLStorages().Informer()}, nil // Group=ml.arangodb.com, Version=v1beta1 diff --git a/pkg/generated/listers/analytics/v1alpha1/expansion_generated.go b/pkg/generated/listers/analytics/v1alpha1/expansion_generated.go new file mode 100644 index 000000000..eb4ab75b3 --- /dev/null +++ b/pkg/generated/listers/analytics/v1alpha1/expansion_generated.go @@ -0,0 +1,31 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +// Code generated by lister-gen. DO NOT EDIT. + +package v1alpha1 + +// GraphAnalyticsEngineListerExpansion allows custom methods to be added to +// GraphAnalyticsEngineLister. +type GraphAnalyticsEngineListerExpansion interface{} + +// GraphAnalyticsEngineNamespaceListerExpansion allows custom methods to be added to +// GraphAnalyticsEngineNamespaceLister. +type GraphAnalyticsEngineNamespaceListerExpansion interface{} diff --git a/pkg/generated/listers/analytics/v1alpha1/graphanalyticsengine.go b/pkg/generated/listers/analytics/v1alpha1/graphanalyticsengine.go new file mode 100644 index 000000000..5c6596981 --- /dev/null +++ b/pkg/generated/listers/analytics/v1alpha1/graphanalyticsengine.go @@ -0,0 +1,103 @@ +// +// DISCLAIMER +// +// Copyright 2024 ArangoDB GmbH, Cologne, Germany +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// +// Copyright holder is ArangoDB GmbH, Cologne, Germany +// + +// Code generated by lister-gen. DO NOT EDIT. + +package v1alpha1 + +import ( + v1alpha1 "github.com/arangodb/kube-arangodb/pkg/apis/analytics/v1alpha1" + "k8s.io/apimachinery/pkg/api/errors" + "k8s.io/apimachinery/pkg/labels" + "k8s.io/client-go/tools/cache" +) + +// GraphAnalyticsEngineLister helps list GraphAnalyticsEngines. +// All objects returned here must be treated as read-only. +type GraphAnalyticsEngineLister interface { + // List lists all GraphAnalyticsEngines in the indexer. + // Objects returned here must be treated as read-only. + List(selector labels.Selector) (ret []*v1alpha1.GraphAnalyticsEngine, err error) + // GraphAnalyticsEngines returns an object that can list and get GraphAnalyticsEngines. + GraphAnalyticsEngines(namespace string) GraphAnalyticsEngineNamespaceLister + GraphAnalyticsEngineListerExpansion +} + +// graphAnalyticsEngineLister implements the GraphAnalyticsEngineLister interface. +type graphAnalyticsEngineLister struct { + indexer cache.Indexer +} + +// NewGraphAnalyticsEngineLister returns a new GraphAnalyticsEngineLister. +func NewGraphAnalyticsEngineLister(indexer cache.Indexer) GraphAnalyticsEngineLister { + return &graphAnalyticsEngineLister{indexer: indexer} +} + +// List lists all GraphAnalyticsEngines in the indexer. +func (s *graphAnalyticsEngineLister) List(selector labels.Selector) (ret []*v1alpha1.GraphAnalyticsEngine, err error) { + err = cache.ListAll(s.indexer, selector, func(m interface{}) { + ret = append(ret, m.(*v1alpha1.GraphAnalyticsEngine)) + }) + return ret, err +} + +// GraphAnalyticsEngines returns an object that can list and get GraphAnalyticsEngines. +func (s *graphAnalyticsEngineLister) GraphAnalyticsEngines(namespace string) GraphAnalyticsEngineNamespaceLister { + return graphAnalyticsEngineNamespaceLister{indexer: s.indexer, namespace: namespace} +} + +// GraphAnalyticsEngineNamespaceLister helps list and get GraphAnalyticsEngines. +// All objects returned here must be treated as read-only. +type GraphAnalyticsEngineNamespaceLister interface { + // List lists all GraphAnalyticsEngines in the indexer for a given namespace. + // Objects returned here must be treated as read-only. + List(selector labels.Selector) (ret []*v1alpha1.GraphAnalyticsEngine, err error) + // Get retrieves the GraphAnalyticsEngine from the indexer for a given namespace and name. + // Objects returned here must be treated as read-only. + Get(name string) (*v1alpha1.GraphAnalyticsEngine, error) + GraphAnalyticsEngineNamespaceListerExpansion +} + +// graphAnalyticsEngineNamespaceLister implements the GraphAnalyticsEngineNamespaceLister +// interface. +type graphAnalyticsEngineNamespaceLister struct { + indexer cache.Indexer + namespace string +} + +// List lists all GraphAnalyticsEngines in the indexer for a given namespace. +func (s graphAnalyticsEngineNamespaceLister) List(selector labels.Selector) (ret []*v1alpha1.GraphAnalyticsEngine, err error) { + err = cache.ListAllByNamespace(s.indexer, s.namespace, selector, func(m interface{}) { + ret = append(ret, m.(*v1alpha1.GraphAnalyticsEngine)) + }) + return ret, err +} + +// Get retrieves the GraphAnalyticsEngine from the indexer for a given namespace and name. +func (s graphAnalyticsEngineNamespaceLister) Get(name string) (*v1alpha1.GraphAnalyticsEngine, error) { + obj, exists, err := s.indexer.GetByKey(s.namespace + "/" + name) + if err != nil { + return nil, err + } + if !exists { + return nil, errors.NewNotFound(v1alpha1.Resource("graphanalyticsengine"), name) + } + return obj.(*v1alpha1.GraphAnalyticsEngine), nil +} diff --git a/pkg/operator/operator.community.go b/pkg/operator/operator.community.go index b8b6b9870..cead56db4 100644 --- a/pkg/operator/operator.community.go +++ b/pkg/operator/operator.community.go @@ -1,7 +1,7 @@ // // DISCLAIMER // -// Copyright 2023 ArangoDB GmbH, Cologne, Germany +// Copyright 2023-2024 ArangoDB GmbH, Cologne, Germany // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. @@ -40,3 +40,12 @@ func (o *Operator) onStartML(stop <-chan struct{}) { func (o *Operator) onStartOperatorV2ML(operator operatorV2.Operator, recorder event.Recorder, client arangoClientSet.Interface, kubeClient kubernetes.Interface, informer arangoInformer.SharedInformerFactory, kubeInformer informers.SharedInformerFactory) { panic("Unable to start ML Operator in Community") } + +// onStartAnalytics starts the operator and run till given channel is closed. +func (o *Operator) onStartAnalytics(stop <-chan struct{}) { + panic("Unable to start Analytics Operator in Community") +} + +func (o *Operator) onStartOperatorV2Analytics(operator operatorV2.Operator, recorder event.Recorder, client arangoClientSet.Interface, kubeClient kubernetes.Interface, informer arangoInformer.SharedInformerFactory, kubeInformer informers.SharedInformerFactory) { + panic("Unable to start Analytics Operator in Community") +} diff --git a/pkg/operator/operator.go b/pkg/operator/operator.go index a050423cc..c83515751 100644 --- a/pkg/operator/operator.go +++ b/pkg/operator/operator.go @@ -1,7 +1,7 @@ // // DISCLAIMER // -// Copyright 2016-2023 ArangoDB GmbH, Cologne, Germany +// Copyright 2016-2024 ArangoDB GmbH, Cologne, Germany // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. @@ -68,9 +68,10 @@ var logger = logging.Global().RegisterAndGetLogger("operator", logging.Info) type operatorV2type string const ( - backupOperator operatorV2type = "backup" - mlOperator operatorV2type = "ml" - appsOperator operatorV2type = "apps" + backupOperator operatorV2type = "backup" + mlOperator operatorV2type = "ml" + analyticsOperator operatorV2type = "analytics" + appsOperator operatorV2type = "apps" ) type Event struct { @@ -100,6 +101,7 @@ type Config struct { EnableDeploymentReplication bool EnableStorage bool EnableML bool + EnableAnalytics bool EnableBackup bool EnableApps bool EnableK2KClusterSync bool @@ -121,6 +123,7 @@ type Dependencies struct { StorageProbe *probe.ReadyProbe BackupProbe *probe.ReadyProbe MlProbe *probe.ReadyProbe + AnalyticsProbe *probe.ReadyProbe AppsProbe *probe.ReadyProbe K2KClusterSyncProbe *probe.ReadyProbe } @@ -182,6 +185,13 @@ func (o *Operator) Run() { go o.runWithoutLeaderElection("arango-ml-operator", constants.MLLabelRole, o.onStartML, o.Dependencies.MlProbe) } } + if o.Config.EnableAnalytics { + if !o.Config.SingleMode { + go o.runLeaderElection("arango-analytics-operator", constants.AnalyticsLabelRole, o.onStartAnalytics, o.Dependencies.AnalyticsProbe) + } else { + go o.runWithoutLeaderElection("arango-analytics-operator", constants.AnalyticsLabelRole, o.onStartAnalytics, o.Dependencies.AnalyticsProbe) + } + } if o.Config.EnableK2KClusterSync { // Nothing to do o.log.Warn("K2K Cluster sync is permanently disabled") @@ -277,6 +287,9 @@ func (o *Operator) onStartOperatorV2(operatorType operatorV2type, stop <-chan st case mlOperator: o.onStartOperatorV2ML(operator, eventRecorder, o.Client.Arango(), o.Client.Kubernetes(), arangoInformer, kubeInformer) o.Dependencies.MlProbe.SetReady() + case analyticsOperator: + o.onStartOperatorV2Analytics(operator, eventRecorder, o.Client.Arango(), o.Client.Kubernetes(), arangoInformer, kubeInformer) + o.Dependencies.AnalyticsProbe.SetReady() } if err := operator.RegisterStarter(arangoInformer); err != nil { @@ -291,6 +304,7 @@ func (o *Operator) onStartOperatorV2(operatorType operatorV2type, stop <-chan st operator.Start(8, stop) o.Dependencies.MlProbe.SetReady() + o.Dependencies.AnalyticsProbe.SetReady() <-stop } diff --git a/pkg/operatorV2/update_wraps.go b/pkg/operatorV2/update_wraps.go index a7bc813a8..a936e1e41 100644 --- a/pkg/operatorV2/update_wraps.go +++ b/pkg/operatorV2/update_wraps.go @@ -25,6 +25,7 @@ import ( meta "k8s.io/apimachinery/pkg/apis/meta/v1" + analyticsApi "github.com/arangodb/kube-arangodb/pkg/apis/analytics/v1alpha1" backupApi "github.com/arangodb/kube-arangodb/pkg/apis/backup/v1" mlApiv1alpha1 "github.com/arangodb/kube-arangodb/pkg/apis/ml/v1alpha1" mlApi "github.com/arangodb/kube-arangodb/pkg/apis/ml/v1beta1" @@ -46,6 +47,10 @@ func WithArangoBatchJobUpdateStatusInterfaceRetry(ctx context.Context, client Up return WithUpdateStatusInterfaceRetry[mlApiv1alpha1.ArangoMLBatchJobStatus, *mlApiv1alpha1.ArangoMLBatchJob](ctx, client, obj, status, opts) } +func WithAnalyticsGAEUpdateStatusInterfaceRetry(ctx context.Context, client UpdateStatusInterface[analyticsApi.GraphAnalyticsEngineStatus, *analyticsApi.GraphAnalyticsEngine], obj *analyticsApi.GraphAnalyticsEngine, status analyticsApi.GraphAnalyticsEngineStatus, opts meta.UpdateOptions) (*analyticsApi.GraphAnalyticsEngine, error) { + return WithUpdateStatusInterfaceRetry[analyticsApi.GraphAnalyticsEngineStatus, *analyticsApi.GraphAnalyticsEngine](ctx, client, obj, status, opts) +} + func WithArangoStorageUpdateStatusInterfaceRetry(ctx context.Context, client UpdateStatusInterface[mlApi.ArangoMLStorageStatus, *mlApi.ArangoMLStorage], obj *mlApi.ArangoMLStorage, status mlApi.ArangoMLStorageStatus, opts meta.UpdateOptions) (*mlApi.ArangoMLStorage, error) { return WithUpdateStatusInterfaceRetry[mlApi.ArangoMLStorageStatus, *mlApi.ArangoMLStorage](ctx, client, obj, status, opts) } diff --git a/pkg/server/server.go b/pkg/server/server.go index faa396897..0bf9ccac1 100644 --- a/pkg/server/server.go +++ b/pkg/server/server.go @@ -69,6 +69,7 @@ type Dependencies struct { Backup OperatorDependency Apps OperatorDependency ML OperatorDependency + Analytics OperatorDependency ClusterSync OperatorDependency Operators Operators Secrets typedCore.SecretInterface @@ -189,6 +190,10 @@ func NewServer(cli typedCore.CoreV1Interface, cfg Config, deps Dependencies) (*S r.GET("/ready/ml", gin.WrapF(deps.ML.Probe.ReadyHandler)) readyProbes = append(readyProbes, deps.ML.Probe) } + if deps.Analytics.Enabled { + r.GET("/ready/analytics", gin.WrapF(deps.Analytics.Probe.ReadyHandler)) + readyProbes = append(readyProbes, deps.Analytics.Probe) + } r.GET("/ready", gin.WrapF(ready(readyProbes...))) r.GET("/metrics", gin.WrapF(metrics.Handler())) r.POST("/login", s.auth.handleLogin) diff --git a/pkg/util/constants/constants.go b/pkg/util/constants/constants.go index 5824722e0..245d3ec05 100644 --- a/pkg/util/constants/constants.go +++ b/pkg/util/constants/constants.go @@ -72,6 +72,7 @@ const ( BackupLabelRole = "backup/role" MLLabelRole = "ml/role" + AnalyticsLabelRole = "analytics/role" AppsLabelRole = "apps/role" ClusterSyncLabelRole = "clustersync/role" LabelRole = "role" diff --git a/pkg/util/tests/kubernetes.go b/pkg/util/tests/kubernetes.go index 8c7ff8ba1..fe5e30498 100644 --- a/pkg/util/tests/kubernetes.go +++ b/pkg/util/tests/kubernetes.go @@ -36,6 +36,8 @@ import ( "k8s.io/apimachinery/pkg/util/uuid" "k8s.io/client-go/kubernetes" + "github.com/arangodb/kube-arangodb/pkg/apis/analytics" + analyticsApi "github.com/arangodb/kube-arangodb/pkg/apis/analytics/v1alpha1" "github.com/arangodb/kube-arangodb/pkg/apis/backup" backupApi "github.com/arangodb/kube-arangodb/pkg/apis/backup/v1" "github.com/arangodb/kube-arangodb/pkg/apis/deployment" @@ -235,6 +237,12 @@ func CreateObjects(t *testing.T, k8s kubernetes.Interface, arango arangoClientSe vl := *v _, err := arango.SchedulerV1beta1().ArangoProfiles(vl.GetNamespace()).Create(context.Background(), vl, meta.CreateOptions{}) require.NoError(t, err) + case **analyticsApi.GraphAnalyticsEngine: + require.NotNil(t, v) + + vl := *v + _, err := arango.AnalyticsV1alpha1().GraphAnalyticsEngines(vl.GetNamespace()).Create(context.Background(), vl, meta.CreateOptions{}) + require.NoError(t, err) default: require.Fail(t, fmt.Sprintf("Unable to create object: %s", reflect.TypeOf(v).String())) } @@ -383,6 +391,12 @@ func UpdateObjects(t *testing.T, k8s kubernetes.Interface, arango arangoClientSe vl := *v _, err := arango.SchedulerV1beta1().ArangoProfiles(vl.GetNamespace()).Update(context.Background(), vl, meta.UpdateOptions{}) require.NoError(t, err) + case **analyticsApi.GraphAnalyticsEngine: + require.NotNil(t, v) + + vl := *v + _, err := arango.AnalyticsV1alpha1().GraphAnalyticsEngines(vl.GetNamespace()).Update(context.Background(), vl, meta.UpdateOptions{}) + require.NoError(t, err) default: require.Fail(t, fmt.Sprintf("Unable to create object: %s", reflect.TypeOf(v).String())) } @@ -506,6 +520,11 @@ func DeleteObjects(t *testing.T, k8s kubernetes.Interface, arango arangoClientSe vl := *v require.NoError(t, arango.SchedulerV1beta1().ArangoProfiles(vl.GetNamespace()).Delete(context.Background(), vl.GetName(), meta.DeleteOptions{})) + case **analyticsApi.GraphAnalyticsEngine: + require.NotNil(t, v) + + vl := *v + require.NoError(t, arango.AnalyticsV1alpha1().GraphAnalyticsEngines(vl.GetNamespace()).Delete(context.Background(), vl.GetName(), meta.DeleteOptions{})) default: require.Fail(t, fmt.Sprintf("Unable to delete object: %s", reflect.TypeOf(v).String())) } @@ -848,6 +867,21 @@ func RefreshObjects(t *testing.T, k8s kubernetes.Interface, arango arangoClientS } else { *v = vn } + case **analyticsApi.GraphAnalyticsEngine: + require.NotNil(t, v) + + vl := *v + + vn, err := arango.AnalyticsV1alpha1().GraphAnalyticsEngines(vl.GetNamespace()).Get(context.Background(), vl.GetName(), meta.GetOptions{}) + if err != nil { + if kerrors.IsNotFound(err) { + *v = nil + } else { + require.NoError(t, err) + } + } else { + *v = vn + } default: require.Fail(t, fmt.Sprintf("Unable to get object: %s", reflect.TypeOf(v).String())) } @@ -1012,6 +1046,14 @@ func SetMetaBasedOnType(t *testing.T, object meta.Object) { scheduler.ArangoProfileResourcePlural, object.GetNamespace(), object.GetName())) + case *analyticsApi.GraphAnalyticsEngine: + v.Kind = analytics.GraphAnalyticsEngineResourceKind + v.APIVersion = analyticsApi.SchemeGroupVersion.String() + v.SetSelfLink(fmt.Sprintf("/api/%s/%s/%s/%s", + analyticsApi.SchemeGroupVersion.String(), + analytics.GraphAnalyticsEngineResourcePlural, + object.GetNamespace(), + object.GetName())) default: require.Fail(t, fmt.Sprintf("Unable to create object: %s", reflect.TypeOf(v).String())) } @@ -1182,6 +1224,12 @@ func GVK(t *testing.T, object meta.Object) schema.GroupVersionKind { Version: schedulerApi.ArangoSchedulerVersion, Kind: scheduler.ArangoProfileResourceKind, } + case *analyticsApi.GraphAnalyticsEngine: + return schema.GroupVersionKind{ + Group: analytics.ArangoAnalyticsGroupName, + Version: analyticsApi.ArangoAnalyticsVersion, + Kind: analytics.GraphAnalyticsEngineResourceKind, + } default: require.Fail(t, fmt.Sprintf("Unable to create object: %s", reflect.TypeOf(v).String())) return schema.GroupVersionKind{} diff --git a/pkg/util/tests/kubernetes_test.go b/pkg/util/tests/kubernetes_test.go index 84477e301..d5e2716ce 100644 --- a/pkg/util/tests/kubernetes_test.go +++ b/pkg/util/tests/kubernetes_test.go @@ -31,6 +31,7 @@ import ( rbac "k8s.io/api/rbac/v1" meta "k8s.io/apimachinery/pkg/apis/meta/v1" + analyticsApi "github.com/arangodb/kube-arangodb/pkg/apis/analytics/v1alpha1" backupApi "github.com/arangodb/kube-arangodb/pkg/apis/backup/v1" api "github.com/arangodb/kube-arangodb/pkg/apis/deployment/v1" mlApiv1alpha1 "github.com/arangodb/kube-arangodb/pkg/apis/ml/v1alpha1" @@ -85,4 +86,5 @@ func Test_NewMetaObject(t *testing.T) { NewMetaObjectRun[*mlApiv1alpha1.ArangoMLBatchJob](t) NewMetaObjectRun[*mlApiv1alpha1.ArangoMLCronJob](t) NewMetaObjectRun[*schedulerApi.ArangoProfile](t) + NewMetaObjectRun[*analyticsApi.GraphAnalyticsEngine](t) }