CAMEL-8041: Camel commands should be reusable.
Project: http://git-wip-us.apache.org/repos/asf/camel/repo Commit: http://git-wip-us.apache.org/repos/asf/camel/commit/cfb04fde Tree: http://git-wip-us.apache.org/repos/asf/camel/tree/cfb04fde Diff: http://git-wip-us.apache.org/repos/asf/camel/diff/cfb04fde Branch: refs/heads/master Commit: cfb04fdeab012959288e1d02f8536aa2c213cd95 Parents: f5b7656 Author: Claus Ibsen <davscl...@apache.org> Authored: Thu Nov 13 10:04:14 2014 +0100 Committer: Claus Ibsen <davscl...@apache.org> Committed: Thu Nov 13 10:04:14 2014 +0100 ---------------------------------------------------------------------- .../camel/commands/ContextResumeCommand.java | 34 ++++ .../camel/commands/ContextStartCommand.java | 34 ++++ .../camel/commands/ContextStopCommand.java | 34 ++++ .../camel/commands/ContextSuspendCommand.java | 34 ++++ .../karaf/commands/AbstractContextCommand.java | 1 + .../camel/karaf/commands/ComponentList.java | 154 +------------------ .../camel/karaf/commands/ContextResume.java | 14 +- .../camel/karaf/commands/ContextStart.java | 13 +- .../camel/karaf/commands/ContextStop.java | 13 +- .../camel/karaf/commands/ContextSuspend.java | 13 +- 10 files changed, 176 insertions(+), 168 deletions(-) ---------------------------------------------------------------------- http://git-wip-us.apache.org/repos/asf/camel/blob/cfb04fde/platforms/commands/commands-core/src/main/java/org/apache/camel/commands/ContextResumeCommand.java ---------------------------------------------------------------------- diff --git a/platforms/commands/commands-core/src/main/java/org/apache/camel/commands/ContextResumeCommand.java b/platforms/commands/commands-core/src/main/java/org/apache/camel/commands/ContextResumeCommand.java new file mode 100644 index 0000000..8273b4a --- /dev/null +++ b/platforms/commands/commands-core/src/main/java/org/apache/camel/commands/ContextResumeCommand.java @@ -0,0 +1,34 @@ +/** + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You 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.apache.camel.commands; + +import java.io.PrintStream; + +import org.apache.camel.CamelContext; + +public class ContextResumeCommand extends AbstractContextCommand { + + public ContextResumeCommand(String context) { + super(context); + } + + @Override + protected Object performContextCommand(CamelController camelController, CamelContext camelContext, PrintStream out, PrintStream err) throws Exception { + camelContext.resume(); + return null; + } +} http://git-wip-us.apache.org/repos/asf/camel/blob/cfb04fde/platforms/commands/commands-core/src/main/java/org/apache/camel/commands/ContextStartCommand.java ---------------------------------------------------------------------- diff --git a/platforms/commands/commands-core/src/main/java/org/apache/camel/commands/ContextStartCommand.java b/platforms/commands/commands-core/src/main/java/org/apache/camel/commands/ContextStartCommand.java new file mode 100644 index 0000000..d7e0f34 --- /dev/null +++ b/platforms/commands/commands-core/src/main/java/org/apache/camel/commands/ContextStartCommand.java @@ -0,0 +1,34 @@ +/** + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You 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.apache.camel.commands; + +import java.io.PrintStream; + +import org.apache.camel.CamelContext; + +public class ContextStartCommand extends AbstractContextCommand { + + public ContextStartCommand(String context) { + super(context); + } + + @Override + protected Object performContextCommand(CamelController camelController, CamelContext camelContext, PrintStream out, PrintStream err) throws Exception { + camelContext.start(); + return null; + } +} http://git-wip-us.apache.org/repos/asf/camel/blob/cfb04fde/platforms/commands/commands-core/src/main/java/org/apache/camel/commands/ContextStopCommand.java ---------------------------------------------------------------------- diff --git a/platforms/commands/commands-core/src/main/java/org/apache/camel/commands/ContextStopCommand.java b/platforms/commands/commands-core/src/main/java/org/apache/camel/commands/ContextStopCommand.java new file mode 100644 index 0000000..615d7a8 --- /dev/null +++ b/platforms/commands/commands-core/src/main/java/org/apache/camel/commands/ContextStopCommand.java @@ -0,0 +1,34 @@ +/** + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You 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.apache.camel.commands; + +import java.io.PrintStream; + +import org.apache.camel.CamelContext; + +public class ContextStopCommand extends AbstractContextCommand { + + public ContextStopCommand(String context) { + super(context); + } + + @Override + protected Object performContextCommand(CamelController camelController, CamelContext camelContext, PrintStream out, PrintStream err) throws Exception { + camelContext.stop(); + return null; + } +} http://git-wip-us.apache.org/repos/asf/camel/blob/cfb04fde/platforms/commands/commands-core/src/main/java/org/apache/camel/commands/ContextSuspendCommand.java ---------------------------------------------------------------------- diff --git a/platforms/commands/commands-core/src/main/java/org/apache/camel/commands/ContextSuspendCommand.java b/platforms/commands/commands-core/src/main/java/org/apache/camel/commands/ContextSuspendCommand.java new file mode 100644 index 0000000..15900c4 --- /dev/null +++ b/platforms/commands/commands-core/src/main/java/org/apache/camel/commands/ContextSuspendCommand.java @@ -0,0 +1,34 @@ +/** + * Licensed to the Apache Software Foundation (ASF) under one or more + * contributor license agreements. See the NOTICE file distributed with + * this work for additional information regarding copyright ownership. + * The ASF licenses this file to You 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.apache.camel.commands; + +import java.io.PrintStream; + +import org.apache.camel.CamelContext; + +public class ContextSuspendCommand extends AbstractContextCommand { + + public ContextSuspendCommand(String context) { + super(context); + } + + @Override + protected Object performContextCommand(CamelController camelController, CamelContext camelContext, PrintStream out, PrintStream err) throws Exception { + camelContext.suspend(); + return null; + } +} http://git-wip-us.apache.org/repos/asf/camel/blob/cfb04fde/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/AbstractContextCommand.java ---------------------------------------------------------------------- diff --git a/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/AbstractContextCommand.java b/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/AbstractContextCommand.java index 7cd3625..bb781d7 100644 --- a/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/AbstractContextCommand.java +++ b/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/AbstractContextCommand.java @@ -19,6 +19,7 @@ package org.apache.camel.karaf.commands; import org.apache.camel.CamelContext; import org.apache.felix.gogo.commands.Argument; +@Deprecated public abstract class AbstractContextCommand extends CamelCommandSupport { @Argument(index = 0, name = "context", description = "The name of the Camel context.", required = true, multiValued = false) http://git-wip-us.apache.org/repos/asf/camel/blob/cfb04fde/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ComponentList.java ---------------------------------------------------------------------- diff --git a/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ComponentList.java b/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ComponentList.java index 43d1a69..27a04cb 100644 --- a/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ComponentList.java +++ b/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ComponentList.java @@ -16,11 +16,7 @@ */ package org.apache.camel.karaf.commands; -import java.io.PrintStream; -import java.util.Hashtable; -import java.util.List; -import java.util.Map; - +import org.apache.camel.commands.ComponentListCommand; import org.apache.felix.gogo.commands.Argument; import org.apache.felix.gogo.commands.Command; import org.apache.felix.gogo.commands.Option; @@ -31,21 +27,6 @@ import org.apache.felix.gogo.commands.Option; @Command(scope = "camel", name = "component-list", description = "Lists all Camel components available in CamelContexts.") public class ComponentList extends CamelCommandSupport { - private static final String NAME_COLUMN_LABEL = "Name"; - private static final String STATUS_COLUMN_LABEL = "Status"; - private static final String MAVEN_COLUMN_LABEL = "Maven Coordinate"; - private static final String DESCRIPTION_COLUMN_LABEL = "Description"; - - private static final int DEFAULT_COLUMN_WIDTH_INCREMENT = 0; - private static final String DEFAULT_FIELD_PREAMBLE = " "; - private static final String DEFAULT_FIELD_POSTAMBLE = " "; - private static final String DEFAULT_HEADER_PREAMBLE = " "; - private static final String DEFAULT_HEADER_POSTAMBLE = " "; - private static final int DEFAULT_FORMAT_BUFFER_LENGTH = 24; - // descriptions can be very long so clip by default after 120 chars - private static final int MAX_COLUMN_WIDTH = 120; - private static final int MIN_COLUMN_WIDTH = 12; - @Argument(index = 0, name = "name", description = "The Camel context name where to look for the components", required = true, multiValued = false) String name; @@ -54,137 +35,8 @@ public class ComponentList extends CamelCommandSupport { boolean verbose; protected Object doExecute() throws Exception { - List<Map<String, String>> components = camelController.listComponents(name); - - if (components == null || components.isEmpty()) { - return null; - } - - final Map<String, Integer> columnWidths = computeColumnWidths(components); - final String headerFormat = buildFormatString(columnWidths, true, verbose); - final String rowFormat = buildFormatString(columnWidths, false, verbose); - final PrintStream out = System.out; - - if (verbose) { - out.println(String.format(headerFormat, NAME_COLUMN_LABEL, STATUS_COLUMN_LABEL, MAVEN_COLUMN_LABEL, DESCRIPTION_COLUMN_LABEL)); - out.println(String.format(headerFormat, "----", "------", "----------------", "-----------")); - } else { - out.println(String.format(headerFormat, NAME_COLUMN_LABEL, DESCRIPTION_COLUMN_LABEL)); - out.println(String.format(headerFormat, "----", "-----------")); - } - for (final Map<String, String> component : components) { - if (verbose) { - String name = safeNull(component.get("name")); - String status = safeNull(component.get("status")); - String maven = ""; - if (component.containsKey("groupId") && component.containsKey("artifactId") && component.containsKey("version")) { - maven = component.get("groupId") + "/" + component.get("artifactId") + "/" + component.get("version"); - } - String description = safeNull(component.get("description")); - out.println(String.format(rowFormat, name, status, maven, description)); - } else { - String name = safeNull(component.get("name")); - String description = safeNull(component.get("description")); - out.println(String.format(rowFormat, name, description)); - } - } - - return null; - } - - private Map<String, Integer> computeColumnWidths(final Iterable<Map<String, String>> components) throws Exception { - if (components == null) { - return null; - } else { - // some of the options is optional so we need to start from 1 - int maxNameLen = 1; - int maxStatusLen = 1; - int maxMavenLen = 1; - int maxDescriptionLen = 1; - - for (final Map<String, String> component : components) { - - // grab the information and compute max len - String name = component.get("name"); - if (name != null) { - maxNameLen = Math.max(maxNameLen, name.length()); - } - String status = component.get("status"); - if (status != null) { - maxStatusLen = Math.max(maxStatusLen, status.length()); - } - String type = component.get("type"); - if (component.containsKey("groupId") && component.containsKey("artifactId") && component.containsKey("version")) { - String mvn = component.get("groupId") + "/" + component.get("artifactId") + "/" + component.get("version"); - maxMavenLen = Math.max(maxMavenLen, mvn.length()); - } - String description = component.get("description"); - if (description != null) { - maxDescriptionLen = Math.max(maxDescriptionLen, description.length()); - } - } - - final Map<String, Integer> retval = new Hashtable<String, Integer>(4); - retval.put(NAME_COLUMN_LABEL, maxNameLen); - retval.put(STATUS_COLUMN_LABEL, maxStatusLen); - retval.put(MAVEN_COLUMN_LABEL, maxMavenLen); - retval.put(DESCRIPTION_COLUMN_LABEL, maxDescriptionLen); - - return retval; - } - } - - private String buildFormatString(Map<String, Integer> columnWidths, boolean isHeader, boolean isVerbose) { - final String fieldPreamble; - final String fieldPostamble; - final int columnWidthIncrement; - - if (isHeader) { - fieldPreamble = DEFAULT_HEADER_PREAMBLE; - fieldPostamble = DEFAULT_HEADER_POSTAMBLE; - } else { - fieldPreamble = DEFAULT_FIELD_PREAMBLE; - fieldPostamble = DEFAULT_FIELD_POSTAMBLE; - } - columnWidthIncrement = DEFAULT_COLUMN_WIDTH_INCREMENT; - - if (verbose) { - int nameLen = Math.min(columnWidths.get(NAME_COLUMN_LABEL) + columnWidthIncrement, getMaxColumnWidth()); - int statusLen = Math.min(columnWidths.get(STATUS_COLUMN_LABEL) + columnWidthIncrement, getMaxColumnWidth()); - int mavenLen = Math.min(columnWidths.get(MAVEN_COLUMN_LABEL) + columnWidthIncrement, getMaxColumnWidth()); - int descriptionLen = Math.min(columnWidths.get(DESCRIPTION_COLUMN_LABEL) + columnWidthIncrement, getMaxColumnWidth()); - - nameLen = Math.max(MIN_COLUMN_WIDTH, nameLen); - statusLen = Math.max(MIN_COLUMN_WIDTH, statusLen); - mavenLen = Math.max(MIN_COLUMN_WIDTH, mavenLen); - // last row does not have min width - - final StringBuilder retval = new StringBuilder(DEFAULT_FORMAT_BUFFER_LENGTH); - retval.append(fieldPreamble).append("%-").append(nameLen).append('.').append(nameLen).append('s').append(fieldPostamble).append(' '); - retval.append(fieldPreamble).append("%-").append(statusLen).append('.').append(statusLen).append('s').append(fieldPostamble).append(' '); - retval.append(fieldPreamble).append("%-").append(mavenLen).append('.').append(mavenLen).append('s').append(fieldPostamble).append(' '); - retval.append(fieldPreamble).append("%-").append(descriptionLen).append('.').append(descriptionLen).append('s').append(fieldPostamble).append(' '); - return retval.toString(); - } else { - int nameLen = Math.min(columnWidths.get(NAME_COLUMN_LABEL) + columnWidthIncrement, getMaxColumnWidth()); - int descriptionLen = Math.min(columnWidths.get(DESCRIPTION_COLUMN_LABEL) + columnWidthIncrement, getMaxColumnWidth()); - - nameLen = Math.max(MIN_COLUMN_WIDTH, nameLen); - // last row does not have min width - - final StringBuilder retval = new StringBuilder(DEFAULT_FORMAT_BUFFER_LENGTH); - retval.append(fieldPreamble).append("%-").append(nameLen).append('.').append(nameLen).append('s').append(fieldPostamble).append(' '); - retval.append(fieldPreamble).append("%-").append(descriptionLen).append('.').append(descriptionLen).append('s').append(fieldPostamble).append(' '); - return retval.toString(); - } - } - - private int getMaxColumnWidth() { - if (verbose) { - return Integer.MAX_VALUE; - } else { - return MAX_COLUMN_WIDTH; - } + ComponentListCommand command = new ComponentListCommand(name, verbose); + return command.execute(camelController, System.out, System.err); } } http://git-wip-us.apache.org/repos/asf/camel/blob/cfb04fde/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextResume.java ---------------------------------------------------------------------- diff --git a/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextResume.java b/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextResume.java index 7c8580e..384bd56 100644 --- a/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextResume.java +++ b/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextResume.java @@ -16,18 +16,22 @@ */ package org.apache.camel.karaf.commands; -import org.apache.camel.CamelContext; +import org.apache.camel.commands.ContextResumeCommand; +import org.apache.felix.gogo.commands.Argument; import org.apache.felix.gogo.commands.Command; /** * Command to resume a Camel context. */ @Command(scope = "camel", name = "context-resume", description = "Resumes a Camel context.") -public class ContextResume extends AbstractContextCommand { +public class ContextResume extends CamelCommandSupport { + + @Argument(index = 0, name = "context", description = "The name of the Camel context.", required = true, multiValued = false) + String context; @Override - protected void performContextCommand(CamelContext camelContext) throws Exception { - camelContext.resume(); + protected Object doExecute() throws Exception { + ContextResumeCommand command = new ContextResumeCommand(context); + return command.execute(camelController, System.out, System.err); } - } http://git-wip-us.apache.org/repos/asf/camel/blob/cfb04fde/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextStart.java ---------------------------------------------------------------------- diff --git a/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextStart.java b/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextStart.java index e2d3e0f..b231715 100644 --- a/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextStart.java +++ b/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextStart.java @@ -16,18 +16,23 @@ */ package org.apache.camel.karaf.commands; -import org.apache.camel.CamelContext; +import org.apache.camel.commands.ContextStartCommand; +import org.apache.felix.gogo.commands.Argument; import org.apache.felix.gogo.commands.Command; /** * Command to start a Camel context. */ @Command(scope = "camel", name = "context-start", description = "Start a Camel context.") -public class ContextStart extends AbstractContextCommand { +public class ContextStart extends CamelCommandSupport { + + @Argument(index = 0, name = "context", description = "The name of the Camel context.", required = true, multiValued = false) + String context; @Override - protected void performContextCommand(CamelContext camelContext) throws Exception { - camelContext.start(); + protected Object doExecute() throws Exception { + ContextStartCommand command = new ContextStartCommand(context); + return command.execute(camelController, System.out, System.err); } } http://git-wip-us.apache.org/repos/asf/camel/blob/cfb04fde/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextStop.java ---------------------------------------------------------------------- diff --git a/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextStop.java b/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextStop.java index 303c388..fd48e22 100644 --- a/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextStop.java +++ b/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextStop.java @@ -16,18 +16,23 @@ */ package org.apache.camel.karaf.commands; -import org.apache.camel.CamelContext; +import org.apache.camel.commands.ContextStopCommand; +import org.apache.felix.gogo.commands.Argument; import org.apache.felix.gogo.commands.Command; /** * Command to stop a Camel context. */ @Command(scope = "camel", name = "context-stop", description = "Stop a Camel context. It becomes unavailable and can not be started again.") -public class ContextStop extends AbstractContextCommand { +public class ContextStop extends CamelCommandSupport { + + @Argument(index = 0, name = "context", description = "The name of the Camel context.", required = true, multiValued = false) + String context; @Override - protected void performContextCommand(CamelContext camelContext) throws Exception { - camelContext.stop(); + protected Object doExecute() throws Exception { + ContextStopCommand command = new ContextStopCommand(context); + return command.execute(camelController, System.out, System.err); } } http://git-wip-us.apache.org/repos/asf/camel/blob/cfb04fde/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextSuspend.java ---------------------------------------------------------------------- diff --git a/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextSuspend.java b/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextSuspend.java index db24b9d..05d48fd 100644 --- a/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextSuspend.java +++ b/platforms/karaf/commands/src/main/java/org/apache/camel/karaf/commands/ContextSuspend.java @@ -16,18 +16,23 @@ */ package org.apache.camel.karaf.commands; -import org.apache.camel.CamelContext; +import org.apache.camel.commands.ContextSuspendCommand; +import org.apache.felix.gogo.commands.Argument; import org.apache.felix.gogo.commands.Command; /** * Command to suspend a Camel context. */ @Command(scope = "camel", name = "context-suspend", description = "Suspends a Camel context.") -public class ContextSuspend extends AbstractContextCommand { +public class ContextSuspend extends CamelCommandSupport { + + @Argument(index = 0, name = "context", description = "The name of the Camel context.", required = true, multiValued = false) + String context; @Override - protected void performContextCommand(CamelContext camelContext) throws Exception { - camelContext.suspend(); + protected Object doExecute() throws Exception { + ContextSuspendCommand command = new ContextSuspendCommand(context); + return command.execute(camelController, System.out, System.err); } }