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.data;
24 import java.io.IOException;
26 import org.onap.ccsdk.features.sdnr.wt.common.database.ExtRestClient;
27 import org.onap.ccsdk.features.sdnr.wt.common.database.HtDatabaseClient;
28 import org.onap.ccsdk.features.sdnr.wt.common.database.SearchResult;
29 import org.onap.ccsdk.features.sdnr.wt.common.database.queries.QueryBuilder;
30 import org.onap.ccsdk.features.sdnr.wt.common.database.queries.QueryBuilders;
31 import org.onap.ccsdk.features.sdnr.wt.common.database.requests.SearchRequest;
32 import org.onap.ccsdk.features.sdnr.wt.common.database.responses.AggregationEntries;
33 import org.onap.ccsdk.features.sdnr.wt.common.database.responses.SearchResponse;
34 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev190801.Entity;
35 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev190801.EntityInput;
36 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev190801.SortOrder;
37 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev190801.entity.input.Filter;
38 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.data.provider.rev190801.entity.input.Sortorder;
39 import org.opendaylight.yangtools.yang.binding.DataObject;
40 import org.slf4j.Logger;
41 import org.slf4j.LoggerFactory;
43 public class DataObjectAcessorPm<T extends DataObject> extends DataObjectAcessor<T> {
45 private final Logger LOG = LoggerFactory.getLogger(DataObjectAcessorPm.class);
47 private static final String UUID_KEY = "uuid-interface";
48 private static final String NODE_KEY = "node-name";
49 private static final String KEY = "node-name";
53 PMDATA15M("historicalperformance15min", "historicalperformance15min"), PMDATA24H("historicalperformance24h",
54 "historicalperformance24h");
59 Intervall(String index, String type) {
64 public String getIndex() {
68 public String getType() {
73 private ExtRestClient dbClient;
74 private Intervall mode;
76 public DataObjectAcessorPm(HtDatabaseClient dbClient, Intervall mode, Entity entity, Class<T> clazz)
77 throws ClassNotFoundException {
78 super(dbClient, entity, clazz, false);
79 this.dbClient = dbClient;
84 * get aggregated list of ltps for filter NODE_KEY
90 QueryResult<String> getDataLtpList(EntityInput input) throws IOException {
91 long page = QueryByFilter.getPage(input);
92 long pageSize = QueryByFilter.getPageSize(input);
93 Filter nodeFilter = QueryByFilter.getFilter(input.getFilter(), NODE_KEY);
94 if (nodeFilter != null) {
95 SearchRequest request = new SearchRequest(mode.getIndex(), mode.getType());
97 QueryBuilders.matchQuery(NODE_KEY, nodeFilter.getFiltervalue()).aggregations(UUID_KEY).size(0));
99 SearchResponse response = this.dbClient.search(request);
100 AggregationEntries aggs = response.getAggregations(UUID_KEY);
101 String[] uuids = aggs.getKeysAsPagedStringList(pageSize, pageSize * (page - 1));
102 long totalSize = aggs.size();
103 return new QueryResult<String>(page, pageSize, new SearchResult<String>(uuids, totalSize));
104 } catch (IOException e) {
105 throw new IOException("problem reading ltps for req=" + request, e);
108 String msg = "no nodename in filter found ";
110 throw new IllegalArgumentException(msg);
114 // QueryResult<String> getDataDeviceList(EntityInput input) throws IOException {
116 // long page = QueryByFilter.getPage(input);
117 // long pageSize = QueryByFilter.getPageSize(input);
119 // SearchRequest request = new SearchRequest(mode.getIndex(), mode.getType());
120 // request.setQuery(QueryBuilders.matchAllQuery().aggregations(KEY).size(0));
122 // SearchResponse response = this.dbClient.search(request);
123 // AggregationEntries aggs = response.getAggregations(KEY);
124 // String[] uuids = aggs.getKeysAsPagedStringList(pageSize, pageSize * (page - 1));
125 // long totalSize = aggs.size();
126 // return new QueryResult<String>(page, pageSize, new SearchResult<String>(uuids, totalSize));
127 //// } catch (IOException e) {
128 //// throw new IOException("problem reading nodes for req="+request, e);
132 * get aggregated devices list
134 * @param input filter should be empty/no filter handled, only sortorder for KEY ('node-name')
136 * @throws IOException
138 QueryResult<String> getDataDeviceList(EntityInput input) throws IOException {
140 long page = QueryByFilter.getPage(input);
141 long pageSize = QueryByFilter.getPageSize(input);
143 Sortorder soNode = QueryByFilter.getSortOrder(input.getSortorder(), KEY);
144 SearchRequest request = new SearchRequest(mode.getIndex(), mode.getType());
145 QueryBuilder query = null;
146 if (soNode != null) {
147 query = QueryBuilders.matchAllQuery()
149 soNode.getSortorder() == SortOrder.Ascending
150 ? org.onap.ccsdk.features.sdnr.wt.common.database.queries.SortOrder.ASCENDING
151 : org.onap.ccsdk.features.sdnr.wt.common.database.queries.SortOrder.DESCENDING)
154 query = QueryBuilders.matchAllQuery().aggregations(KEY).size(0);
156 request.setQuery(query);
158 SearchResponse response = this.dbClient.search(request);
159 AggregationEntries aggs = response.getAggregations(KEY);
160 String[] uuids = aggs.getKeysAsPagedStringList(pageSize, pageSize * (page - 1));
161 long totalSize = aggs.size();
162 return new QueryResult<String>(page, pageSize, new SearchResult<String>(uuids, totalSize));
163 } catch (IOException e) {
164 throw new IOException("problem reading nodes for req=" + request, e);