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);