X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;f=plugins%2Forg.argeo.slc.client.ui%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Fclient%2Fui%2FClientUiPlugin.java;fp=plugins%2Forg.argeo.slc.client.ui%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Fclient%2Fui%2FClientUiPlugin.java;h=e7d1c616c5a1407e3ab177bbd6258989c01108bc;hb=76420da459e9fe47612f77166f5e708648e40ef1;hp=9d794fb2652859ef21742f4516e7a13a4f9ac961;hpb=2599d7187ce8b15ef9b9c6e0bf3292bf25cf9a46;p=gpl%2Fargeo-slc.git diff --git a/plugins/org.argeo.slc.client.ui/src/main/java/org/argeo/slc/client/ui/ClientUiPlugin.java b/plugins/org.argeo.slc.client.ui/src/main/java/org/argeo/slc/client/ui/ClientUiPlugin.java index 9d794fb26..e7d1c616c 100644 --- a/plugins/org.argeo.slc.client.ui/src/main/java/org/argeo/slc/client/ui/ClientUiPlugin.java +++ b/plugins/org.argeo.slc.client.ui/src/main/java/org/argeo/slc/client/ui/ClientUiPlugin.java @@ -15,13 +15,26 @@ */ package org.argeo.slc.client.ui; +import javax.jcr.Node; +import javax.jcr.RepositoryException; + +import org.argeo.slc.BasicNameVersion; +import org.argeo.slc.NameVersion; +import org.argeo.slc.SlcException; +import org.argeo.slc.deploy.ModulesManager; +import org.argeo.slc.jcr.SlcNames; +import org.argeo.slc.jcr.SlcTypes; +import org.eclipse.core.runtime.IProgressMonitor; +import org.eclipse.core.runtime.IStatus; +import org.eclipse.core.runtime.Status; +import org.eclipse.core.runtime.jobs.Job; import org.eclipse.jface.resource.ImageDescriptor; import org.eclipse.swt.graphics.Image; import org.eclipse.ui.plugin.AbstractUIPlugin; import org.osgi.framework.BundleContext; /** The activator class controls the plug-in life cycle */ -public class ClientUiPlugin extends AbstractUIPlugin { +public class ClientUiPlugin extends AbstractUIPlugin implements SlcNames { public static final String ID = "org.argeo.slc.client.ui"; private static ClientUiPlugin plugin; @@ -47,4 +60,54 @@ public class ClientUiPlugin extends AbstractUIPlugin { public static ImageDescriptor getImageDescriptor(String path) { return imageDescriptorFromPlugin(ID, path); } + + /** Start execution module if it was stopped and vice-versa */ + public static void startStopExecutionModule( + final ModulesManager modulesManager, Node node) { + try { + if (!node.isNodeType(SlcTypes.SLC_EXECUTION_MODULE)) + throw new SlcException(node + " is not an execution module"); + + String name = node.getProperty(SLC_NAME).getString(); + String version = node.getProperty(SLC_VERSION).getString(); + final NameVersion nameVersion = new BasicNameVersion(name, version); + Boolean started = node.getProperty(SLC_STARTED).getBoolean(); + + Job job; + if (started) { + job = new Job("Stop " + nameVersion) { + protected IStatus run(IProgressMonitor monitor) { + monitor.beginTask("Stop " + nameVersion, 1); + modulesManager.stop(nameVersion); + monitor.worked(1); + return Status.OK_STATUS; + } + + protected void canceling() { + getThread().interrupt(); + super.canceling(); + } + }; + } else { + job = new Job("Start " + nameVersion) { + protected IStatus run(IProgressMonitor monitor) { + monitor.beginTask("Start " + nameVersion, 1); + modulesManager.start(nameVersion); + monitor.worked(1); + return Status.OK_STATUS; + } + + protected void canceling() { + getThread().interrupt(); + super.canceling(); + } + }; + } + job.setUser(true); + job.schedule(); + } catch (RepositoryException e) { + throw new SlcException("Cannot start " + node, e); + } + + } }