From 540189c0a93d5c968a645b6ba135f01a97628978 Mon Sep 17 00:00:00 2001 From: Sebastian Sdorra Date: Fri, 10 May 2013 15:59:31 +0200 Subject: [PATCH] implement git push command --- .../scm/repository/spi/GitPushCommand.java | 115 ++++++++++++++++++ .../spi/GitRepositoryServiceProvider.java | 16 ++- 2 files changed, 130 insertions(+), 1 deletion(-) create mode 100644 scm-plugins/scm-git-plugin/src/main/java/sonia/scm/repository/spi/GitPushCommand.java diff --git a/scm-plugins/scm-git-plugin/src/main/java/sonia/scm/repository/spi/GitPushCommand.java b/scm-plugins/scm-git-plugin/src/main/java/sonia/scm/repository/spi/GitPushCommand.java new file mode 100644 index 0000000000..4c155fc3e6 --- /dev/null +++ b/scm-plugins/scm-git-plugin/src/main/java/sonia/scm/repository/spi/GitPushCommand.java @@ -0,0 +1,115 @@ +/** + * 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.repository.spi; + +//~--- non-JDK imports -------------------------------------------------------- + +import com.google.common.collect.Iterables; + +import org.eclipse.jgit.api.Git; +import org.eclipse.jgit.transport.PushResult; + +import sonia.scm.repository.GitRepositoryHandler; +import sonia.scm.repository.Repository; +import sonia.scm.repository.RepositoryException; +import sonia.scm.repository.api.PushResponse; + +//~--- JDK imports ------------------------------------------------------------ + +import java.io.File; +import java.io.IOException; + +/** + * + * @author Sebastian Sdorra + */ +public class GitPushCommand extends AbstractGitCommand implements PushCommand +{ + + /** + * Constructs ... + * + * + * @param handler + * @param context + * @param repository + */ + public GitPushCommand(GitRepositoryHandler handler, GitContext context, + Repository repository) + { + super(context, repository); + this.handler = handler; + } + + //~--- methods -------------------------------------------------------------- + + /** + * Method description + * + * + * @param request + * + * @return + * + * @throws IOException + * @throws RepositoryException + */ + @Override + public PushResponse push(PushCommandRequest request) + throws IOException, RepositoryException + { + PushResponse response = null; + File remoteRepository = handler.getDirectory(request.getRemoteRepository()); + org.eclipse.jgit.api.PushCommand push = Git.wrap(open()).push(); + + push.setPushAll().setPushTags(); + push.setRemote(remoteRepository.getAbsolutePath()); + + try + { + Iterable results = push.call(); + + response = new PushResponse(Iterables.size(results)); + } + catch (Exception ex) + { + throw new RepositoryException("could not execute push command", ex); + } + + return response; + } + + //~--- fields --------------------------------------------------------------- + + /** Field description */ + private GitRepositoryHandler handler; +} diff --git a/scm-plugins/scm-git-plugin/src/main/java/sonia/scm/repository/spi/GitRepositoryServiceProvider.java b/scm-plugins/scm-git-plugin/src/main/java/sonia/scm/repository/spi/GitRepositoryServiceProvider.java index 83ba0d6a5c..bfb8f71be1 100644 --- a/scm-plugins/scm-git-plugin/src/main/java/sonia/scm/repository/spi/GitRepositoryServiceProvider.java +++ b/scm-plugins/scm-git-plugin/src/main/java/sonia/scm/repository/spi/GitRepositoryServiceProvider.java @@ -64,7 +64,9 @@ public class GitRepositoryServiceProvider extends RepositoryServiceProvider Command.LOG, Command.TAGS, Command.BRANCHES, - Command.INCOMING + Command.INCOMING, + Command.OUTGOING, + Command.PUSH ); //J+ @@ -184,6 +186,18 @@ public class GitRepositoryServiceProvider extends RepositoryServiceProvider return new GitLogCommand(context, repository); } + /** + * Method description + * + * + * @return + */ + @Override + public PushCommand getPushCommand() + { + return new GitPushCommand(handler, context, repository); + } + /** * Method description *