diff options
author | Rajamohan Raj <rajamohan.raj@intel.com> | 2020-04-15 18:45:47 +0000 |
---|---|---|
committer | Rajamohan Raj <rajamohan.raj@intel.com> | 2020-04-17 23:33:04 +0000 |
commit | 6e0b4df46f51f9793f2d88626234edaaf9992403 (patch) | |
tree | 1c91022afe63ee3643ff5a1246a28236e5d33c32 /src/orchestrator/pkg/gpic/gpic.go | |
parent | 1c3a22e3de0dd24b4161ae8b34794627620a208b (diff) |
Added intentResolver
IntentResolver shall collect the clusterdetails for each of the app
where it needs to be deployed. This shall be called by
the instantiation code.
Issue-ID: MULTICLOUD-1041
Signed-off-by: Rajamohan Raj <rajamohan.raj@intel.com>
Change-Id: I7d29901e46a5349ef502786c187c1c88bea61a12
Diffstat (limited to 'src/orchestrator/pkg/gpic/gpic.go')
-rw-r--r-- | src/orchestrator/pkg/gpic/gpic.go | 120 |
1 files changed, 120 insertions, 0 deletions
diff --git a/src/orchestrator/pkg/gpic/gpic.go b/src/orchestrator/pkg/gpic/gpic.go new file mode 100644 index 00000000..f02e5352 --- /dev/null +++ b/src/orchestrator/pkg/gpic/gpic.go @@ -0,0 +1,120 @@ +/* + * Copyright 2020 Intel Corporation, Inc + * + * 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. + */ + +package gpic + +/* + gpic stands for GenericPlacementIntent Controller. + This file pertains to the implementation and handling of generic placement intents +*/ + +import ( + "log" + ncmmodule "github.com/onap/multicloud-k8s/src/ncm/pkg/module" + pkgerrors "github.com/pkg/errors" +) + +// Clusters has 1 field - a list of ClusterNames +type Clusters struct { + ClustersWithName []ClusterWithName +} + +// ClusterWithName has two fields - ProviderName and ClusterName +type ClusterWithName struct { + ProviderName string + ClusterName string +} + +// ClusterWithLabel has two fields - ProviderName and ClusterLabel +type ClusterWithLabel struct { + ProviderName string + ClusterLabel string +} + +// IntentStruc consists of AllOfArray and AnyOfArray +type IntentStruc struct { + AllOfArray []AllOf `json:"allOf,omitempty"` + AnyOfArray []AnyOf `json:"anyOf,omitempty"` +} + +// AllOf consists if ProviderName, ClusterName, ClusterLabelName and AnyOfArray. Any of them can be empty +type AllOf struct { + ProviderName string `json:"provider-name,omitempty"` + ClusterName string `json:"cluster-name,omitempty"` + ClusterLabelName string `json:"cluster-label-name,omitempty"` + AnyOfArray []AnyOf `json:"anyOf,omitempty"` +} + +// AnyOf consists of Array of ProviderName & ClusterLabelNames +type AnyOf struct { + ProviderName string `json:"provider-name,omitempty"` + ClusterName string `json:"cluster-name,omitempty"` + ClusterLabelName string `json:"cluster-label-name,omitempty"` +} + +// intentResolverHelper helps to populate the cluster lists +func intentResolverHelper(pn, cn, cln string, clustersWithName []ClusterWithName) ([]ClusterWithName, error) { + if cln == "" && cn != "" { + eachClusterWithName := ClusterWithName{pn, cn} + clustersWithName = append(clustersWithName, eachClusterWithName) + log.Printf("Added Cluster: %s ", cn) + } + if cn == "" && cln != "" { + //Finding cluster names for the clusterlabel + clusterNamesList, err := ncmmodule.NewClusterClient().GetClustersWithLabel(pn, cln) + if err != nil { + return []ClusterWithName{}, pkgerrors.Wrap(err, "Error getting clusterLabels") + } + // Populate the clustersWithName array with the clusternames found above + for _, eachClusterName := range clusterNamesList { + eachClusterWithPN := ClusterWithName{pn, eachClusterName} + clustersWithName = append(clustersWithName, eachClusterWithPN) + log.Printf("Added Cluster: %s ", cln) + } + } + return clustersWithName, nil +} + +// IntentResolver shall help to resolve the given intent into 2 lists of clusters where the app need to be deployed. +func IntentResolver(intent IntentStruc) (Clusters, error) { + var clustersWithName []ClusterWithName + var err error + + for _, eachAllOf := range intent.AllOfArray { + clustersWithName, err = intentResolverHelper(eachAllOf.ProviderName, eachAllOf.ClusterName, eachAllOf.ClusterLabelName, clustersWithName) + if err!=nil { + return Clusters{}, pkgerrors.Wrap(err, "intentResolverHelper error") + } + if len(eachAllOf.AnyOfArray) > 0 { + for _, eachAnyOf := range eachAllOf.AnyOfArray { + clustersWithName, err = intentResolverHelper(eachAnyOf.ProviderName, eachAnyOf.ClusterName, eachAnyOf.ClusterLabelName, clustersWithName) + if err!=nil { + return Clusters{}, pkgerrors.Wrap(err, "intentResolverHelper error") + } + } + } + } + if len(intent.AnyOfArray) > 0 { + for _, eachAnyOf := range intent.AnyOfArray { + clustersWithName, err = intentResolverHelper(eachAnyOf.ProviderName, eachAnyOf.ClusterName, eachAnyOf.ClusterLabelName, clustersWithName) + if err!=nil { + return Clusters{}, pkgerrors.Wrap(err, "intentResolverHelper error") + } + } + } + clusters := Clusters{clustersWithName} + return clusters, nil +} |