From fbff8b2ac04227d59cff0f2a53c8cdbdaa775900 Mon Sep 17 00:00:00 2001 From: Stephen Kitt Date: Tue, 14 Apr 2020 10:31:54 +0200 Subject: [PATCH] Add Gateway CRD This will be used to store and report the cluster-local engine status. Signed-off-by: Stephen Kitt --- .../operator/submarinerop/crds/ensure.go | 31 +++++++++++++++++-- 1 file changed, 29 insertions(+), 2 deletions(-) diff --git a/pkg/subctl/operator/submarinerop/crds/ensure.go b/pkg/subctl/operator/submarinerop/crds/ensure.go index 920703d42..3cbc7fb5d 100644 --- a/pkg/subctl/operator/submarinerop/crds/ensure.go +++ b/pkg/subctl/operator/submarinerop/crds/ensure.go @@ -37,7 +37,7 @@ func Ensure(restConfig *rest.Config) (bool, error) { return false, err } - crd, err := getSubmarinerCRD() + submarinerCrd, err := getSubmarinerCRD() if err != nil { return false, err } @@ -45,8 +45,13 @@ func Ensure(restConfig *rest.Config) (bool, error) { // Attempt to update or create the CRD definition // TODO(majopela): In the future we may want to report when we have updated the existing // CRD definition with new versions - return updateOrCreateCRD(clientSet, crd) + submarinerResult, err := updateOrCreateCRD(clientSet, submarinerCrd) + if err != nil { + return submarinerResult, err + } + gatewaysResult, err := updateOrCreateCRD(clientSet, getGatewaysCRD()) + return (submarinerResult || gatewaysResult), err } func updateOrCreateCRD(clientSet clientset.Interface, crd *apiextensionsv1beta1.CustomResourceDefinition) (bool, error) { @@ -77,3 +82,25 @@ func getSubmarinerCRD() (*apiextensionsv1beta1.CustomResourceDefinition, error) return crd, nil } + +// TODO Move this to the operator +func getGatewaysCRD() *apiextensionsv1beta1.CustomResourceDefinition { + crd := &apiextensionsv1beta1.CustomResourceDefinition{ + ObjectMeta: v1.ObjectMeta{ + Name: "gateways.submariner.io", + }, + Spec: apiextensionsv1beta1.CustomResourceDefinitionSpec{ + Group: "submariner.io", + Scope: apiextensionsv1beta1.NamespaceScoped, + Names: apiextensionsv1beta1.CustomResourceDefinitionNames{ + Plural: "gateways", + Singular: "gateway", + ListKind: "GatewayList", + Kind: "Gateway", + }, + Version: "v1", + }, + } + + return crd +}