ad0abee8990c2b52e892a18c43becf0d59ef4123
[ccsdk/features.git] /
1 /*
2  * ============LICENSE_START=======================================================
3  * ONAP : ccsdk features
4  * ================================================================================
5  * Copyright (C) 2020 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.setup.frankfurt;
23
24 import java.io.IOException;
25 import java.util.HashMap;
26 import java.util.Map;
27 import org.onap.ccsdk.features.sdnr.wt.dataprovider.setup.data.ComponentName;
28 import org.onap.ccsdk.features.sdnr.wt.dataprovider.setup.data.DatabaseInfo;
29 import org.onap.ccsdk.features.sdnr.wt.dataprovider.setup.data.Release;
30 import org.onap.ccsdk.features.sdnr.wt.dataprovider.setup.data.SearchHitConverter;
31 import org.slf4j.Logger;
32 import org.slf4j.LoggerFactory;
33 import org.onap.ccsdk.features.sdnr.wt.common.database.HtDatabaseClient;
34 import org.onap.ccsdk.features.sdnr.wt.common.database.requests.ClusterSettingsRequest;
35 import org.onap.ccsdk.features.sdnr.wt.common.database.responses.ClusterSettingsResponse;
36 import org.onap.ccsdk.features.sdnr.wt.dataprovider.setup.ReleaseInformation;
37
38 public class FrankfurtReleaseInformation extends ReleaseInformation {
39
40     private final Logger LOG = LoggerFactory.getLogger(FrankfurtReleaseInformation.class);
41     private final Map<Release, Map<ComponentName, SearchHitConverter>> converters = new HashMap<>();
42
43     public FrankfurtReleaseInformation() {
44         super(Release.FRANKFURT_R1, createDBMap());
45     }
46
47     private static Map<ComponentName, DatabaseInfo> createDBMap() {
48         Map<ComponentName, DatabaseInfo> map = new HashMap<>();
49         map.put(ComponentName.CONNECTIONLOG, new DatabaseInfo("connectionlog", "connectionlog",
50                 "{\"node-id\": {\"type\": \"keyword\"},\"timestamp\": {\"type\": \"date\"},\"status\": {\"type\": \"keyword\"}}"));
51         map.put(ComponentName.EVENTLOG, new DatabaseInfo("eventlog", "eventlog",
52                 "{\"node-id\": {\"type\": \"keyword\"},\"source-type\": {\"type\": \"keyword\"},\"timestamp\": {\"type\": \"date\"},\"new-value\": {\"type\": \"keyword\"},\"attribute-name\": {\"type\": \"keyword\"},\"counter\": {\"type\": \"long\"},\"object-id\": {\"type\": \"keyword\"}}"));
53         map.put(ComponentName.FAULTCURRENT, new DatabaseInfo("faultcurrent", "faultcurrent",
54                 "{\"node-id\": {\"type\": \"keyword\"},\"severity\": {\"type\": \"keyword\"},\"timestamp\": {\"type\": \"date\"},\"problem\": {\"type\": \"keyword\"},\"counter\": {\"type\": \"long\"},\"object-id\":{\"type\": \"keyword\"}}"));
55         map.put(ComponentName.FAULTLOG, new DatabaseInfo("faultlog", "faultlog",
56                 "{\"node-id\": {\"type\": \"keyword\"},\"severity\": {\"type\": \"keyword\"},\"timestamp\": {\"type\": \"date\"},\"problem\": {\"type\": \"keyword\"},\"counter\": {\"type\": \"long\"},\"object-id\":{\"type\": \"keyword\"},\"source-type\":{\"type\": \"keyword\"}}"));
57         map.put(ComponentName.INVENTORY, new DatabaseInfo("inventoryequipment", "inventoryequipment",
58                 "{\"date\": {\"type\": \"keyword\"},\"model-identifier\": {\"type\": \"keyword\"},\"manufacturer-identifier\": {\"type\": \"keyword\"},\"type-name\": {\"type\": \"keyword\"},\"description\": {\"type\": \"keyword\"},\"uuid\": {\"type\": \"keyword\"},\"version\": {\"type\": \"keyword\"},\"parent-uuid\": {\"type\": \"keyword\"},\"contained-holder\": {\"type\": \"keyword\"},\"node-id\": {\"type\": \"keyword\"},\"tree-level\": {\"type\": \"long\"},\"part-type-id\": {\"type\": \"keyword\"},\"serial\": {\"type\": \"keyword\"}}"));
59         map.put(ComponentName.HISTORICAL_PERFORMANCE_15M, new DatabaseInfo("historicalperformance15min",
60                 "historicalperformance15min",
61                 "{\"node-name\":{\"type\": \"keyword\"},\"timestamp\":{\"type\": \"date\"},\"suspect-interval-flag\":{\"type\":\"boolean\"},\"scanner-id\":{\"type\": \"keyword\"},\"uuid-interface\":{\"type\": \"keyword\"},\"layer-protocol-name\":{\"type\": \"keyword\"},\"granularity-period\":{\"type\": \"keyword\"},\"radio-signal-id\":{\"type\": \"keyword\"}}"));
62         map.put(ComponentName.HISTORICAL_PERFORMANCE_24H, new DatabaseInfo("historicalperformance24h",
63                 "historicalperformance24h",
64                 "{\"node-name\":{\"type\": \"keyword\"},\"timestamp\":{\"type\": \"date\"},\"suspect-interval-flag\":{\"type\":\"boolean\"},\"scanner-id\":{\"type\": \"keyword\"},\"uuid-interface\":{\"type\": \"keyword\"},\"layer-protocol-name\":{\"type\": \"keyword\"},\"granularity-period\":{\"type\": \"keyword\"},\"radio-signal-id\":{\"type\": \"keyword\"}}"));
65         map.put(ComponentName.REQUIRED_NETWORKELEMENT, new DatabaseInfo("networkelement-connection",
66                 "networkelement-connection",
67                 "{\"node-id\": {\"type\": \"keyword\"},\"host\": {\"type\": \"keyword\"},\"port\": {\"type\": \"long\"},\"username\": {\"type\": \"keyword\"},\"password\": {\"type\": \"keyword\"},\"core-model-capability\": {\"type\": \"keyword\"},\"device-type\": {\"type\": \"keyword\"},\"is-required\": {\"type\": \"boolean\"},\"status\": {\"type\": \"keyword\"}}"));
68         map.put(ComponentName.MEDIATOR_SERVER, new DatabaseInfo("mediator-server", "mediator-server",
69                 "{\"url\":{\"type\": \"keyword\"},\"name\":{\"type\": \"keyword\"}}"));
70         map.put(ComponentName.MAINTENANCE, new DatabaseInfo("maintenancemode", "maintenancemode",
71                 "{\"node-id\": {\"type\": \"keyword\"},\"start\": {\"type\": \"date\"},\"end\": {\"type\": \"date\"},\"description\": {\"type\": \"keyword\"},\"active\": {\"type\": \"boolean\"}},\"date_detection\":false}}"));
72         return map;
73     }
74
75     @Override
76     public SearchHitConverter getConverter(Release dst, ComponentName comp) {
77         SearchHitConverter c = this.converters.containsKey(dst) ? this.converters.get(dst).get(comp) : null;
78         if (c == null) {
79             c = super.getConverter(dst, comp);
80         }
81         return c;
82     }
83
84     @Override
85     protected boolean runPreInitCommands(HtDatabaseClient dbClient) {
86
87         ClusterSettingsResponse response = null;
88         try {
89             response = dbClient.setupClusterSettings(new ClusterSettingsRequest(false));
90         } catch (IOException e) {
91             LOG.warn("problem setting up cluster: {}", e);
92         }
93         return response == null ? false : response.isAcknowledged();
94     }
95
96     @Override
97     protected boolean runPostInitCommands(HtDatabaseClient dbClient) {
98         return true;
99     }
100
101 }