5014f7dc378619cfba7583eb9ffb2ff847f85242
[policy/clamp.git] /
1 /*-
2  * ============LICENSE_START=======================================================
3  *  Copyright (C) 2021,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
8  *
9  *      http://www.apache.org/licenses/LICENSE-2.0
10  *
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.
16  *
17  * SPDX-License-Identifier: Apache-2.0
18  * ============LICENSE_END=========================================================
19  */
20
21 package org.onap.policy.clamp.acm.runtime.supervision.comm;
22
23 import jakarta.ws.rs.core.Response.Status;
24 import java.util.List;
25 import java.util.Optional;
26 import org.onap.policy.clamp.acm.runtime.config.messaging.Publisher;
27 import org.onap.policy.clamp.acm.runtime.main.parameters.Topics;
28 import org.onap.policy.clamp.common.acm.exception.AutomationCompositionRuntimeException;
29 import org.onap.policy.clamp.models.acm.messages.kafka.participant.ParticipantAckMessage;
30 import org.onap.policy.common.endpoints.event.comm.TopicSink;
31 import org.onap.policy.common.endpoints.event.comm.client.TopicSinkClient;
32
33 public abstract class AbstractParticipantAckPublisher<E extends ParticipantAckMessage> implements Publisher {
34
35     private TopicSinkClient topicSinkClient;
36     private boolean active = false;
37
38     /**
39      * Method to send Participant message to participants on demand.
40      *
41      * @param participantMessage the Participant message
42      */
43     public void send(final E participantMessage) {
44         if (!active) {
45             throw new AutomationCompositionRuntimeException(Status.NOT_ACCEPTABLE, "Not Active!");
46         }
47         topicSinkClient.send(participantMessage);
48     }
49
50
51     @Override
52     public void active(TopicSink topicSink) {
53         this.topicSinkClient = new TopicSinkClient(topicSink);
54         active = true;
55     }
56
57     @Override
58     public void stop() {
59         active = false;
60     }
61
62     /**
63      * Is default topic.
64      * @return true if default
65      */
66     @Override
67     public boolean isDefaultTopic() {
68         return true;
69     }
70 }