ee358ff218e28b7163c8e7579a41c9da7ed53f17
[policy/clamp.git] /
1 /*-
2  * ============LICENSE_START=======================================================
3  * Copyright (C) 2021-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
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 io.micrometer.core.annotation.Timed;
24 import java.util.UUID;
25 import java.util.stream.Collectors;
26 import org.onap.policy.clamp.models.acm.concepts.AutomationComposition;
27 import org.onap.policy.clamp.models.acm.concepts.AutomationCompositionElement;
28 import org.onap.policy.clamp.models.acm.messages.kafka.participant.AutomationCompositionStateChange;
29 import org.onap.policy.clamp.models.acm.utils.AcmUtils;
30 import org.springframework.stereotype.Component;
31
32 /**
33  * This class is used to send AutomationCompositionStateChangePublisher messages to participants on Kafka.
34  */
35 @Component
36 public class AutomationCompositionStateChangePublisher
37         extends AbstractParticipantPublisher<AutomationCompositionStateChange> {
38
39     /**
40      * Send AutomationCompositionStateChange message to Participant.
41      *
42      * @param automationComposition the AutomationComposition
43      * @param startPhase the startPhase
44      * @param revisionIdComposition the last Update from Composition
45      */
46     @Timed(
47             value = "publisher.automation_composition_state_change",
48             description = "AUTOMATION_COMPOSITION_STATE_CHANGE messages published")
49     public void send(AutomationComposition automationComposition, int startPhase, boolean firstStartPhase,
50             UUID revisionIdComposition) {
51         var acsc = new AutomationCompositionStateChange();
52         acsc.setCompositionId(automationComposition.getCompositionId());
53         acsc.setAutomationCompositionId(automationComposition.getInstanceId());
54         acsc.setMessageId(UUID.randomUUID());
55         acsc.setDeployOrderedState(AcmUtils.stateDeployToOrder(automationComposition.getDeployState()));
56         acsc.setLockOrderedState(AcmUtils.stateLockToOrder(automationComposition.getLockState()));
57         acsc.setStartPhase(startPhase);
58         acsc.setFirstStartPhase(firstStartPhase);
59         acsc.setRevisionIdInstance(automationComposition.getRevisionId());
60         acsc.setRevisionIdComposition(revisionIdComposition);
61         acsc.setParticipantIdList(automationComposition.getElements().values().stream()
62                 .map(AutomationCompositionElement::getParticipantId).collect(Collectors.toSet()));
63
64         super.send(acsc);
65     }
66 }