Class TransportGitAnon
- java.lang.Object
-
- org.eclipse.jgit.transport.Transport
-
- org.eclipse.jgit.transport.TcpTransport
-
- org.eclipse.jgit.transport.TransportGitAnon
-
- All Implemented Interfaces:
java.lang.AutoCloseable
,PackTransport
class TransportGitAnon extends TcpTransport implements PackTransport
Transport through a git-daemon waiting for anonymous TCP connections.This transport supports the
git://
protocol, usually run on the IANA registered port 9418. It is a popular means for distributing open source projects, as there are no authentication or authorization overheads.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description (package private) class
TransportGitAnon.TcpFetchConnection
(package private) class
TransportGitAnon.TcpPushConnection
-
Nested classes/interfaces inherited from class org.eclipse.jgit.transport.Transport
Transport.Operation
-
-
Field Summary
Fields Modifier and Type Field Description (package private) static int
GIT_PORT
(package private) static TransportProtocol
PROTO_GIT
-
Fields inherited from class org.eclipse.jgit.transport.Transport
DEFAULT_FETCH_THIN, DEFAULT_PUSH_THIN, local, protocol, REFSPEC_PUSH_ALL, REFSPEC_TAGS, uri
-
-
Constructor Summary
Constructors Constructor Description TransportGitAnon(Repository local, URIish uri)
TransportGitAnon(URIish uri)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
close()
(package private) java.net.Socket
openConnection()
FetchConnection
openFetch()
Begins a new connection for fetching from the remote repository.FetchConnection
openFetch(java.util.Collection<RefSpec> refSpecs, java.lang.String... additionalPatterns)
Begins a new connection for fetching from the remote repository.PushConnection
openPush()
Begins a new connection for pushing into the remote repository.(package private) void
service(java.lang.String name, PacketLineOut pckOut, TransferConfig.ProtocolVersion gitProtocol)
-
Methods inherited from class org.eclipse.jgit.transport.Transport
applyConfig, fetch, fetch, findRemoteRefUpdatesFor, findRemoteRefUpdatesFor, findRemoteRefUpdatesFor, findRemoteRefUpdatesFor, getCredentialsProvider, getFilterBlobLimit, getFilterSpec, getObjectChecker, getOptionReceivePack, getOptionUploadPack, getPackConfig, getPushOptions, getTagOpt, getTimeout, getTransportProtocols, getURI, isCheckFetchedObjects, isDryRun, isFetchThin, isPushAtomic, isPushThin, isRemoveDeletedRefs, open, open, open, open, open, open, open, openAll, openAll, openAll, openAll, push, push, register, setCheckFetchedObjects, setCredentialsProvider, setDryRun, setFetchThin, setFilterBlobLimit, setFilterSpec, setObjectChecker, setOptionReceivePack, setOptionUploadPack, setPackConfig, setPushAtomic, setPushOptions, setPushThin, setRemoveDeletedRefs, setTagOpt, setTimeout, unregister
-
-
-
-
Field Detail
-
GIT_PORT
static final int GIT_PORT
- See Also:
- Constant Field Values
-
PROTO_GIT
static final TransportProtocol PROTO_GIT
-
-
Constructor Detail
-
TransportGitAnon
TransportGitAnon(Repository local, URIish uri)
-
TransportGitAnon
TransportGitAnon(URIish uri)
-
-
Method Detail
-
openFetch
public FetchConnection openFetch() throws TransportException
Begins a new connection for fetching from the remote repository.If the transport has no local repository, the fetch connection can only be used for reading remote refs.
- Specified by:
openFetch
in classTransport
- Returns:
- a fresh connection to fetch from the remote repository.
- Throws:
TransportException
- the remote connection could not be established.
-
openFetch
public FetchConnection openFetch(java.util.Collection<RefSpec> refSpecs, java.lang.String... additionalPatterns) throws NotSupportedException, TransportException
Description copied from class:Transport
Begins a new connection for fetching from the remote repository.If the transport has no local repository, the fetch connection can only be used for reading remote refs.
If the server supports git protocol V2, the
RefSpec
s and the additional patterns, if any, are used to restrict the server's ref advertisement to matching refs only.Transports that want to support git protocol V2 must override this; the default implementation ignores its arguments and calls
Transport.openFetch()
.- Overrides:
openFetch
in classTransport
- Parameters:
refSpecs
- that will be fetched viaFetchConnection.fetch(ProgressMonitor, Collection, java.util.Set, OutputStream)
lateradditionalPatterns
- that will be set as ref prefixes if the server supports git protocol V2;null
values are ignored- Returns:
- a fresh connection to fetch from the remote repository.
- Throws:
NotSupportedException
- the implementation does not support fetching.TransportException
- the remote connection could not be established.
-
openPush
public PushConnection openPush() throws TransportException
Begins a new connection for pushing into the remote repository.- Specified by:
openPush
in classTransport
- Returns:
- a fresh connection to push into the remote repository.
- Throws:
TransportException
- the remote connection could not be established
-
close
public void close()
Close any resources used by this transport.
If the remote repository is contacted by a network socket this method must close that network socket, disconnecting the two peers. If the remote repository is actually local (same system) this method must close any open file handles used to read the "remote" repository.
AutoClosable.close()
declares that it throwsException
. Implementers shouldn't throw checked exceptions. This override narrows the signature to prevent them from doing so.
-
openConnection
java.net.Socket openConnection() throws TransportException
- Throws:
TransportException
-
service
void service(java.lang.String name, PacketLineOut pckOut, TransferConfig.ProtocolVersion gitProtocol) throws java.io.IOException
- Throws:
java.io.IOException
-
-