8104c104bc7e9f027d4e24032d02ec012fbc66c9
[ccsdk/apps.git] /
1 /*\r
2  *  Copyright © 2017-2018 AT&T Intellectual Property.\r
3  *\r
4  *  Licensed under the Apache License, Version 2.0 (the "License");\r
5  *  you may not use this file except in compliance with the License.\r
6  *  You may obtain a copy of the License at\r
7  *\r
8  *      http://www.apache.org/licenses/LICENSE-2.0\r
9  *\r
10  *  Unless required by applicable law or agreed to in writing, software\r
11  *  distributed under the License is distributed on an "AS IS" BASIS,\r
12  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
13  *  See the License for the specific language governing permissions and\r
14  *  limitations under the License.\r
15  */\r
16 \r
17 package org.onap.ccsdk.apps.blueprintsprocessor.core.factory\r
18 \r
19 import com.att.eelf.configuration.EELFManager\r
20 import org.onap.ccsdk.apps.controllerblueprints.resource.dict.ResourceAssignmentProcessor\r
21 import org.slf4j.Logger\r
22 import org.slf4j.LoggerFactory\r
23 import org.springframework.context.ApplicationContext\r
24 import org.springframework.context.ApplicationContextAware\r
25 import org.springframework.stereotype.Service\r
26 \r
27 @Service\r
28 class ResourceAssignmentProcessorFactory : ApplicationContextAware {\r
29 \r
30     private val log = EELFManager.getInstance().getLogger(ResourceAssignmentProcessorFactory::class.java)\r
31 \r
32     var resourceAssignmentProcessors: MutableMap<String, ResourceAssignmentProcessor> = hashMapOf()\r
33 \r
34     fun getInstance(instanceName: String): ResourceAssignmentProcessor? {\r
35         log.trace("looking for Resource Assignment Processor : {}", instanceName)\r
36         return resourceAssignmentProcessors.get(instanceName)\r
37     }\r
38 \r
39     fun injectInstance(instanceName: String, resourceAssignmentProcessor: ResourceAssignmentProcessor) {\r
40         this.resourceAssignmentProcessors[instanceName] = resourceAssignmentProcessor\r
41     }\r
42 \r
43     override fun setApplicationContext(context: ApplicationContext) {\r
44         resourceAssignmentProcessors = context.getBeansOfType(ResourceAssignmentProcessor::class.java)\r
45         log.info("Injected Resource Assignment Processor : {}", resourceAssignmentProcessors)\r
46     }\r
47 }