X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;ds=sidebyside;f=rapp-manager-application%2Fsrc%2Fmain%2Fjava%2Fcom%2Foransc%2Frappmanager%2Fservice%2FRappService.java;h=925d5d33c0c8a899696a985ced8fdbd77c885be1;hb=refs%2Fchanges%2F19%2F11819%2F1;hp=1b9fb68b7a0d5edadddc130ed72d086a4eddf25f;hpb=6ab517a1fe9ea8bd69645a9bcb70839a436e8ea4;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 1b9fb68..925d5d3 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 @@ -20,6 +20,7 @@ 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; @@ -40,6 +41,7 @@ public class RappService { 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) { @@ -78,6 +80,21 @@ public class RappService { } } + 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)) { rappInstanceStateMachine.sendRappInstanceEvent(rappInstance, RappEvent.DEPLOYING);