X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=rapp-manager-application%2Fsrc%2Fmain%2Fjava%2Fcom%2Foransc%2Frappmanager%2Fservice%2FRappService.java;h=8546082d2122755a8b44bbcc9ca91c1500ed238f;hb=7c96a8b483bb12318a04433ce36bccff314ddacb;hp=82054f5a72fe508cded4226207b482f043f38cd6;hpb=a071d6befe8d38a5e589dffbbf1dc3904ff3aa79;p=nonrtric%2Fplt%2Frappmanager.git diff --git a/rapp-manager-application/src/main/java/com/oransc/rappmanager/service/RappService.java b/rapp-manager-application/src/main/java/com/oransc/rappmanager/service/RappService.java index 82054f5..8546082 100755 --- a/rapp-manager-application/src/main/java/com/oransc/rappmanager/service/RappService.java +++ b/rapp-manager-application/src/main/java/com/oransc/rappmanager/service/RappService.java @@ -19,11 +19,13 @@ 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.rapp.RappState; import com.oransc.rappmanager.models.statemachine.RappInstanceStateMachine; import com.oransc.rappmanager.sme.service.SmeDeployer; import lombok.RequiredArgsConstructor; @@ -37,37 +39,62 @@ 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); - if (!acmDeployer.primeRapp(rapp)) { + 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(); } - return ResponseEntity.ok().build(); } else { return ResponseEntity.badRequest() - .body("State transition from " + RappState.PRIMED.name() + " to " + rapp.getState().name() - + " is not permitted."); + .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); - if (!acmDeployer.deprimeRapp(rapp)) { + 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(); } - return ResponseEntity.ok().build(); } else { if (!rapp.getRappInstances().isEmpty()) { return ResponseEntity.badRequest().body("Unable to deprime as there are active rapp instances,"); } else { return ResponseEntity.badRequest() - .body("State transition from " + RappState.COMMISSIONED.name() + " to " + rapp.getState() - .name() - + " is not permitted."); + .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."); } } } @@ -75,14 +102,15 @@ public class RappService { public ResponseEntity deployRappInstance(Rapp rapp, RappInstance rappInstance) { if (rappInstance.getState().equals(RappInstanceState.UNDEPLOYED)) { rappInstanceStateMachine.sendRappInstanceEvent(rappInstance, RappEvent.DEPLOYING); - if (acmDeployer.deployRappInstance(rapp, rappInstance) && smeDeployer.deployRappInstance(rapp, - rappInstance)) { + 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("State transition from " + rappInstance.getState().name() + " to " - + RappInstanceState.DEPLOYED.name() + " is not permitted."); + return ResponseEntity.badRequest() + .body(String.format(STATE_TRANSITION_NOT_PERMITTED, rappInstance.getState().name(), + RappInstanceState.DEPLOYED.name())); } } @@ -90,14 +118,14 @@ public class RappService { if (rappInstance.getState().equals(RappInstanceState.DEPLOYED)) { rappInstanceStateMachine.sendRappInstanceEvent(rappInstance, RappEvent.UNDEPLOYING); if (acmDeployer.undeployRappInstance(rapp, rappInstance) && smeDeployer.undeployRappInstance(rapp, - rappInstance)) { + rappInstance) && dmeDeployer.undeployRappInstance(rapp, rappInstance)) { return ResponseEntity.accepted().build(); } return ResponseEntity.status(HttpStatus.BAD_GATEWAY).build(); } else { - return ResponseEntity.badRequest().body("State transition from " + rappInstance.getState().name() + " to " - + RappInstanceState.UNDEPLOYED.name() - + " is not permitted."); + return ResponseEntity.badRequest() + .body(String.format(STATE_TRANSITION_NOT_PERMITTED, rappInstance.getState().name(), + RappInstanceState.UNDEPLOYED.name())); } }