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