boolean isRedeploy = false;
int actionCode = -1;
String targetName = null;
DeploymentTarget target = null;
DeploymentRequest req = phaseCtx.getDeploymentRequest();
DeploymentStatus status = phaseCtx.getDeploymentStatus();
Deployer deployer = null;
ExtensionModuleDeployer extDeployer = null;
try {
DeploymentCallback callback = req.getDeploymentCallback();
if (callback != null) {
int percent = 0;
DeploymentProgress progress = new DeploymentProgressImpl(
(byte)percent, "deployment started", null);
callback.deploymentProgress(progress);
}
// set the current deployment status in deployment request
// to J2EECPhase deployment status
req.setCurrentDeploymentStatus(status);
req.setDescriptor(deploymentCtx.getApplication(req.getName()));
if (DeploymentServiceUtils.isRegistered(req.getName(),
req.getType()) && req.isForced()) {
isRedeploy = true;
//Re-record instrospect/instrument/verifier data if
//any of the application is re-deployed
if (AppVerification.doInstrument()) {
AppVerification.getInstrumentLogger().handleChangeInDeployment();
}
}
if(req.isApplication())
isApp = true;
if (!req.isExtensionModule()) {
deployer = DeployerFactory.getDeployer(req);
deployer.doRequestPrepare();
}
if(isRedeploy) {
// clear the deploymentCtx cache now
deploymentCtx.removeApplication(req.getName());
req.setDescriptor(null);
target = (DeploymentTarget)req.getTarget();
// In the case of redeploy to domain,
// no stop event will be sent.
if(target != null && ! target.getName().equals("domain")) {
targetName = target.getName();
if(isApp) {
type = null;
actionCode = BaseDeployEvent.APPLICATION_UNDEPLOYED;
}
else {
type = DeploymentServiceUtils.getModuleTypeString(req.getType());
actionCode = BaseDeployEvent.MODULE_UNDEPLOYED;
}
DeploymentServiceUtils.multicastEvent(actionCode, req.getName(), type, req.getCascade(), req.isForced(), targetName);
wasUnRegistered = true;
}
}
if (req.isExtensionModule()) {
ModuleType moduleType = req.getType().getModuleType();
extDeployer =
PluggableDeploymentInfo.getExtensionModuleDeployer(
moduleType);
if (isRedeploy) {
extDeployer.redeployToDomain(req);
} else {
extDeployer.deployToDomain(req);
}
} else {
deployer.doRequestFinish();
// cache the updated application object in deployment context
deploymentCtx.addApplication(req.getName(), req.getDescriptor());
parseAndValidateSunResourcesXMLFiles(req);
deployer.cleanup();
}
// check if an abort operation has been issued
// throw exception if true
DeploymentServiceUtils.checkAbort(req.getName());
// do all the config update at the end for easy rollback
if(isRedeploy) {
DeploymentServiceUtils.updateConfig(req);
} else {
DeploymentServiceUtils.addToConfig(req);
}
// set context roots on config bean
ApplicationConfigHelper.resetAppContextRoots(
DeploymentServiceUtils.getConfigContext(), req.getName(),
true);
wasUnRegistered = false; // addToConfig re-registered it...
// everything went fine
status.setStageStatus(DeploymentStatus.SUCCESS);
// some useful information for clients...
sLogger.log(Level.INFO, "deployed with " + DeploymentProperties.MODULE_ID + " = " + req.getName());
populateStatusProperties(status, req);
if (callback != null) {
int percent = 100;
DeploymentProgress progress2 = new DeploymentProgressImpl(
(byte)percent, "deployment finished", null);
callback.deploymentProgress(progress2);
}
} catch(Throwable t) {
String msg =
localStrings.getString("enterprise.deployment.phasing.j2eec.error" );
if (t.getCause()!= null)
msg += t.getCause().toString();
// For any failure during the J2EEC phase (during fresh deploy or redeploy), cleanup the domain.xml
// so that the config is left in a clean state without any hanging j2ee-app/module elements without
// any app-refs;
// the target==null check ensures that this code is done for 8.1 only thereby preserving same
// behavior for 8.0 apps
try {
if (target == null) {
if (deployer != null) {
deployer.removePolicy();
}
DeploymentServiceUtils.removeFromConfig(req.getName(),
req.getType());
}
} catch (Exception eee){}
if(isRedeploy && wasUnRegistered && t instanceof IASDeploymentException && req.getReRegisterOnFailure()) {
// DBE rollback re-registered. We need to notify to get it reloaded now.
if(isApp)
actionCode = BaseDeployEvent.APPLICATION_DEPLOYED;
else
actionCode = BaseDeployEvent.MODULE_DEPLOYED;
try {
DeploymentServiceUtils.multicastEvent(actionCode, req.getName(), type, req.getCascade(), req.isForced(), targetName);
}
catch(Throwable t2) {
msg += t2;
}
}
// log
sLogger.log(Level.SEVERE, msg, t);
// we now update our status
status.setStageStatus(DeploymentStatus.FAILURE);
if (t instanceof java.io.Serializable) {
status.setStageException(t);
} else {
sLogger.severe(localStrings.getString("enterprise.deployment.phasing.exception_notserializable", t.getClass()));
sLogger.severe(localStrings.getString("enterprise.deployment.phasing.exception_notforwarded", t.getMessage()));
}
status.setStageStatusMessage(t.getMessage());
}
}