+/*
+ * 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;
}
}