1 /* 2 * Copyright (C) 2015, Kaloyan Raev <kaloyan.r@zend.com> 3 * and other copyright owners as documented in the project's IP log. 4 * 5 * This program and the accompanying materials are made available 6 * under the terms of the Eclipse Distribution License v1.0 which 7 * accompanies this distribution, is reproduced below, and is 8 * available at http://www.eclipse.org/org/documents/edl-v10.php 9 * 10 * All rights reserved. 11 * 12 * Redistribution and use in source and binary forms, with or 13 * without modification, are permitted provided that the following 14 * conditions are met: 15 * 16 * - Redistributions of source code must retain the above copyright 17 * notice, this list of conditions and the following disclaimer. 18 * 19 * - Redistributions in binary form must reproduce the above 20 * copyright notice, this list of conditions and the following 21 * disclaimer in the documentation and/or other materials provided 22 * with the distribution. 23 * 24 * - Neither the name of the Eclipse Foundation, Inc. nor the 25 * names of its contributors may be used to endorse or promote 26 * products derived from this software without specific prior 27 * written permission. 28 * 29 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND 30 * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, 31 * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 32 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 33 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR 34 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 35 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT 36 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 37 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 38 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 39 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 40 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 41 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 42 */ 43 package org.eclipse.jgit.api; 44 45 import java.io.IOException; 46 import java.net.URISyntaxException; 47 import java.util.List; 48 49 import org.eclipse.jgit.api.errors.GitAPIException; 50 import org.eclipse.jgit.api.errors.JGitInternalException; 51 import org.eclipse.jgit.lib.Repository; 52 import org.eclipse.jgit.lib.StoredConfig; 53 import org.eclipse.jgit.transport.RemoteConfig; 54 import org.eclipse.jgit.transport.URIish; 55 56 /** 57 * Used to change the URL of a remote. 58 * 59 * This class has setters for all supported options and arguments of this 60 * command and a {@link #call()} method to finally execute the command. 61 * 62 * @see <a href= 63 * "http://www.kernel.org/pub/software/scm/git/docs/git-remote.html" > Git 64 * documentation about Remote</a> 65 * @since 4.2 66 */ 67 public class RemoteSetUrlCommand extends GitCommand<RemoteConfig> { 68 69 /** 70 * The available URI types for the remote. 71 * 72 * @since 5.3 73 */ 74 public enum UriType { 75 /** 76 * Fetch URL for the remote. 77 */ 78 FETCH, 79 /** 80 * Push URL for the remote. 81 */ 82 PUSH 83 } 84 85 86 private String remoteName; 87 88 private URIish remoteUri; 89 90 private UriType type; 91 92 /** 93 * <p> 94 * Constructor for RemoteSetUrlCommand. 95 * </p> 96 * 97 * @param repo 98 * the {@link org.eclipse.jgit.lib.Repository} 99 */ 100 protected RemoteSetUrlCommand(Repository repo) { 101 super(repo); 102 } 103 104 /** 105 * The name of the remote to change the URL for. 106 * 107 * @param name 108 * a remote name 109 * @deprecated use {@link #setRemoteName} instead 110 */ 111 @Deprecated 112 public void setName(String name) { 113 this.remoteName = name; 114 } 115 116 /** 117 * The name of the remote to change the URL for. 118 * 119 * @param remoteName 120 * a remote remoteName 121 * @return {@code this} 122 * @since 5.3 123 */ 124 public RemoteSetUrlCommand setRemoteName(String remoteName) { 125 this.remoteName = remoteName; 126 return this; 127 } 128 129 /** 130 * The new URL for the remote. 131 * 132 * @param uri 133 * an URL for the remote 134 * @deprecated use {@link #setRemoteUri} instead 135 */ 136 @Deprecated 137 public void setUri(URIish uri) { 138 this.remoteUri = uri; 139 } 140 141 /** 142 * The new URL for the remote. 143 * 144 * @param remoteUri 145 * an URL for the remote 146 * @return {@code this} 147 * @since 5.3 148 */ 149 public RemoteSetUrlCommand setRemoteUri(URIish remoteUri) { 150 this.remoteUri = remoteUri; 151 return this; 152 } 153 154 /** 155 * Whether to change the push URL of the remote instead of the fetch URL. 156 * 157 * @param push 158 * <code>true</code> to set the push url, <code>false</code> to 159 * set the fetch url 160 * @deprecated use {@link #setUriType} instead 161 */ 162 @Deprecated 163 public void setPush(boolean push) { 164 if (push) { 165 setUriType(UriType.PUSH); 166 } else { 167 setUriType(UriType.FETCH); 168 } 169 } 170 171 /** 172 * Whether to change the push URL of the remote instead of the fetch URL. 173 * 174 * @param type 175 * the <code>UriType</code> value to set 176 * @return {@code this} 177 * @since 5.3 178 */ 179 public RemoteSetUrlCommand setUriType(UriType type) { 180 this.type = type; 181 return this; 182 } 183 184 /** 185 * {@inheritDoc} 186 * <p> 187 * Executes the {@code remote} command with all the options and parameters 188 * collected by the setter methods of this class. 189 */ 190 @Override 191 public RemoteConfig call() throws GitAPIException { 192 checkCallable(); 193 194 try { 195 StoredConfig config = repo.getConfig(); 196 RemoteConfig remote = new RemoteConfig(config, remoteName); 197 if (type == UriType.PUSH) { 198 List<URIish> uris = remote.getPushURIs(); 199 if (uris.size() > 1) { 200 throw new JGitInternalException( 201 "remote.newtest.pushurl has multiple values"); //$NON-NLS-1$ 202 } else if (uris.size() == 1) { 203 remote.removePushURI(uris.get(0)); 204 } 205 remote.addPushURI(remoteUri); 206 } else { 207 List<URIish> uris = remote.getURIs(); 208 if (uris.size() > 1) { 209 throw new JGitInternalException( 210 "remote.newtest.url has multiple values"); //$NON-NLS-1$ 211 } else if (uris.size() == 1) { 212 remote.removeURI(uris.get(0)); 213 } 214 remote.addURI(remoteUri); 215 } 216 217 remote.update(config); 218 config.save(); 219 return remote; 220 } catch (IOException | URISyntaxException e) { 221 throw new JGitInternalException(e.getMessage(), e); 222 } 223 } 224 225 }