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.datajobs.subscription.ncmp;
23 import java.util.List;
24 import lombok.RequiredArgsConstructor;
25 import lombok.extern.slf4j.Slf4j;
26 import org.onap.cps.ncmp.impl.datajobs.subscription.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.datajobs.subscription.client_to_ncmp.DataJobSubscriptionOperationInEvent"})
47 public void consumeSubscriptionEvent(
48 final DataJobSubscriptionOperationInEvent dataJobSubscriptionOperationInEvent) {
50 final String eventType = dataJobSubscriptionOperationInEvent.getEventType();
51 final String dataNodeSelector = dataJobSubscriptionOperationInEvent.getEvent().getDataJob()
52 .getProductionJobDefinition().getTargetSelector().getDataNodeSelector();
53 final List<String> fdns = JexParser.toXpaths(dataNodeSelector);
54 final String dataJobId = dataJobSubscriptionOperationInEvent.getEvent().getDataJob().getId();
55 final String dataTypeId = dataJobSubscriptionOperationInEvent.getEvent().getDataType() != null
56 ? dataJobSubscriptionOperationInEvent.getEvent().getDataType().getDataTypeId() : "UNKNOWN";
58 log.info("Consumed subscription event with details: | jobId={} | eventType={} | fdns={} | dataType={}",
59 dataJobId, eventType, fdns, dataTypeId);