View Javadoc
1   /*
2    * Copyright (C) 2008-2009, Google Inc.
3    * Copyright (C) 2008, Marek Zawirski <marek.zawirski@gmail.com>
4    * Copyright (C) 2008, Mike Ralphson <mike@abacus.co.uk>
5    * Copyright (C) 2008, Shawn O. Pearce <spearce@spearce.org>
6    * and other copyright owners as documented in the project's IP log.
7    *
8    * This program and the accompanying materials are made available
9    * under the terms of the Eclipse Distribution License v1.0 which
10   * accompanies this distribution, is reproduced below, and is
11   * available at http://www.eclipse.org/org/documents/edl-v10.php
12   *
13   * All rights reserved.
14   *
15   * Redistribution and use in source and binary forms, with or
16   * without modification, are permitted provided that the following
17   * conditions are met:
18   *
19   * - Redistributions of source code must retain the above copyright
20   *   notice, this list of conditions and the following disclaimer.
21   *
22   * - Redistributions in binary form must reproduce the above
23   *   copyright notice, this list of conditions and the following
24   *   disclaimer in the documentation and/or other materials provided
25   *   with the distribution.
26   *
27   * - Neither the name of the Eclipse Foundation, Inc. nor the
28   *   names of its contributors may be used to endorse or promote
29   *   products derived from this software without specific prior
30   *   written permission.
31   *
32   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
33   * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
34   * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
35   * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
36   * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
37   * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
38   * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
39   * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
40   * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
41   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
42   * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
43   * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
44   * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
45   */
46  
47  package org.eclipse.jgit.transport;
48  
49  import java.io.OutputStream;
50  import java.util.Collection;
51  import java.util.Set;
52  
53  import org.eclipse.jgit.errors.TransportException;
54  import org.eclipse.jgit.internal.storage.file.PackLock;
55  import org.eclipse.jgit.lib.ObjectId;
56  import org.eclipse.jgit.lib.ProgressMonitor;
57  import org.eclipse.jgit.lib.Ref;
58  
59  /**
60   * Lists known refs from the remote and copies objects of selected refs.
61   * <p>
62   * A fetch connection typically connects to the <code>git-upload-pack</code>
63   * service running where the remote repository is stored. This provides a
64   * one-way object transfer service to copy objects from the remote repository
65   * into this local repository.
66   * <p>
67   * Instances of a FetchConnection must be created by a
68   * {@link org.eclipse.jgit.transport.Transport} that implements a specific
69   * object transfer protocol that both sides of the connection understand.
70   * <p>
71   * FetchConnection instances are not thread safe and may be accessed by only one
72   * thread at a time.
73   *
74   * @see Transport
75   */
76  public interface FetchConnection extends Connection {
77  	/**
78  	 * Fetch objects we don't have but that are reachable from advertised refs.
79  	 * <p>
80  	 * Only one call per connection is allowed. Subsequent calls will result in
81  	 * {@link org.eclipse.jgit.errors.TransportException}.
82  	 * </p>
83  	 * <p>
84  	 * Implementations are free to use network connections as necessary to
85  	 * efficiently (for both client and server) transfer objects from the remote
86  	 * repository into this repository. When possible implementations should
87  	 * avoid replacing/overwriting/duplicating an object already available in
88  	 * the local destination repository. Locally available objects and packs
89  	 * should always be preferred over remotely available objects and packs.
90  	 * {@link org.eclipse.jgit.transport.Transport#isFetchThin()} should be
91  	 * honored if applicable.
92  	 * </p>
93  	 *
94  	 * @param monitor
95  	 *            progress monitor to inform the end-user about the amount of
96  	 *            work completed, or to indicate cancellation. Implementations
97  	 *            should poll the monitor at regular intervals to look for
98  	 *            cancellation requests from the user.
99  	 * @param want
100 	 *            one or more refs advertised by this connection that the caller
101 	 *            wants to store locally.
102 	 * @param have
103 	 *            additional objects known to exist in the destination
104 	 *            repository, especially if they aren't yet reachable by the ref
105 	 *            database. Connections should take this set as an addition to
106 	 *            what is reachable through all Refs, not in replace of it.
107 	 * @throws org.eclipse.jgit.errors.TransportException
108 	 *             objects could not be copied due to a network failure,
109 	 *             protocol error, or error on remote side, or connection was
110 	 *             already used for fetch.
111 	 */
112 	void fetch(final ProgressMonitor monitor,
113 			final Collection<Ref> want, final Set<ObjectId> have)
114 			throws TransportException;
115 
116 	/**
117 	 * Fetch objects we don't have but that are reachable from advertised refs.
118 	 * <p>
119 	 * Only one call per connection is allowed. Subsequent calls will result in
120 	 * {@link org.eclipse.jgit.errors.TransportException}.
121 	 * </p>
122 	 * <p>
123 	 * Implementations are free to use network connections as necessary to
124 	 * efficiently (for both client and server) transfer objects from the remote
125 	 * repository into this repository. When possible implementations should
126 	 * avoid replacing/overwriting/duplicating an object already available in
127 	 * the local destination repository. Locally available objects and packs
128 	 * should always be preferred over remotely available objects and packs.
129 	 * {@link org.eclipse.jgit.transport.Transport#isFetchThin()} should be
130 	 * honored if applicable.
131 	 * </p>
132 	 *
133 	 * @param monitor
134 	 *            progress monitor to inform the end-user about the amount of
135 	 *            work completed, or to indicate cancellation. Implementations
136 	 *            should poll the monitor at regular intervals to look for
137 	 *            cancellation requests from the user.
138 	 * @param want
139 	 *            one or more refs advertised by this connection that the caller
140 	 *            wants to store locally.
141 	 * @param have
142 	 *            additional objects known to exist in the destination
143 	 *            repository, especially if they aren't yet reachable by the ref
144 	 *            database. Connections should take this set as an addition to
145 	 *            what is reachable through all Refs, not in replace of it.
146 	 * @param out
147 	 *            OutputStream to write sideband messages to
148 	 * @throws org.eclipse.jgit.errors.TransportException
149 	 *             objects could not be copied due to a network failure,
150 	 *             protocol error, or error on remote side, or connection was
151 	 *             already used for fetch.
152 	 * @since 3.0
153 	 */
154 	void fetch(final ProgressMonitor monitor,
155 			final Collection<Ref> want, final Set<ObjectId> have,
156 			OutputStream out) throws TransportException;
157 
158 	/**
159 	 * Did the last {@link #fetch(ProgressMonitor, Collection, Set)} get tags?
160 	 * <p>
161 	 * Some Git aware transports are able to implicitly grab an annotated tag if
162 	 * {@link org.eclipse.jgit.transport.TagOpt#AUTO_FOLLOW} or
163 	 * {@link org.eclipse.jgit.transport.TagOpt#FETCH_TAGS} was selected and the
164 	 * object the tag peels to (references) was transferred as part of the last
165 	 * {@link #fetch(ProgressMonitor, Collection, Set)} call. If it is possible
166 	 * for such tags to have been included in the transfer this method returns
167 	 * true, allowing the caller to attempt tag discovery.
168 	 * <p>
169 	 * By returning only true/false (and not the actual list of tags obtained)
170 	 * the transport itself does not need to be aware of whether or not tags
171 	 * were included in the transfer.
172 	 *
173 	 * @return true if the last fetch call implicitly included tag objects;
174 	 *         false if tags were not implicitly obtained.
175 	 */
176 	boolean didFetchIncludeTags();
177 
178 	/**
179 	 * Did the last {@link #fetch(ProgressMonitor, Collection, Set)} validate
180 	 * graph?
181 	 * <p>
182 	 * Some transports walk the object graph on the client side, with the client
183 	 * looking for what objects it is missing and requesting them individually
184 	 * from the remote peer. By virtue of completing the fetch call the client
185 	 * implicitly tested the object connectivity, as every object in the graph
186 	 * was either already local or was requested successfully from the peer. In
187 	 * such transports this method returns true.
188 	 * <p>
189 	 * Some transports assume the remote peer knows the Git object graph and is
190 	 * able to supply a fully connected graph to the client (although it may
191 	 * only be transferring the parts the client does not yet have). Its faster
192 	 * to assume such remote peers are well behaved and send the correct
193 	 * response to the client. In such transports this method returns false.
194 	 *
195 	 * @return true if the last fetch had to perform a connectivity check on the
196 	 *         client side in order to succeed; false if the last fetch assumed
197 	 *         the remote peer supplied a complete graph.
198 	 */
199 	boolean didFetchTestConnectivity();
200 
201 	/**
202 	 * Set the lock message used when holding a pack out of garbage collection.
203 	 * <p>
204 	 * Callers that set a lock message <b>must</b> ensure they call
205 	 * {@link #getPackLocks()} after
206 	 * {@link #fetch(ProgressMonitor, Collection, Set)}, even if an exception
207 	 * was thrown, and release the locks that are held.
208 	 *
209 	 * @param message message to use when holding a pack in place.
210 	 */
211 	void setPackLockMessage(String message);
212 
213 	/**
214 	 * All locks created by the last
215 	 * {@link #fetch(ProgressMonitor, Collection, Set)} call.
216 	 *
217 	 * @return collection (possibly empty) of locks created by the last call to
218 	 *         fetch. The caller must release these after refs are updated in
219 	 *         order to safely permit garbage collection.
220 	 */
221 	Collection<PackLock> getPackLocks();
222 }