View Javadoc
1   /*
2    * Copyright (C) 2009, Constantine Plotnikov <constantine.plotnikov@gmail.com>
3    * Copyright (C) 2009, JetBrains s.r.o.
4    * Copyright (C) 2009, Shawn O. Pearce <spearce@spearce.org>
5    * and other copyright owners as documented in the project's IP log.
6    *
7    * This program and the accompanying materials are made available
8    * under the terms of the Eclipse Distribution License v1.0 which
9    * accompanies this distribution, is reproduced below, and is
10   * available at http://www.eclipse.org/org/documents/edl-v10.php
11   *
12   * All rights reserved.
13   *
14   * Redistribution and use in source and binary forms, with or
15   * without modification, are permitted provided that the following
16   * conditions are met:
17   *
18   * - Redistributions of source code must retain the above copyright
19   *   notice, this list of conditions and the following disclaimer.
20   *
21   * - Redistributions in binary form must reproduce the above
22   *   copyright notice, this list of conditions and the following
23   *   disclaimer in the documentation and/or other materials provided
24   *   with the distribution.
25   *
26   * - Neither the name of the Eclipse Foundation, Inc. nor the
27   *   names of its contributors may be used to endorse or promote
28   *   products derived from this software without specific prior
29   *   written permission.
30   *
31   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
32   * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
33   * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
34   * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
35   * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
36   * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
37   * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
38   * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
39   * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
40   * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
41   * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
42   * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
43   * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
44   */
45  
46  package org.eclipse.jgit.transport;
47  
48  import org.eclipse.jgit.lib.Repository;
49  import org.eclipse.jgit.transport.http.HttpConnectionFactory;
50  import org.eclipse.jgit.transport.http.JDKHttpConnectionFactory;
51  
52  /**
53   * The base class for transports that use HTTP as underlying protocol. This class
54   * allows customizing HTTP connection settings.
55   */
56  public abstract class HttpTransport extends Transport {
57  	/**
58  	 * factory for creating HTTP connections
59  	 *
60  	 * @since 3.3
61  	 */
62  	protected static HttpConnectionFactory connectionFactory = new JDKHttpConnectionFactory();
63  
64  	/**
65  	 * Get the {@link org.eclipse.jgit.transport.http.HttpConnectionFactory}
66  	 * used to create new connections
67  	 *
68  	 * @return the {@link org.eclipse.jgit.transport.http.HttpConnectionFactory}
69  	 *         used to create new connections
70  	 * @since 3.3
71  	 */
72  	public static HttpConnectionFactory getConnectionFactory() {
73  		return connectionFactory;
74  	}
75  
76  	/**
77  	 * Set the {@link org.eclipse.jgit.transport.http.HttpConnectionFactory} to
78  	 * be used to create new connections
79  	 *
80  	 * @param cf
81  	 *            connection factory
82  	 * @since 3.3
83  	 */
84  	public static void setConnectionFactory(HttpConnectionFactory cf) {
85  		connectionFactory = cf;
86  	}
87  
88  	/**
89  	 * Create a new transport instance.
90  	 *
91  	 * @param local
92  	 *            the repository this instance will fetch into, or push out of.
93  	 *            This must be the repository passed to
94  	 *            {@link #open(Repository, URIish)}.
95  	 * @param uri
96  	 *            the URI used to access the remote repository. This must be the
97  	 *            URI passed to {@link #open(Repository, URIish)}.
98  	 */
99  	protected HttpTransport(Repository local, URIish uri) {
100 		super(local, uri);
101 	}
102 
103 	/**
104 	 * Create a minimal HTTP transport instance not tied to a single repository.
105 	 *
106 	 * @param uri a {@link org.eclipse.jgit.transport.URIish} object.
107 	 */
108 	protected HttpTransport(URIish uri) {
109 		super(uri);
110 	}
111 }