diff --git a/scm-clients/scm-cli-client/src/main/java/sonia/scm/cli/I18n.java b/scm-clients/scm-cli-client/src/main/java/sonia/scm/cli/I18n.java index 6d76041c60..3444a0904a 100644 --- a/scm-clients/scm-cli-client/src/main/java/sonia/scm/cli/I18n.java +++ b/scm-clients/scm-cli-client/src/main/java/sonia/scm/cli/I18n.java @@ -50,6 +50,9 @@ import java.util.ResourceBundle; public class I18n { + /** Field description */ + public static final String REPOSITORY_NOT_FOUND = "repositoryNotFound"; + /** Field description */ public static final String RESOURCE_BUNDLE = "sonia.resources.i18n"; diff --git a/scm-clients/scm-cli-client/src/main/java/sonia/scm/cli/cmd/GetRepositorySubCommand.java b/scm-clients/scm-cli-client/src/main/java/sonia/scm/cli/cmd/GetRepositorySubCommand.java new file mode 100644 index 0000000000..85529d577a --- /dev/null +++ b/scm-clients/scm-cli-client/src/main/java/sonia/scm/cli/cmd/GetRepositorySubCommand.java @@ -0,0 +1,90 @@ +/** + * Copyright (c) 2010, Sebastian Sdorra + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, + * this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright notice, + * this list of conditions and the following disclaimer in the documentation + * and/or other materials provided with the distribution. + * 3. Neither the name of SCM-Manager; nor the names of its + * contributors may be used to endorse or promote products derived from this + * software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" + * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR ANY + * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; + * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON + * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + * + * http://bitbucket.org/sdorra/scm-manager + * + */ + + + +package sonia.scm.cli.cmd; + +//~--- non-JDK imports -------------------------------------------------------- + +import org.kohsuke.args4j.Argument; + +import sonia.scm.cli.I18n; +import sonia.scm.client.ScmClientSession; +import sonia.scm.repository.Repository; + +//~--- JDK imports ------------------------------------------------------------ + +import java.util.HashMap; +import java.util.Map; + +/** + * + * @author Sebastian Sdorra + */ +@Command("get-repository") +public class GetRepositorySubCommand extends TemplateSubCommand +{ + + /** Field description */ + public static final String TEMPLATE = "/sonia/resources/get-repository.ftl"; + + //~--- methods -------------------------------------------------------------- + + /** + * Method description + * + */ + @Override + protected void run() + { + ScmClientSession session = createSession(); + Repository repository = session.getRepositoryHandler().get(id); + + if (repository != null) + { + Map env = new HashMap(); + + env.put("repository", repository); + renderTemplate(env, TEMPLATE); + } + else + { + output.println(i18n.getMessage(I18n.REPOSITORY_NOT_FOUND)); + } + } + + //~--- fields --------------------------------------------------------------- + + /** Field description */ + @Argument(usage = "optionRepositoryId", required = true) + private String id; +} diff --git a/scm-clients/scm-cli-client/src/main/resources/META-INF/services/sonia.scm.cli.cmd.SubCommand b/scm-clients/scm-cli-client/src/main/resources/META-INF/services/sonia.scm.cli.cmd.SubCommand index 99987bd555..56bff29aae 100644 --- a/scm-clients/scm-cli-client/src/main/resources/META-INF/services/sonia.scm.cli.cmd.SubCommand +++ b/scm-clients/scm-cli-client/src/main/resources/META-INF/services/sonia.scm.cli.cmd.SubCommand @@ -27,6 +27,7 @@ # http://bitbucket.org/sdorra/scm-manager # +sonia.scm.cli.cmd.GetRepositorySubCommand sonia.scm.cli.cmd.ListRepositoriesSubCommand sonia.scm.cli.cmd.StoreConfigSubCommand sonia.scm.cli.cmd.DeleteConfigSubCommand \ No newline at end of file diff --git a/scm-clients/scm-cli-client/src/main/resources/sonia/resources/get-repository.ftl b/scm-clients/scm-cli-client/src/main/resources/sonia/resources/get-repository.ftl new file mode 100644 index 0000000000..8eb0118dd2 --- /dev/null +++ b/scm-clients/scm-cli-client/src/main/resources/sonia/resources/get-repository.ftl @@ -0,0 +1,15 @@ +ID: ${repository.id} +Name: ${repository.name} +Type: ${repository.type} +E-Mail: ${repository.contact} +Description: ${repository.description} +Public: ${repository.publicReadable?string} +Creation-Date: ${repository.creationDate!""?string} +Last-Modified: ${repository.lastModified!""?string} +URL: ${repository.url} +Permissions: +<#if repository.permissions??> +<#list repository.permissions as permission> + ${permission.type} - ${permission.name} (Group: ${permission.groupPermission?string}) + + diff --git a/scm-clients/scm-cli-client/src/main/resources/sonia/resources/i18n.properties b/scm-clients/scm-cli-client/src/main/resources/sonia/resources/i18n.properties index a4f3b92449..4f0c469ad8 100644 --- a/scm-clients/scm-cli-client/src/main/resources/sonia/resources/i18n.properties +++ b/scm-clients/scm-cli-client/src/main/resources/sonia/resources/i18n.properties @@ -36,6 +36,9 @@ optionPassword = Password optionHelpText = Shows this help optionTemplate = Template optionTemplateFile = Template file +optionRepositoryId = Repository Id + +repositoryNotFound = The repository is not available metaVar_config = configname metaVar_arg = subcommand arguments