pub struct GitProtocol<R: RepositoryAccess, A: AuthenticationService> { /* private fields */ }Expand description
Transport-agnostic Git smart protocol handler Main Git protocol handler
This struct provides the core Git protocol implementation that works across HTTP, SSH, and other transports. It uses SmartProtocol internally to handle all Git protocol details.
Implementations§
Source§impl<R: RepositoryAccess, A: AuthenticationService> GitProtocol<R, A>
impl<R: RepositoryAccess, A: AuthenticationService> GitProtocol<R, A>
Sourcepub async fn authenticate_http(
&self,
headers: &HashMap<String, String>,
) -> Result<(), ProtocolError>
pub async fn authenticate_http( &self, headers: &HashMap<String, String>, ) -> Result<(), ProtocolError>
Authenticate HTTP request before serving Git operations
Sourcepub async fn authenticate_ssh(
&self,
username: &str,
public_key: &[u8],
) -> Result<(), ProtocolError>
pub async fn authenticate_ssh( &self, username: &str, public_key: &[u8], ) -> Result<(), ProtocolError>
Authenticate SSH session before serving Git operations
Sourcepub fn set_transport(&mut self, protocol: TransportProtocol)
pub fn set_transport(&mut self, protocol: TransportProtocol)
Set transport protocol (Http, Ssh, etc.)
Sourcepub async fn info_refs(&self, service: &str) -> Result<Vec<u8>, ProtocolError>
pub async fn info_refs(&self, service: &str) -> Result<Vec<u8>, ProtocolError>
Handle git info-refs request
Sourcepub async fn upload_pack(
&mut self,
request_data: &[u8],
) -> Result<ProtocolStream, ProtocolError>
pub async fn upload_pack( &mut self, request_data: &[u8], ) -> Result<ProtocolStream, ProtocolError>
Handle git-upload-pack request (for clone/fetch)
Sourcepub async fn receive_pack(
&mut self,
request_stream: ProtocolStream,
) -> Result<ProtocolStream, ProtocolError>
pub async fn receive_pack( &mut self, request_stream: ProtocolStream, ) -> Result<ProtocolStream, ProtocolError>
Handle git-receive-pack request (for push)
Auto Trait Implementations§
impl<R, A> Freeze for GitProtocol<R, A>
impl<R, A> RefUnwindSafe for GitProtocol<R, A>where
R: RefUnwindSafe,
A: RefUnwindSafe,
impl<R, A> Send for GitProtocol<R, A>
impl<R, A> Sync for GitProtocol<R, A>
impl<R, A> Unpin for GitProtocol<R, A>
impl<R, A> UnsafeUnpin for GitProtocol<R, A>where
R: UnsafeUnpin,
A: UnsafeUnpin,
impl<R, A> UnwindSafe for GitProtocol<R, A>where
R: UnwindSafe,
A: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> ValueSize for T
impl<T> ValueSize for T
Source§fn value_size(&self) -> usize
fn value_size(&self) -> usize
The size of this value in bytes, excluding allocated data. Read more
Source§fn value_size_sum_iter<'item>(iterator: impl Iterator<Item = &'item T>) -> usizewhere
T: 'item,
fn value_size_sum_iter<'item>(iterator: impl Iterator<Item = &'item T>) -> usizewhere
T: 'item,
The total sum of the sizes of all values in the given iterator, in
bytes. This is default-implemented by computing ValueSize::value_size
on every element and summing them. For Sized types, a more potentially
efficient implementation using Iterator::count is provided. If you are
implementing this trait manually, it is unlikely to be more efficient to
provide a manual implementation here. Read more
Source§fn value_size_sum_exact_size_iter<'item>(
iterator: impl ExactSizeIterator<Item = &'item T>,
) -> usizewhere
T: 'item,
fn value_size_sum_exact_size_iter<'item>(
iterator: impl ExactSizeIterator<Item = &'item T>,
) -> usizewhere
T: 'item,
The total sum of the sizes of all values in the given
exact-size-iterator, in bytes. This is default-implemented by using
ValueSize::value_size_sum_iter. For Sized types, a usually more
efficient implementation using ExactSizeIterator::len is provided. If
you are implementing this trait manually, it is unlikely to be more
efficient to provide a manual implementation here. Read more