Skip to main content

ReplicationProtocol

Struct ReplicationProtocol 

Source
pub struct ReplicationProtocol { /* private fields */ }
Expand description

Repository replication protocol.

Handles incoming P2P messages and coordinates repository synchronization.

Implementations§

Source§

impl ReplicationProtocol

Source

pub fn new() -> Self

Create a new replication protocol instance.

Source

pub fn set_handler(&mut self, handler: Arc<dyn ReplicationHandler>)

Set the message handler for sending responses.

Source

pub fn repos(&self) -> Arc<RwLock<HashMap<String, Arc<Repository>>>>

Get the repository store reference.

Source

pub fn register_repo(&self, key: String, repo: Arc<Repository>)

Register a repository for replication.

Source

pub fn get_repo(&self, key: &str) -> Option<Arc<Repository>>

Get a repository by key.

Source

pub fn get_or_create_repo(&self, key: &str) -> Arc<Repository>

Get or create a repository by key.

Source

pub fn handle_message( &self, peer_id: &[u8], data: &[u8], ) -> Result<Option<Message>>

Handle an incoming message from a peer.

Returns an optional response message.

Source

pub fn broadcast_update( &self, repo_key: &str, new_objects: Vec<ObjectId>, refs: Vec<(String, ObjectId)>, )

Broadcast a repository update to all peers.

Called after a push to notify peers about new objects.

Source

pub fn broadcast_ref_update( &self, repo_key: &str, ref_name: &str, old_id: ObjectId, new_id: ObjectId, )

Broadcast a reference update to all peers.

Source

pub fn get_repo_state(&self, key: &str) -> Option<RepoState>

Get repository state summary for a given repo.

Trait Implementations§

Source§

impl Default for ReplicationProtocol

Source§

fn default() -> Self

Returns the “default value” for a type. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more