c98ec3e55eb7c978f998a05f5bd4f9902e0ee571
[appc.git] / appc-config / appc-config-params / provider / src / main / java / org / onap / sdnc / config / params / ParamsHandlerActivator.java
1 /*-
2  * ============LICENSE_START=======================================================
3  * ONAP : APPC
4  * ================================================================================
5  * Copyright (C) 2017-2018 AT&T Intellectual Property. All rights reserved.
6  * ================================================================================
7  * Copyright (C) 2017 Amdocs
8  * ================================================================================
9  * Modifications Copyright (c) 2019 IBM
10  * ================================================================================
11  * Licensed under the Apache License, Version 2.0 (the "License");
12  * you may not use this file except in compliance with the License.
13  * You may obtain a copy of the License at
14  * 
15  *      http://www.apache.org/licenses/LICENSE-2.0
16  * 
17  * Unless required by applicable law or agreed to in writing, software
18  * distributed under the License is distributed on an "AS IS" BASIS,
19  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
20  * See the License for the specific language governing permissions and
21  * limitations under the License.
22  * 
23  * ============LICENSE_END=========================================================
24  */
25
26 package org.onap.sdnc.config.params;
27
28 import java.util.LinkedList;
29 import java.util.List;
30
31 import org.onap.sdnc.config.params.parser.PropertyDefinitionNode;
32 import org.osgi.framework.BundleActivator;
33 import org.osgi.framework.BundleContext;
34 import org.osgi.framework.ServiceRegistration;
35
36 import com.att.eelf.configuration.EELFLogger;
37 import com.att.eelf.configuration.EELFManager;
38
39 public class ParamsHandlerActivator implements BundleActivator {
40     
41     private static final String STR_PROPERTY_DEFINITION_FAILED = "Failed while getting PropertyDefinitionNode";
42
43     private List<ServiceRegistration> registrations = new LinkedList<ServiceRegistration>();
44
45
46     private static final EELFLogger log =
47             EELFManager.getInstance().getLogger(ParamsHandlerActivator.class);
48
49     @Override
50     public void start(BundleContext ctx) throws Exception {
51
52         try {
53             PropertyDefinitionNode propertyDefinitionNode = new PropertyDefinitionNode();
54             log.info("Registering service " + propertyDefinitionNode.getClass().getName());
55             registrations.add(ctx.registerService(propertyDefinitionNode.getClass().getName(),
56                     propertyDefinitionNode, null));
57             log.info("Registering service sccessful for  "
58                     + propertyDefinitionNode.getClass().getName());
59         } catch (Exception e) {
60             log.error(STR_PROPERTY_DEFINITION_FAILED, e);
61             
62         }
63
64     }
65
66     @Override
67     public void stop(BundleContext arg0) throws Exception {
68         for (ServiceRegistration registration : registrations) {
69             registration.unregister();
70             registration = null;
71         }
72
73     }
74
75 }