2 * ============LICENSE_START=======================================================
3 * Copyright (c) 2024-2025 OpenInfra Foundation Europe. All rights reserved.
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.cmnotificationsubscription.ncmp;
23 import java.util.List;
24 import lombok.RequiredArgsConstructor;
25 import lombok.extern.slf4j.Slf4j;
26 import org.onap.cps.ncmp.impl.cmnotificationsubscription_1_0_0.client_to_ncmp.DataJobSubscriptionOperationInEvent;
27 import org.onap.cps.ncmp.impl.utils.JexParser;
28 import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
29 import org.springframework.kafka.annotation.KafkaListener;
30 import org.springframework.stereotype.Component;
34 @RequiredArgsConstructor
35 @ConditionalOnProperty(name = "notification.enabled", havingValue = "true", matchIfMissing = true)
36 public class NcmpInEventConsumer {
39 * Consume the specified event.
41 * @param dataJobSubscriptionOperationInEvent the event to be consumed
43 @KafkaListener(topics = "${app.ncmp.avc.cm-subscription-ncmp-in}",
44 containerFactory = "legacyEventConcurrentKafkaListenerContainerFactory",
45 properties = {"spring.json.value.default.type="
46 + "org.onap.cps.ncmp.impl.cmnotificationsubscription_1_0_0"
47 + ".client_to_ncmp.DataJobSubscriptionOperationInEvent"})
48 public void consumeSubscriptionEvent(
49 final DataJobSubscriptionOperationInEvent dataJobSubscriptionOperationInEvent) {
51 final String eventType = dataJobSubscriptionOperationInEvent.getEventType();
52 final String dataNodeSelector = dataJobSubscriptionOperationInEvent.getEvent().getDataJob()
53 .getProductionJobDefinition().getTargetSelector().getDataNodeSelector();
54 final List<String> fdns = JexParser.extractFdnsFromLocationPaths(dataNodeSelector);
55 final String dataJobId = dataJobSubscriptionOperationInEvent.getEvent().getDataJob().getId();
56 final String dataTypeId = dataJobSubscriptionOperationInEvent.getEvent().getDataType() != null
57 ? dataJobSubscriptionOperationInEvent.getEvent().getDataType().getDataTypeId() : "UNKNOWN";
59 log.info("Consumed subscription event with details: | jobId={} | eventType={} | fdns={} | dataType={}",
60 dataJobId, eventType, fdns, dataTypeId);