1 /*******************************************************************************
 
   2  * ============LICENSE_START========================================================================
 
   3  * ONAP : ccsdk feature sdnr wt
 
   4  * =================================================================================================
 
   5  * Copyright (C) 2019 highstreet technologies GmbH Intellectual Property. All rights reserved.
 
   6  * =================================================================================================
 
   7  * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
 
   8  * in compliance with the License. You may obtain a copy of the License at
 
  10  * http://www.apache.org/licenses/LICENSE-2.0
 
  12  * Unless required by applicable law or agreed to in writing, software distributed under the License
 
  13  * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
 
  14  * or implied. See the License for the specific language governing permissions and limitations under
 
  16  * ============LICENSE_END==========================================================================
 
  17  ******************************************************************************/
 
  18 package org.onap.ccsdk.features.sdnr.wt.devicemanager.performancemanager.impl;
 
  20 import javax.annotation.Nullable;
 
  21 import org.onap.ccsdk.features.sdnr.wt.devicemanager.base.netconf.ONFCoreNetworkElementRepresentation;
 
  22 import org.onap.ccsdk.features.sdnr.wt.devicemanager.performancemanager.impl.database.service.MicrowaveHistoricalPerformanceWriterService;
 
  23 import org.slf4j.Logger;
 
  24 import org.slf4j.LoggerFactory;
 
  26 public class PerformanceManagerImpl implements AutoCloseable {
 
  28     private static final Logger LOG = LoggerFactory.getLogger(PerformanceManagerImpl.class);
 
  30     private @Nullable PerformanceManagerTask task;
 
  32     public PerformanceManagerImpl(long seconds, MicrowaveHistoricalPerformanceWriterService databaseService) {
 
  34         LOG.info("Construct begin {} with {} Seconds",PerformanceManagerImpl.class.getSimpleName(), seconds);
 
  36         if (MicrowaveHistoricalPerformanceWriterService.isAvailable(databaseService)) {
 
  38             LOG.info("Do start of PM task");
 
  39             task = new PerformanceManagerTask(seconds, databaseService);
 
  41             LOG.info("PM task scheduled");
 
  44             LOG.info("Database not available. Do not start PM task");
 
  47         LOG.info("Construct end {}",PerformanceManagerImpl.class.getSimpleName());
 
  52         LOG.info("Close {}", PerformanceManagerImpl.class.getSimpleName());
 
  58     public void registration(String mountPointNodeName, ONFCoreNetworkElementRepresentation ne) {
 
  59         LOG.debug("Register {}",mountPointNodeName);
 
  61                         task.registration(mountPointNodeName, ne);
 
  65     public void deRegistration(String mountPointNodeName) {
 
  66         LOG.debug("Deregister {}",mountPointNodeName);
 
  68                         task.deRegistration(mountPointNodeName);