import com.oransc.rappmanager.models.RappDeployer;
import com.oransc.rappmanager.models.cache.RappCacheService;
import com.oransc.rappmanager.models.exception.RappHandlerException;
+import com.oransc.rappmanager.models.exception.RappValidationException;
import com.oransc.rappmanager.models.rapp.Rapp;
import com.oransc.rappmanager.models.rapp.RappEvent;
import com.oransc.rappmanager.models.rapp.RappState;
private final List<RappDeployer> rappDeployers;
private final RappInstanceStateMachine rappInstanceStateMachine;
private final RappCacheService rappCacheService;
+ private final DeploymentArtifactsService deploymentArtifactsService;
private static final String STATE_TRANSITION_NOT_PERMITTED = "State transition from %s to %s is not permitted.";
public ResponseEntity<String> primeRapp(Rapp rapp) {
if (rapp.getState().equals(RappState.COMMISSIONED)) {
rapp.setState(RappState.PRIMING);
rapp.setReason(null);
- if (rappDeployers.parallelStream().allMatch(rappDeployer -> rappDeployer.primeRapp(rapp))) {
- rapp.setState(RappState.PRIMED);
- return ResponseEntity.ok().build();
+ try {
+ //Configuring the deployment artifact needs to be done before starting the priming with other components
+ //If there are additional conditions needs to be checked before priming, This needs handled as part of pre-priming stage.
+ if (deploymentArtifactsService.configureDeploymentArtifacts(rapp) && rappDeployers.parallelStream()
+ .allMatch(
+ rappDeployer -> rappDeployer.primeRapp(
+ rapp))) {
+ rapp.setState(RappState.PRIMED);
+ return ResponseEntity.ok().build();
+ }
+ } catch (RappValidationException e) {
+ rapp.setState(RappState.COMMISSIONED);
+ throw e;
}
rapp.setState(RappState.COMMISSIONED);
- return ResponseEntity.status(HttpStatus.BAD_GATEWAY).build();
+ throw new RappHandlerException(HttpStatus.BAD_GATEWAY, rapp.getReason());
}
throw new RappHandlerException(HttpStatus.BAD_REQUEST,
String.format(STATE_TRANSITION_NOT_PERMITTED, rapp.getState().name(), RappState.PRIMED.name()));
return ResponseEntity.ok().build();
}
rapp.setState(RappState.PRIMED);
- return ResponseEntity.status(HttpStatus.BAD_GATEWAY).build();
+ throw new RappHandlerException(HttpStatus.BAD_GATEWAY, rapp.getReason());
}
if (!rapp.getRappInstances().isEmpty()) {
throw new RappHandlerException(HttpStatus.BAD_REQUEST,
.allMatch(rappDeployer -> rappDeployer.deployRappInstance(rapp, rappInstance))) {
return ResponseEntity.accepted().build();
}
- return ResponseEntity.status(HttpStatus.BAD_GATEWAY).build();
+ throw new RappHandlerException(HttpStatus.BAD_GATEWAY, rappInstance.getReason());
}
throw new RappHandlerException(HttpStatus.BAD_REQUEST,
String.format("Unable to deploy rApp instance %s as it is not in UNDEPLOYED state",
.allMatch(rappDeployer -> rappDeployer.undeployRappInstance(rapp, rappInstance))) {
return ResponseEntity.accepted().build();
}
- return ResponseEntity.status(HttpStatus.BAD_GATEWAY).build();
+ throw new RappHandlerException(HttpStatus.BAD_GATEWAY, rappInstance.getReason());
}
throw new RappHandlerException(HttpStatus.BAD_REQUEST,
String.format("Unable to undeploy rApp instance %s as it is not in DEPLOYED state",