2 * ============LICENSE_START=======================================================
3 * ONAP : ccsdk features
4 * ================================================================================
5 * Copyright (C) 2019 highstreet technologies GmbH Intellectual Property.
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
12 * http://www.apache.org/licenses/LICENSE-2.0
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=========================================================
22 package org.onap.ccsdk.features.sdnr.wt.dataprovider.database.elasticsearch.data.acessor;
24 import java.io.IOException;
25 import org.onap.ccsdk.features.sdnr.wt.common.database.ExtRestClient;
26 import org.onap.ccsdk.features.sdnr.wt.common.database.HtDatabaseClient;
27 import org.onap.ccsdk.features.sdnr.wt.common.database.SearchResult;
28 import org.onap.ccsdk.features.sdnr.wt.common.database.requests.SearchRequest;
29 import org.onap.ccsdk.features.sdnr.wt.common.database.responses.AggregationEntries;
30 import org.onap.ccsdk.features.sdnr.wt.common.database.responses.SearchResponse;
31 import org.onap.ccsdk.features.sdnr.wt.dataprovider.database.elasticsearch.data.rpctypehelper.QueryByFilter;
32 import org.onap.ccsdk.features.sdnr.wt.dataprovider.database.elasticsearch.data.rpctypehelper.QueryResult;
33 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.Entity;
34 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev201110.EntityInput;
35 import org.opendaylight.yangtools.yang.binding.DataObject;
36 import org.slf4j.Logger;
37 import org.slf4j.LoggerFactory;
39 public class DataObjectAcessorPm<T extends DataObject> extends DataObjectAcessor<T> {
41 private final Logger LOG = LoggerFactory.getLogger(DataObjectAcessorPm.class);
43 private static final String UUID_KEY = "uuid-interface";
44 private static final String NODE_KEY = "node-name";
45 private static final String KEY = "node-name";
48 public enum Intervall {
49 PMDATA15M("historicalperformance15min", "historicalperformance15min"), PMDATA24H("historicalperformance24h",
50 "historicalperformance24h");
55 Intervall(String index, String type) {
60 public String getIndex() {
64 public String getType() {
69 private ExtRestClient dbClient;
70 private Intervall mode;
72 public DataObjectAcessorPm(HtDatabaseClient dbClient, Intervall mode, Entity entity, Class<T> clazz,
73 boolean doFullsizeRequest) throws ClassNotFoundException {
74 super(dbClient, entity, clazz, doFullsizeRequest);
75 LOG.info("DataObjectAcessorPm");
76 this.dbClient = dbClient;
81 * get aggregated list of ltps for filter NODE_KEY
87 public QueryResult<String> getDataLtpList(EntityInput input) throws IOException {
89 QueryByFilter queryByFilter = new QueryByFilter(input);
90 SearchRequest request = queryByFilter.getSearchRequestByFilter(NODE_KEY, UUID_KEY, mode.getIndex(),
91 mode.getType(), this.doFullsizeRequest);
93 SearchResponse response = this.dbClient.search(request);
94 AggregationEntries aggs = response.getAggregations(UUID_KEY);
96 aggs.getKeysAsPagedStringList(queryByFilter.getPageSize(), queryByFilter.getPageStartIndex());
97 long totalSize = aggs.size();
98 return new QueryResult<String>(queryByFilter.getPage(), queryByFilter.getPageSize(),
99 new SearchResult<String>(uuids, totalSize));
100 } catch (IOException e) {
101 throw new IOException("problem reading ltps for req=" + request, e);
106 * get aggregated devices list
108 * @param input filter should be empty/no filter handled, only sortorder for KEY ('node-name')
110 * @throws IOException
112 public QueryResult<String> getDataDeviceList(EntityInput input) throws IOException {
114 QueryByFilter queryByFilter = new QueryByFilter(input);
115 SearchRequest request =
116 queryByFilter.getSearchRequestBySortOrder(NODE_KEY, UUID_KEY, mode.getIndex(), mode.getType(), this.doFullsizeRequest);
118 SearchResponse response = this.dbClient.search(request);
119 AggregationEntries aggs = response.getAggregations(KEY);
121 aggs.getKeysAsPagedStringList(queryByFilter.getPageSize(), queryByFilter.getPageStartIndex());
122 long totalSize = aggs.size();
123 return new QueryResult<String>(queryByFilter.getPage(), queryByFilter.getPageSize(),
124 new SearchResult<String>(uuids, totalSize));
125 } catch (IOException e) {
126 throw new IOException("problem reading nodes for req=" + request, e);