2 * ============LICENSE_START=======================================================
3 * Copyright (C) 2023-2024 Nordix Foundation
4 * ================================================================================
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
9 * http://www.apache.org/licenses/LICENSE-2.0
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
17 * SPDX-License-Identifier: Apache-2.0
18 * ============LICENSE_END=========================================================
21 package org.onap.cps.ncmp.impl.inventory.trustlevel;
23 import java.util.Collection;
25 import lombok.RequiredArgsConstructor;
26 import lombok.extern.slf4j.Slf4j;
27 import org.onap.cps.ncmp.api.inventory.models.TrustLevel;
28 import org.onap.cps.ncmp.impl.dmi.DmiRestClient;
29 import org.onap.cps.ncmp.impl.dmi.DmiServiceUrlTemplateBuilder;
30 import org.onap.cps.ncmp.impl.dmi.UrlTemplateParameters;
31 import org.onap.cps.ncmp.impl.inventory.CmHandleQueryService;
32 import org.springframework.beans.factory.annotation.Qualifier;
33 import org.springframework.scheduling.annotation.Scheduled;
34 import org.springframework.stereotype.Service;
37 @RequiredArgsConstructor
39 public class DmiPluginTrustLevelWatchDog {
41 private final DmiRestClient dmiRestClient;
42 private final CmHandleQueryService cmHandleQueryService;
43 private final TrustLevelManager trustLevelManager;
45 @Qualifier(TrustLevelCacheConfig.TRUST_LEVEL_PER_DMI_PLUGIN)
46 private final Map<String, TrustLevel> trustLevelPerDmiPlugin;
49 * This class monitors the trust level of all DMI plugin by checking the health status
50 * the resulting trust level wil be stored in the relevant cache.
51 * The @fixedDelayString is the time interval, in milliseconds, between consecutive checks.
53 @Scheduled(fixedDelayString = "${ncmp.timers.trust-level.dmi-availability-watchdog-ms:30000}")
54 public void checkDmiAvailability() {
55 trustLevelPerDmiPlugin.forEach((dmiServiceName, oldDmiTrustLevel) -> {
56 final TrustLevel newDmiTrustLevel;
57 final String dmiHealthStatus = getDmiHealthStatus(dmiServiceName);
58 log.debug("The health status for dmi-plugin: {} is {}", dmiServiceName, dmiHealthStatus);
60 if ("UP".equals(dmiHealthStatus)) {
61 newDmiTrustLevel = TrustLevel.COMPLETE;
63 newDmiTrustLevel = TrustLevel.NONE;
65 if (oldDmiTrustLevel.equals(newDmiTrustLevel)) {
66 log.debug("The Dmi Plugin: {} has already the same trust level: {}", dmiServiceName, newDmiTrustLevel);
68 final Collection<String> cmHandleIds =
69 cmHandleQueryService.getCmHandleIdsByDmiPluginIdentifier(dmiServiceName);
70 trustLevelManager.handleUpdateOfDmiTrustLevel(dmiServiceName, cmHandleIds, newDmiTrustLevel);
75 private String getDmiHealthStatus(final String dmiServiceBaseUrl) {
76 final UrlTemplateParameters urlTemplateParameters = DmiServiceUrlTemplateBuilder.newInstance()
77 .createUrlTemplateParametersForHealthCheck(dmiServiceBaseUrl);
78 return dmiRestClient.getDmiHealthStatus(urlTemplateParameters).block();