2 * ============LICENSE_START=======================================================
3 * Copyright (c) 2023 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.api.impl.events.avc;
23 import lombok.RequiredArgsConstructor;
24 import lombok.extern.slf4j.Slf4j;
25 import org.onap.cps.ncmp.api.impl.events.EventsPublisher;
26 import org.onap.cps.ncmp.event.model.AvcEvent;
27 import org.springframework.beans.factory.annotation.Value;
28 import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
29 import org.springframework.kafka.annotation.KafkaListener;
30 import org.springframework.stereotype.Component;
33 * Listener for AVC events.
37 @RequiredArgsConstructor
38 @ConditionalOnProperty(name = "notification.enabled", havingValue = "true", matchIfMissing = true)
39 public class AvcEventConsumer {
42 @Value("${app.ncmp.avc.cm-events-topic}")
43 private String cmEventsTopicName;
45 private final EventsPublisher<AvcEvent> eventsPublisher;
46 private final AvcEventMapper avcEventMapper;
50 * Consume the specified event.
52 * @param avcEvent the event to be consumed and produced.
55 topics = "${app.dmi.cm-events.topic}",
56 properties = {"spring.json.value.default.type=org.onap.cps.ncmp.event.model.AvcEvent"})
57 public void consumeAndForward(final AvcEvent avcEvent) {
58 log.debug("Consuming AVC event {} ...", avcEvent);
59 final AvcEvent outgoingAvcEvent = avcEventMapper.toOutgoingAvcEvent(avcEvent);
60 eventsPublisher.publishEvent(cmEventsTopicName, outgoingAvcEvent.getEventId(), outgoingAvcEvent);