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==========================================================================
18 package org.onap.ccsdk.features.sdnr.wt.devicemanager.performancemanager.impl;
20 import org.onap.ccsdk.features.sdnr.wt.common.configuration.ConfigurationFileRepresentation;
21 import org.onap.ccsdk.features.sdnr.wt.dataprovider.model.DataProvider;
22 import org.onap.ccsdk.features.sdnr.wt.devicemanager.ne.service.NetworkElement;
23 import org.onap.ccsdk.features.sdnr.wt.devicemanager.performancemanager.impl.config.PmConfig;
24 import org.onap.ccsdk.features.sdnr.wt.devicemanager.service.NetconfNetworkElementService;
25 import org.onap.ccsdk.features.sdnr.wt.devicemanager.service.PerformanceManager;
26 import org.slf4j.Logger;
27 import org.slf4j.LoggerFactory;
29 public class PerformanceManagerImpl implements PerformanceManager, AutoCloseable {
31 private static final Logger LOG = LoggerFactory.getLogger(PerformanceManagerImpl.class);
33 private PerformanceManagerTask task;
35 public PerformanceManagerImpl(long seconds, NetconfNetworkElementService netconfNetworkElementService,
36 DataProvider microwaveHistoricalPerformanceWriterService, ConfigurationFileRepresentation config) {
38 LOG.info("Construct {}", PerformanceManagerImpl.class.getSimpleName());
41 PmConfig configurationPM = new PmConfig(config);
42 LOG.info("Performance manager configuration: {}", configurationPM);
44 if (!configurationPM.isPerformanceManagerEnabled()) {
45 LOG.info("Don't start performance manager");
48 LOG.info("{} Seconds", seconds);
49 LOG.info("Start of PM task");
50 task = new PerformanceManagerTask(seconds, microwaveHistoricalPerformanceWriterService,
51 netconfNetworkElementService);
53 LOG.info("PM task scheduled");
56 LOG.info("Construct end {}", PerformanceManagerImpl.class.getSimpleName());
61 LOG.info("Close {}", PerformanceManagerImpl.class.getSimpleName());
68 public void registration(String mountPointNodeName, NetworkElement ne) {
69 LOG.debug("Register {}", mountPointNodeName);
71 task.registration(mountPointNodeName, ne);
76 public void deRegistration(String mountPointNodeName) {
77 LOG.debug("Deregister {}", mountPointNodeName);
79 task.deRegistration(mountPointNodeName);