]> git.argeo.org Git - gpl/argeo-slc.git/blobdiff - runtime/org.argeo.slc.support.equinox/src/main/java/org/argeo/slc/equinox/ExecutionCommandProvider.java
Clean up directories
[gpl/argeo-slc.git] / runtime / org.argeo.slc.support.equinox / src / main / java / org / argeo / slc / equinox / ExecutionCommandProvider.java
index 462e2901601a82766fae0fbe47291b91d0e513fd..94ccf2649d54349d9c801edc827b29efccaed8ad 100644 (file)
+/*
+ * Copyright (C) 2007-2012 Argeo GmbH
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *         http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
 package org.argeo.slc.equinox;
 
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
+import java.util.ArrayList;
+import java.util.List;
+
 import org.argeo.slc.SlcException;
-import org.argeo.slc.execution.ExecutionFlowDescriptor;
-import org.argeo.slc.execution.ExecutionModule;
-import org.argeo.slc.osgi.BundlesManager;
+import org.argeo.slc.execution.SlcAgentCli;
 import org.eclipse.osgi.framework.console.CommandInterpreter;
 import org.eclipse.osgi.framework.console.CommandProvider;
-import org.osgi.framework.Bundle;
-import org.osgi.framework.BundleContext;
-import org.osgi.framework.ServiceReference;
-import org.springframework.context.ApplicationContext;
-import org.springframework.osgi.context.BundleContextAware;
-
-public class ExecutionCommandProvider implements CommandProvider,
-               BundleContextAware {
-       private final static Log log = LogFactory
-                       .getLog(ExecutionCommandProvider.class);
-
-       private BundleContext bundleContext;
-       private BundlesManager bundlesManager;
 
-       private String lastModuleName = null;
-       private String lastExecutionName = null;
+public class ExecutionCommandProvider implements CommandProvider {
+       private SlcAgentCli agentCli;
 
-       /** @deprecated Use slc command instead. */
-       public Object _slc_exec(CommandInterpreter ci) {
-               return _slc(ci);
-       }
+       private String lastProcessUuid;
 
        public Object _slc(CommandInterpreter ci) {
-               // TODO: check version
-               String firstArg = ci.nextArgument();
-               if (firstArg == null) {
-                       if (lastModuleName != null) {
-                               String cmd = "slc " + lastModuleName + " " + lastExecutionName;
-                               if (log.isDebugEnabled())
-                                       log.debug("Execute again last command: " + cmd);
-                               return ci.execute(cmd);
-                       } else {
-                               ci.execute("help");
-                               throw new SlcException("Command not properly formatted");
-                       }
-               }
-               String executionName = ci.nextArgument();
-
-               String moduleName = null;
-
-               // First check whether we have a bundleId
-               Long bundleId = null;
-               try {
-                       bundleId = Long.parseLong(firstArg);
-               } catch (NumberFormatException e) {
-                       // silent
-               }
-
-               // Look for bundle names containing pattern
-               Bundle bundle = null;
-               if (bundleId != null) {
-                       bundle = bundleContext.getBundle(bundleId);
-               } else {
-                       for (Bundle b : bundleContext.getBundles()) {
-                               if (b.getSymbolicName().contains(firstArg)) {
-                                       bundle = b;
-                                       break;
-                               }
-                       }
-               }
-
-               if (bundle != null) {
-                       moduleName = bundle.getSymbolicName();
-                       lastModuleName = moduleName;
-                       lastExecutionName = executionName;
-               } else {
-                       log
-                                       .warn("Could not find any execution module matching these requirements.");
-                       return null;
+               List<String> args = new ArrayList<String>();
+               String arg = null;
+               while ((arg = ci.nextArgument()) != null)
+                       args.add(arg);
+               if (args.size() == 0) {
+                       // TODO relaunch last process
+                       ci.execute("help");
+                       throw new SlcException("Command not properly formatted");
                }
 
-               // Find module
-               ExecutionModule module = null;
-               ServiceReference serviceRef = null;
-               try {
-                       bundlesManager.stopSynchronous(bundle);
-                       bundlesManager.updateSynchronous(bundle);
-                       // Refresh in case there are fragments
-                       bundlesManager.refreshSynchronous(bundle);
-                       bundlesManager.startSynchronous(bundle);
-
-                       String filter = "(Bundle-SymbolicName=" + moduleName + ")";
-                       // Wait for application context to be ready
-                       bundlesManager.getServiceRefSynchronous(ApplicationContext.class
-                                       .getName(), filter);
-
-                       if (log.isDebugEnabled())
-                               log.debug("Bundle " + bundle.getSymbolicName()
-                                               + " ready to be used at latest version.");
-
-                       ServiceReference[] sfs = bundlesManager.getServiceRefSynchronous(
-                                       ExecutionModule.class.getName(), filter);
-
-                       if (sfs.length > 1)
-                               log
-                                               .warn("More than one execution module service found in module "
-                                                               + moduleName);
-
-                       if (sfs.length > 0) {
-                               serviceRef = sfs[0];
-                               module = (ExecutionModule) bundleContext.getService(serviceRef);
-                       }
-
-                       if (module != null) {
-                               ExecutionFlowDescriptor descriptor = new ExecutionFlowDescriptor();
-                               descriptor.setName(executionName);
-                               module.execute(descriptor);
-                               log.info("Executed " + executionName + " from " + moduleName);
-                       }
-
-               } catch (Exception e) {
-                       throw new SlcException("Cannot find or update module.", e);
-               } finally {
-                       if (serviceRef != null)
-                               bundleContext.ungetService(serviceRef);
-               }
-
-               return "COMMAND COMPLETED";
+               lastProcessUuid = agentCli
+                               .process(args.toArray(new String[args.size()]));
+               return lastProcessUuid;
        }
 
        public String getHelp() {
                StringBuffer buf = new StringBuffer();
                buf.append("---SLC Execution Commands---\n");
-               buf
-                               .append("\tslc (<id>|<segment of bsn>) <execution bean>  - execute an execution flow (without arg, execute last)\n");
+               buf.append("\tslc <module> <flow> [[ --arg value | --booleanArg ]]"
+                               + "  - executes an execution flow\n");
                return buf.toString();
 
        }
 
-       public void setBundleContext(BundleContext bundleContext) {
-               this.bundleContext = bundleContext;
-       }
-
-       public void setBundlesManager(BundlesManager bundlesManager) {
-               this.bundlesManager = bundlesManager;
+       public void setAgentCli(SlcAgentCli agentCli) {
+               this.agentCli = agentCli;
        }
 
 }