/*- * ============LICENSE_START====================================================================== * Copyright (C) 2023 Nordix Foundation. All rights reserved. * =============================================================================================== * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * ============LICENSE_END======================================================================== */ package com.oransc.rappmanager.service; import com.oransc.rappmanager.acm.service.AcmDeployer; import com.oransc.rappmanager.dme.service.DmeDeployer; import com.oransc.rappmanager.models.cache.RappCacheService; import com.oransc.rappmanager.models.rapp.Rapp; import com.oransc.rappmanager.models.rapp.RappEvent; import com.oransc.rappmanager.models.rapp.RappState; import com.oransc.rappmanager.models.rappinstance.RappInstance; import com.oransc.rappmanager.models.rappinstance.RappInstanceState; import com.oransc.rappmanager.models.statemachine.RappInstanceStateMachine; import com.oransc.rappmanager.sme.service.SmeDeployer; import lombok.RequiredArgsConstructor; import org.springframework.http.HttpStatus; import org.springframework.http.ResponseEntity; import org.springframework.stereotype.Service; @Service @RequiredArgsConstructor public class RappService { private final AcmDeployer acmDeployer; private final SmeDeployer smeDeployer; private final DmeDeployer dmeDeployer; private final RappInstanceStateMachine rappInstanceStateMachine; private final RappCacheService rappCacheService; private static final String STATE_TRANSITION_NOT_PERMITTED = "State transition from %s to %s is not permitted."; public ResponseEntity primeRapp(Rapp rapp) { if (rapp.getState().equals(RappState.COMMISSIONED)) { rapp.setState(RappState.PRIMING); rapp.setReason(null); if (acmDeployer.primeRapp(rapp) && dmeDeployer.primeRapp(rapp)) { rapp.setState(RappState.PRIMED); return ResponseEntity.ok().build(); } else { rapp.setState(RappState.COMMISSIONED); return ResponseEntity.status(HttpStatus.BAD_GATEWAY).build(); } } else { return ResponseEntity.badRequest() .body(String.format(STATE_TRANSITION_NOT_PERMITTED, RappState.PRIMED.name(), rapp.getState().name())); } } public ResponseEntity deprimeRapp(Rapp rapp) { if (rapp.getState().equals(RappState.PRIMED) && rapp.getRappInstances().isEmpty()) { rapp.setState(RappState.DEPRIMING); rapp.setReason(null); if (acmDeployer.deprimeRapp(rapp) && dmeDeployer.deprimeRapp(rapp)) { rapp.setState(RappState.COMMISSIONED); return ResponseEntity.ok().build(); } else { rapp.setState(RappState.PRIMED); return ResponseEntity.status(HttpStatus.BAD_GATEWAY).build(); } } else { if (!rapp.getRappInstances().isEmpty()) { return ResponseEntity.badRequest().body("Unable to deprime as there are active rapp instances,"); } else { return ResponseEntity.badRequest() .body(String.format(STATE_TRANSITION_NOT_PERMITTED, RappState.COMMISSIONED.name(), rapp.getState().name())); } } } public ResponseEntity deleteRapp(Rapp rApp) { if (rApp.getRappInstances().isEmpty() && rApp.getState().equals(RappState.COMMISSIONED)) { rappCacheService.deleteRapp(rApp); return ResponseEntity.ok().build(); } else { if (!rApp.getRappInstances().isEmpty()) { return ResponseEntity.badRequest() .body("Unable to delete '" + rApp.getName() + "' as there are active rApp instances."); } else { return ResponseEntity.badRequest().body("Unable to delete '" + rApp.getName() + "' as the rApp is not in COMMISSIONED state."); } } } public ResponseEntity deployRappInstance(Rapp rapp, RappInstance rappInstance) { if (rappInstance.getState().equals(RappInstanceState.UNDEPLOYED)) { rappInstance.setReason(null); rappInstanceStateMachine.sendRappInstanceEvent(rappInstance, RappEvent.DEPLOYING); if (acmDeployer.deployRappInstance(rapp, rappInstance) && smeDeployer.deployRappInstance(rapp, rappInstance) && dmeDeployer.deployRappInstance(rapp, rappInstance)) { return ResponseEntity.accepted().build(); } return ResponseEntity.status(HttpStatus.BAD_GATEWAY).build(); } else { return ResponseEntity.badRequest() .body(String.format(STATE_TRANSITION_NOT_PERMITTED, rappInstance.getState().name(), RappInstanceState.DEPLOYED.name())); } } public ResponseEntity undeployRappInstance(Rapp rapp, RappInstance rappInstance) { if (rappInstance.getState().equals(RappInstanceState.DEPLOYED)) { rappInstance.setReason(null); rappInstanceStateMachine.sendRappInstanceEvent(rappInstance, RappEvent.UNDEPLOYING); if (acmDeployer.undeployRappInstance(rapp, rappInstance) && smeDeployer.undeployRappInstance(rapp, rappInstance) && dmeDeployer.undeployRappInstance(rapp, rappInstance)) { return ResponseEntity.accepted().build(); } return ResponseEntity.status(HttpStatus.BAD_GATEWAY).build(); } else { return ResponseEntity.badRequest() .body(String.format(STATE_TRANSITION_NOT_PERMITTED, rappInstance.getState().name(), RappInstanceState.UNDEPLOYED.name())); } } public void updateRappInstanceState(Rapp rapp, RappInstance rappInstance) { acmDeployer.syncRappInstanceStatus(rapp.getCompositionId(), rappInstance); } }