d7ae4cc51ffa9cbc0114a07a22303503fdb0eaf3
[ccsdk/features.git] /
1 /*
2  * ============LICENSE_START=======================================================
3  * ONAP : ccsdk features
4  * ================================================================================
5  * Copyright (C) 2019 highstreet technologies GmbH Intellectual Property.
6  * All rights reserved.
7  * ================================================================================
8  * Licensed under the Apache License, Version 2.0 (the "License");
9  * you may not use this file except in compliance with the License.
10  * You may obtain a copy of the License at
11  *
12  *     http://www.apache.org/licenses/LICENSE-2.0
13  *
14  * Unless required by applicable law or agreed to in writing, software
15  * distributed under the License is distributed on an "AS IS" BASIS,
16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17  * See the License for the specific language governing permissions and
18  * limitations under the License.
19  * ============LICENSE_END=========================================================
20  *
21  */
22 package org.onap.ccsdk.features.sdnr.wt.dataprovider.impl;
23
24 import javax.servlet.ServletException;
25 import org.onap.ccsdk.features.sdnr.wt.common.database.HtDatabaseClient;
26 import org.onap.ccsdk.features.sdnr.wt.common.database.HtDatabaseClientException;
27 import org.onap.ccsdk.features.sdnr.wt.dataprovider.http.DataTreeHttpServlet;
28 import org.onap.ccsdk.features.sdnr.wt.dataprovider.http.MsServlet;
29 import org.onap.ccsdk.features.sdnr.wt.dataprovider.http.UserdataHttpServlet;
30 import org.onap.ccsdk.features.sdnr.wt.dataprovider.http.about.AboutHttpServlet;
31 import org.onap.ccsdk.features.sdnr.wt.dataprovider.model.DataProvider;
32 import org.onap.ccsdk.features.sdnr.wt.dataprovider.model.HtDatabaseMaintenance;
33 import org.onap.ccsdk.features.sdnr.wt.dataprovider.model.HtUserdataManager;
34 import org.onap.ccsdk.features.sdnr.wt.dataprovider.model.IEntityDataProvider;
35 import org.onap.ccsdk.features.sdnr.wt.dataprovider.model.IEsConfig;
36 import org.onap.ccsdk.features.sdnr.wt.dataprovider.model.NetconfTimeStamp;
37 import org.onap.ccsdk.features.sdnr.wt.dataprovider.model.StatusChangedHandler.StatusKey;
38 import org.onap.ccsdk.features.sdnr.wt.dataprovider.model.types.NetconfTimeStampImpl;
39 import org.opendaylight.mdsal.binding.api.DataBroker;
40 import org.opendaylight.mdsal.binding.api.RpcProviderService;
41 import org.osgi.service.http.HttpService;
42 import org.osgi.service.http.NamespaceException;
43 import org.slf4j.Logger;
44 import org.slf4j.LoggerFactory;
45
46 public class DataProviderImpl implements IEntityDataProvider, AutoCloseable {
47
48     private static final Logger LOG = LoggerFactory.getLogger(DataProviderImpl.class);
49
50     private static final String APPLICATION_NAME = "data-provider";
51     private RpcProviderService rpcProviderService = null;
52     private MsServlet mediatorServerServlet;
53     private DataProviderServiceImpl rpcApiService;
54     private AboutHttpServlet aboutServlet;
55     private DataTreeHttpServlet treeServlet;
56     private UserdataHttpServlet userdataServlet;
57     private HtDatabaseClient dbClient;
58     private DataBroker dataBroker;
59
60     // Blueprint 1
61     public DataProviderImpl() {
62         super();
63         LOG.info("Creating provider for {}", APPLICATION_NAME);
64     }
65
66     public void setRpcProviderService(RpcProviderService rpcProviderService) {
67         this.rpcProviderService = rpcProviderService;
68     }
69
70     public void setMediatorServerServlet(MsServlet servlet) {
71         this.mediatorServerServlet = servlet;
72     }
73
74     public void setAboutServlet(AboutHttpServlet aboutServlet) {
75         this.aboutServlet = aboutServlet;
76     }
77
78     public void setTreeServlet(DataTreeHttpServlet treeServlet) {
79         this.treeServlet = treeServlet;
80     }
81     public void setUserdataServlet(UserdataHttpServlet userdataServlet) {
82         this.userdataServlet = userdataServlet;
83     }
84     public void setDataBroker(DataBroker dataBroker) {
85         this.dataBroker = dataBroker;
86     }
87     public void init() throws Exception {
88
89         LOG.info("Session Initiated start {}", APPLICATION_NAME);
90         try {
91             // Start RPC Service
92             this.rpcApiService = new DataProviderServiceImpl(rpcProviderService, this.mediatorServerServlet, this.dataBroker);
93             this.treeServlet.setInventoryTreeProvider(this.rpcApiService.getInventoryTreeProvider());
94             this.userdataServlet.setDatabaseClient(this.rpcApiService.getHtDatabaseUserManager());
95             LOG.info("Session Initiated end. Initialization done");
96         } catch (Exception e) {
97             if (e instanceof HtDatabaseClientException)
98                 LOG.error("IOException: Could not connect to the Database. Please check Database connectivity");
99             throw e;
100         }
101     }
102
103     public void onUnbindService(HttpService httpService) {
104         httpService.unregister(AboutHttpServlet.URI_PRE);
105         httpService.unregister(DataTreeHttpServlet.URI_PRE);
106         this.aboutServlet = null;
107         this.treeServlet = null;
108     }
109
110     public void onBindService(HttpService httpService)
111             throws ServletException, NamespaceException {
112         if (httpService == null) {
113             LOG.warn("Unable to inject HttpService into loader.");
114         } else {
115             httpService.registerServlet(AboutHttpServlet.URI_PRE, aboutServlet, null, null);
116             httpService.registerServlet(DataTreeHttpServlet.URI_PRE, treeServlet, null, null);
117             LOG.info("about servlet and tree servlet registered.");
118         }
119     }
120
121     @Override
122     public void close() throws Exception {
123         LOG.info("DeviceManagerImpl closing ...");
124
125         close(dbClient);
126         close(rpcApiService);
127         LOG.info("DeviceManagerImpl closing done");
128     }
129
130     /**
131      * Used to close all Services, that should support AutoCloseable Pattern
132      *
133      * @param toCloseList
134      * @throws Exception
135      */
136     private void close(AutoCloseable... toCloseList) throws Exception {
137         for (AutoCloseable element : toCloseList) {
138             if (element != null) {
139                 element.close();
140             }
141         }
142     }
143
144     @Override
145     public DataProvider getDataProvider() {
146         return rpcApiService.getDataProvider();
147     }
148
149     @Override
150     public HtDatabaseMaintenance getHtDatabaseMaintenance() {
151         return rpcApiService.getHtDatabaseMaintenance();
152     }
153
154     @Override
155     public IEsConfig getEsConfig() {
156         return rpcApiService.getEsConfig();
157     }
158
159     @Override
160     public NetconfTimeStamp getConverter() {
161         return NetconfTimeStampImpl.getConverter();
162     }
163
164     @Override
165     public void setStatus(StatusKey key, String value) {
166         if (this.aboutServlet != null) {
167             if (key == StatusKey.CLUSTER_SIZE) {
168                 this.aboutServlet.setClusterSize(value);
169             }
170         }
171     }
172
173     @Override
174     public HtUserdataManager getHtDatabaseUserManager() {
175         return this.rpcApiService.getHtDatabaseUserManager();
176     }
177
178 }