2  * ============LICENSE_START=======================================================
 
   3  * Copyright (C) 2023-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.policy.clamp.acm.runtime.supervision.comm;
 
  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.DeployState;
 
  28 import org.onap.policy.clamp.models.acm.concepts.ParticipantDeploy;
 
  29 import org.onap.policy.clamp.models.acm.messages.kafka.participant.AutomationCompositionMigration;
 
  30 import org.onap.policy.clamp.models.acm.messages.rest.instantiation.DeployOrder;
 
  31 import org.onap.policy.clamp.models.acm.utils.AcmUtils;
 
  32 import org.springframework.stereotype.Component;
 
  35 public class AutomationCompositionMigrationPublisher
 
  36         extends AbstractParticipantPublisher<AutomationCompositionMigration> {
 
  39      * Send AutomationCompositionMigration message to Participant.
 
  41      * @param automationComposition the AutomationComposition
 
  42      * @param stage the stage to execute
 
  43      * @param revisionIdComposition the last Update from Composition
 
  44      * @param revisionIdCompositionTarget the last Update from Composition Target
 
  47             value = "publisher.automation_composition_migration",
 
  48             description = "AUTOMATION_COMPOSITION_MIGRATION messages published")
 
  49     public void send(AutomationComposition automationComposition, int stage, UUID revisionIdComposition,
 
  50                      UUID revisionIdCompositionTarget) {
 
  51         var acMigration = new AutomationCompositionMigration();
 
  52         acMigration.setRollback(DeployState.MIGRATION_REVERTING.equals(automationComposition.getDeployState()));
 
  53         acMigration.setPrecheck(Boolean.TRUE.equals(automationComposition.getPrecheck()));
 
  54         acMigration.setCompositionId(automationComposition.getCompositionId());
 
  55         acMigration.setAutomationCompositionId(automationComposition.getInstanceId());
 
  56         acMigration.setMessageId(UUID.randomUUID());
 
  57         acMigration.setCompositionTargetId(automationComposition.getCompositionTargetId());
 
  58         acMigration.setStage(stage);
 
  59         acMigration.setRevisionIdInstance(automationComposition.getRevisionId());
 
  60         acMigration.setRevisionIdComposition(revisionIdComposition);
 
  61         acMigration.setRevisionIdCompositionTarget(revisionIdCompositionTarget);
 
  62         var participantUpdatesList = AcmUtils.createParticipantDeployList(automationComposition, DeployOrder.MIGRATE);
 
  63         acMigration.setParticipantUpdatesList(participantUpdatesList);
 
  64         acMigration.setParticipantIdList(participantUpdatesList.stream()
 
  65                 .map(ParticipantDeploy::getParticipantId).collect(Collectors.toSet()));
 
  67         super.send(acMigration);