diff options
Diffstat (limited to 'core/bundles/org.eclipse.jst.ws.consumption/src/org/eclipse/jst/ws/internal/consumption/command/common/StartProjectCommand.java')
-rw-r--r-- | core/bundles/org.eclipse.jst.ws.consumption/src/org/eclipse/jst/ws/internal/consumption/command/common/StartProjectCommand.java | 156 |
1 files changed, 156 insertions, 0 deletions
diff --git a/core/bundles/org.eclipse.jst.ws.consumption/src/org/eclipse/jst/ws/internal/consumption/command/common/StartProjectCommand.java b/core/bundles/org.eclipse.jst.ws.consumption/src/org/eclipse/jst/ws/internal/consumption/command/common/StartProjectCommand.java new file mode 100644 index 000000000..774a0f22b --- /dev/null +++ b/core/bundles/org.eclipse.jst.ws.consumption/src/org/eclipse/jst/ws/internal/consumption/command/common/StartProjectCommand.java @@ -0,0 +1,156 @@ +/******************************************************************************* + * Copyright (c) 2000, 2005 IBM Corporation and others. + * All rights reserved. This program and the accompanying materials + * are made available under the terms of the Eclipse Public License v1.0 + * which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/epl-v10.html + * + * Contributors: + * IBM Corporation - initial API and implementation + *******************************************************************************/ + +package org.eclipse.jst.ws.internal.consumption.command.common; + +import org.eclipse.core.resources.IProject; +import org.eclipse.core.runtime.CoreException; +import org.eclipse.core.runtime.IAdaptable; +import org.eclipse.core.runtime.IProgressMonitor; +import org.eclipse.core.runtime.IStatus; +import org.eclipse.core.runtime.Status; +import org.eclipse.jst.ws.internal.common.ServerUtils; +import org.eclipse.jst.ws.internal.consumption.ConsumptionMessages; +import org.eclipse.jst.ws.internal.consumption.common.WebServiceStartServerRegistry; +import org.eclipse.wst.command.internal.env.core.common.ProgressUtils; +import org.eclipse.wst.command.internal.env.core.common.StatusUtils; +import org.eclipse.wst.common.environment.IEnvironment; +import org.eclipse.wst.common.frameworks.datamodel.AbstractDataModelOperation; +import org.eclipse.wst.server.core.IServer; + +public class StartProjectCommand extends AbstractDataModelOperation +{ + +private Boolean creationScenario_ = Boolean.TRUE; + +private boolean isWebProjectStartupRequested_; +private IProject serviceProject_; +private IProject sampleProject_; +private String serviceServerTypeID_; +private String sampleServerTypeID_; +private IServer serviceExistingServer_; +private IServer sampleExistingServer_; + + +/** + * Default CTOR; + */ +public StartProjectCommand( ) { + +} + +/** + * Default CTOR; + */ +public StartProjectCommand(boolean creationScenario ) { + creationScenario_ = new Boolean(creationScenario); +} + +/** + * Execute the command + */ +public IStatus execute( IProgressMonitor monitor, IAdaptable adaptable ) +{ + IEnvironment env = getEnvironment(); + + IStatus status = Status.OK_STATUS; + ProgressUtils.report( monitor, ConsumptionMessages.PROGRESS_INFO_START_WEB_PROJECT); + + + IProject project = ((creationScenario_.booleanValue()) ? serviceProject_ : sampleProject_); + String serverTypeID = ((creationScenario_.booleanValue()) ? serviceServerTypeID_ : sampleServerTypeID_); + IServer server = ((creationScenario_.booleanValue()) ? serviceExistingServer_ : sampleExistingServer_); + if (serverTypeID == null && server!=null) { + serverTypeID = server.getServerType().getId(); + } + if (project == null) + { + status = StatusUtils.errorStatus( ConsumptionMessages.MSG_ERROR_PROJECT_NOT_FOUND ); + env.getStatusHandler().reportError(status); + return status; + } + IServer instance = ServerUtils.getServerForModule(ServerUtils.getModule(project), serverTypeID, server, true, monitor ); + if (instance == null) + { + status = StatusUtils.errorStatus( ConsumptionMessages.MSG_ERROR_INSTANCE_NOT_FOUND ); + env.getStatusHandler().reportError(status); + return status; + } + + try + { + AbstractStartServer startServerCommand = null; + WebServiceStartServerRegistry reg = WebServiceStartServerRegistry.getInstance(); + startServerCommand = (AbstractStartServer)reg.getServerStartByTypeId(instance.getServerType().getId()); + startServerCommand.StartServer(project, instance, monitor, isWebProjectStartupRequested_); + return status; + } + catch (CoreException ce ) + { + IStatus embeddedStatus = ce.getStatus(); + status = embeddedStatus; + env.getStatusHandler().reportError(status); + return status; + } + catch (Exception e) + { + status = StatusUtils.errorStatus( ConsumptionMessages.MSG_ERROR_SERVER, e); + env.getStatusHandler().reportError(status); + return status; + } + +} + +public void setCreationScenario(Boolean creationScenario) +{ + creationScenario_ = creationScenario; +} + +public void setServiceProject(IProject serviceProject) +{ + serviceProject_ = serviceProject; +} + +public void setSampleProject(IProject sampleProject) +{ + sampleProject_ = sampleProject; +} + +public void setServiceServerTypeID(String serviceServerTypeID) +{ + serviceServerTypeID_ = serviceServerTypeID; +} + +public void setSampleServerTypeID(String sampleServerTypeID) +{ + sampleServerTypeID_ = sampleServerTypeID; +} + +public void setServiceExistingServer(IServer serviceExistingServer) +{ + serviceExistingServer_ = serviceExistingServer; + if (serviceExistingServer_ != null) + setServiceServerTypeID(serviceExistingServer_.getServerType().getId()); +} + +public void setSampleExistingServer(IServer sampleExistingServer) +{ + sampleExistingServer_ = sampleExistingServer; + if (sampleExistingServer_ != null) + setSampleServerTypeID(sampleExistingServer_.getServerType().getId()); +} + +public void setIsWebProjectStartupRequested(boolean webProjectStartupRequested) +{ + isWebProjectStartupRequested_ = webProjectStartupRequested; +} + +} |