2  *  Copyright © 2018 IBM.
 
   3  *  Modifications Copyright © 2017-2018 AT&T Intellectual Property.
 
   5  *  Licensed under the Apache License, Version 2.0 (the "License");
 
   6  *  you may not use this file except in compliance with the License.
 
   7  *  You may obtain a copy of the License at
 
   9  *      http://www.apache.org/licenses/LICENSE-2.0
 
  11  *  Unless required by applicable law or agreed to in writing, software
 
  12  *  distributed under the License is distributed on an "AS IS" BASIS,
 
  13  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
  14  *  See the License for the specific language governing permissions and
 
  15  *  limitations under the License.
 
  18 package org.onap.ccsdk.apps.blueprintsprocessor.functions.resource.resolutionprocessor
 
  20 import org.onap.ccsdk.apps.controllerblueprints.core.BluePrintProcessorException
 
  21 import org.onap.ccsdk.apps.controllerblueprints.core.interfaces.BlueprintFunctionNode
 
  22 import org.onap.ccsdk.apps.controllerblueprints.core.service.BluePrintRuntimeService
 
  23 import org.onap.ccsdk.apps.controllerblueprints.resource.dict.ResourceAssignment
 
  24 import org.onap.ccsdk.apps.controllerblueprints.resource.dict.ResourceDefinition
 
  25 import org.slf4j.LoggerFactory
 
  27 abstract class ResourceAssignmentProcessor : BlueprintFunctionNode<ResourceAssignment, ResourceAssignment> {
 
  29     private val log = LoggerFactory.getLogger(ResourceAssignmentProcessor::class.java)
 
  31     var bluePrintRuntimeService: BluePrintRuntimeService<*>? = null
 
  33     var resourceDictionaries: Map<String, ResourceDefinition> = hashMapOf()
 
  36     open fun resourceDefinition(name: String): ResourceDefinition {
 
  37         return resourceDictionaries[name]
 
  38                 ?: throw BluePrintProcessorException("couldn't get resource definition($name)")
 
  41     override fun prepareRequest(resourceAssignment: ResourceAssignment): ResourceAssignment {
 
  42         log.info("prepareRequest for ${resourceAssignment.name}, dictionary(${resourceAssignment.dictionaryName})," +
 
  43                 "source(${resourceAssignment.dictionarySource})")
 
  44         return resourceAssignment
 
  47     override fun prepareResponse(): ResourceAssignment {
 
  48         log.info("Preparing Response...")
 
  49         return ResourceAssignment()
 
  52     override fun apply(executionServiceInput: ResourceAssignment): ResourceAssignment {
 
  53         prepareRequest(executionServiceInput)
 
  54         process(executionServiceInput)
 
  55         return prepareResponse()