2 * Copyright © 2017-2018 AT&T Intellectual Property.
\r
3 * Modifications Copyright © 2018 IBM.
\r
5 * Licensed under the Apache License, Version 2.0 (the "License");
\r
6 * you may not use this file except in compliance with the License.
\r
7 * You may obtain a copy of the License at
\r
9 * http://www.apache.org/licenses/LICENSE-2.0
\r
11 * Unless required by applicable law or agreed to in writing, software
\r
12 * distributed under the License is distributed on an "AS IS" BASIS,
\r
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
\r
14 * See the License for the specific language governing permissions and
\r
15 * limitations under the License.
\r
18 package org.onap.ccsdk.apps.controllerblueprints.service.enhancer
\r
20 import com.att.eelf.configuration.EELFLogger
\r
21 import com.att.eelf.configuration.EELFManager
\r
22 import org.onap.ccsdk.apps.controllerblueprints.core.BluePrintException
\r
23 import org.onap.ccsdk.apps.controllerblueprints.core.BluePrintTypes
\r
24 import org.onap.ccsdk.apps.controllerblueprints.core.data.*
\r
25 import org.onap.ccsdk.apps.controllerblueprints.core.format
\r
26 import org.onap.ccsdk.apps.controllerblueprints.core.interfaces.BluePrintEnhancerService
\r
27 import org.onap.ccsdk.apps.controllerblueprints.core.service.BluePrintContext
\r
28 import org.onap.ccsdk.apps.controllerblueprints.core.service.BluePrintRepoService
\r
29 import org.onap.ccsdk.apps.controllerblueprints.core.utils.BluePrintFileUtils
\r
30 import org.onap.ccsdk.apps.controllerblueprints.core.utils.BluePrintMetadataUtils
\r
32 open class BluePrintEnhancerServiceImpl(val bluePrintRepoService: BluePrintRepoService) : BluePrintEnhancerService {
\r
34 private val log: EELFLogger = EELFManager.getInstance().getLogger(BluePrintEnhancerServiceImpl::class.toString())
\r
36 lateinit var serviceTemplate: ServiceTemplate
\r
38 override fun enhance(basePath: String, enrichedBasePath: String): BluePrintContext {
\r
39 BluePrintFileUtils.copyBluePrint(basePath, enrichedBasePath)
\r
40 BluePrintFileUtils.deleteBluePrintTypes(enrichedBasePath)
\r
41 val enhancedBluePrintContext = enhance(enrichedBasePath)
\r
42 BluePrintFileUtils.writeBluePrintTypes(enhancedBluePrintContext)
\r
43 return enhancedBluePrintContext
\r
46 @Throws(BluePrintException::class)
\r
47 override fun enhance(basePath: String): BluePrintContext {
\r
48 val bluePrintContext = BluePrintMetadataUtils.getBluePrintContext(basePath)
\r
49 enhance(bluePrintContext.serviceTemplate)
\r
50 return bluePrintContext
\r
53 @Throws(BluePrintException::class)
\r
54 override fun enhance(serviceTemplate: ServiceTemplate): ServiceTemplate {
\r
55 this.serviceTemplate = serviceTemplate
\r
57 enrichTopologyTemplate(serviceTemplate)
\r
59 // log.info("Enriched Blueprint :\n {}", JacksonUtils.getJson(serviceTemplate, true))
\r
60 return this.serviceTemplate
\r
63 open fun initialCleanUp() {
\r
64 serviceTemplate.artifactTypes?.clear()
\r
65 serviceTemplate.nodeTypes?.clear()
\r
66 serviceTemplate.dataTypes?.clear()
\r
67 serviceTemplate.policyTypes?.clear()
\r
69 serviceTemplate.artifactTypes = mutableMapOf()
\r
70 serviceTemplate.nodeTypes = mutableMapOf()
\r
71 serviceTemplate.dataTypes = mutableMapOf()
\r
72 serviceTemplate.policyTypes = mutableMapOf()
\r
76 @Throws(BluePrintException::class)
\r
77 open fun enrichTopologyTemplate(serviceTemplate: ServiceTemplate) {
\r
78 serviceTemplate.topologyTemplate?.let { topologyTemplate ->
\r
79 enrichTopologyTemplateInputs(topologyTemplate)
\r
80 enrichTopologyTemplateNodeTemplates(topologyTemplate)
\r
84 @Throws(BluePrintException::class)
\r
85 open fun enrichTopologyTemplateInputs(topologyTemplate: TopologyTemplate) {
\r
86 topologyTemplate.inputs?.let { inputs ->
\r
87 enrichPropertyDefinitions(inputs)
\r
91 open fun enrichTopologyTemplateNodeTemplates(topologyTemplate: TopologyTemplate) {
\r
92 topologyTemplate.nodeTemplates?.forEach { nodeTemplateName, nodeTemplate ->
\r
93 enrichNodeTemplate(nodeTemplateName, nodeTemplate)
\r
97 @Throws(BluePrintException::class)
\r
98 open fun enrichNodeTemplate(nodeTemplateName: String, nodeTemplate: NodeTemplate) {
\r
99 val nodeTypeName = nodeTemplate.type
\r
100 // Get NodeType from Repo and Update Service Template
\r
101 val nodeType = populateNodeType(nodeTypeName)
\r
104 enrichNodeType(nodeTypeName, nodeType)
\r
106 //Enrich Node Template Artifacts
\r
107 enrichNodeTemplateArtifactDefinition(nodeTemplateName, nodeTemplate)
\r
110 @Throws(BluePrintException::class)
\r
111 fun enrichNodeType(nodeTypeName: String, nodeType: NodeType) {
\r
112 log.debug("Enriching NodeType({})", nodeTypeName)
\r
113 val derivedFrom = nodeType.derivedFrom
\r
115 if (!BluePrintTypes.rootNodeTypes().contains(derivedFrom)) {
\r
116 val derivedFromNodeType = populateNodeType(nodeTypeName)
\r
118 enrichNodeType(derivedFrom, derivedFromNodeType)
\r
121 // NodeType Property Definitions
\r
122 enrichNodeTypeProperties(nodeTypeName, nodeType)
\r
124 //NodeType Requirement
\r
125 enrichNodeTypeRequirements(nodeTypeName, nodeType)
\r
127 //NodeType Capability
\r
128 enrichNodeTypeCapabilityProperties(nodeTypeName, nodeType)
\r
130 //NodeType Interface
\r
131 enrichNodeTypeInterfaces(nodeTypeName, nodeType)
\r
134 open fun enrichNodeTypeProperties(nodeTypeName: String, nodeType: NodeType) {
\r
135 nodeType.properties?.let { enrichPropertyDefinitions(nodeType.properties!!) }
\r
138 open fun enrichNodeTypeRequirements(nodeTypeName: String, nodeType: NodeType) {
\r
140 nodeType.requirements?.forEach { _, requirementDefinition ->
\r
141 // Populate Requirement Node
\r
142 requirementDefinition.node?.let { requirementNodeTypeName ->
\r
143 // Get Requirement NodeType from Repo and Update Service Template
\r
144 val requirementNodeType = populateNodeType(requirementNodeTypeName)
\r
146 enrichNodeType(requirementNodeTypeName, requirementNodeType)
\r
151 open fun enrichNodeTypeCapabilityProperties(nodeTypeName: String, nodeType: NodeType) {
\r
152 nodeType.capabilities?.forEach { _, capabilityDefinition ->
\r
153 capabilityDefinition.properties?.let { properties ->
\r
154 enrichPropertyDefinitions(properties)
\r
159 open fun enrichNodeTypeInterfaces(nodeTypeName: String, nodeType: NodeType) {
\r
160 nodeType.interfaces?.forEach { interfaceName, interfaceObj ->
\r
161 // Populate Node type Interface Operation
\r
162 log.debug("Enriching NodeType({}) Interface({})", nodeTypeName, interfaceName)
\r
163 populateNodeTypeInterfaceOperation(nodeTypeName, interfaceName, interfaceObj)
\r
168 open fun populateNodeTypeInterfaceOperation(nodeTypeName: String, interfaceName: String, interfaceObj: InterfaceDefinition) {
\r
170 interfaceObj.operations?.forEach { operationName, operation ->
\r
171 enrichNodeTypeInterfaceOperationInputs(nodeTypeName, operationName, operation)
\r
172 enrichNodeTypeInterfaceOperationOputputs(nodeTypeName, operationName, operation)
\r
176 open fun enrichNodeTypeInterfaceOperationInputs(nodeTypeName: String, operationName: String, operation: OperationDefinition) {
\r
177 operation.inputs?.let { inputs ->
\r
178 enrichPropertyDefinitions(inputs)
\r
182 open fun enrichNodeTypeInterfaceOperationOputputs(nodeTypeName: String, operationName: String, operation: OperationDefinition) {
\r
183 operation.outputs?.let { inputs ->
\r
184 enrichPropertyDefinitions(inputs)
\r
188 open fun enrichPropertyDefinitions(properties: MutableMap<String, PropertyDefinition>) {
\r
190 properties.forEach { propertyName, propertyDefinition ->
\r
191 enrichPropertyDefinition(propertyName, propertyDefinition)
\r
195 @Throws(BluePrintException::class)
\r
196 fun enrichPropertyDefinition(propertyName: String, propertyDefinition: PropertyDefinition) {
\r
197 val propertyType = propertyDefinition.type
\r
198 if (BluePrintTypes.validPrimitiveTypes().contains(propertyType)) {
\r
200 } else if (BluePrintTypes.validCollectionTypes().contains(propertyType)) {
\r
201 val entrySchema = propertyDefinition.entrySchema
\r
202 ?: throw BluePrintException(format("Entry Schema is missing for collection property : {}", propertyName))
\r
204 if (!BluePrintTypes.validPrimitiveTypes().contains(entrySchema.type)) {
\r
205 populateDataTypes(entrySchema.type)
\r
208 populateDataTypes(propertyType)
\r
213 open fun enrichNodeTemplateArtifactDefinition(nodeTemplateName: String, nodeTemplate: NodeTemplate) {
\r
215 nodeTemplate.artifacts?.forEach { artifactDefinitionName, artifactDefinition ->
\r
216 val artifactTypeName = artifactDefinition.type
\r
217 ?: throw BluePrintException(format("Artifact type is missing for NodeTemplate({}) artifact({})", nodeTemplateName, artifactDefinitionName))
\r
219 // Populate Artifact Type
\r
220 populateArtifactType(artifactTypeName)
\r
224 open fun populateNodeType(nodeTypeName: String): NodeType {
\r
226 val nodeType = serviceTemplate.nodeTypes?.get(nodeTypeName)
\r
227 ?: bluePrintRepoService.getNodeType(nodeTypeName)
\r
228 ?: throw BluePrintException(format("Couldn't get NodeType({}) from repo.", nodeTypeName))
\r
229 serviceTemplate.nodeTypes?.put(nodeTypeName, nodeType)
\r
233 open fun populateArtifactType(artifactTypeName: String): ArtifactType {
\r
234 val artifactType = serviceTemplate.artifactTypes?.get(artifactTypeName)
\r
235 ?: bluePrintRepoService.getArtifactType(artifactTypeName)
\r
236 ?: throw BluePrintException(format("Couldn't get ArtifactType({}) from repo.", artifactTypeName))
\r
237 serviceTemplate.artifactTypes?.put(artifactTypeName, artifactType)
\r
238 return artifactType
\r
241 open fun populateDataTypes(dataTypeName: String): DataType {
\r
242 val dataType = serviceTemplate.dataTypes?.get(dataTypeName)
\r
243 ?: bluePrintRepoService.getDataType(dataTypeName)
\r
244 ?: throw BluePrintException(format("Couldn't get DataType({}) from repo.", dataTypeName))
\r
245 serviceTemplate.dataTypes?.put(dataTypeName, dataType)
\r