[−][src]Struct kad::dht::Dht
Methods
impl<Id, Info, Data, ReqId, Conn, Table, Store, Ctx> Dht<Id, Info, Data, ReqId, Conn, Table, Store, Ctx> where
Id: DatabaseId + Clone + Send + 'static,
Info: PartialEq + Clone + Debug + Send + 'static,
Data: PartialEq + Clone + Send + Debug + 'static,
ReqId: RequestId + Clone + Send + 'static,
Conn: Connector<ReqId, Entry<Id, Info>, Request<Id, Data>, Response<Id, Info, Data>, Error, Ctx> + Clone + Send + 'static,
Table: NodeTable<Id, Info> + Clone + Sync + Send + 'static,
Store: Datastore<Id, Data> + Clone + Sync + Send + 'static,
Ctx: Clone + Debug + PartialEq + Send + 'static,
[src]
Id: DatabaseId + Clone + Send + 'static,
Info: PartialEq + Clone + Debug + Send + 'static,
Data: PartialEq + Clone + Send + Debug + 'static,
ReqId: RequestId + Clone + Send + 'static,
Conn: Connector<ReqId, Entry<Id, Info>, Request<Id, Data>, Response<Id, Info, Data>, Error, Ctx> + Clone + Send + 'static,
Table: NodeTable<Id, Info> + Clone + Sync + Send + 'static,
Store: Datastore<Id, Data> + Clone + Sync + Send + 'static,
Ctx: Clone + Debug + PartialEq + Send + 'static,
pub fn new(
id: Id,
config: Config,
table: Table,
conn_mgr: Conn,
datastore: Store
) -> Dht<Id, Info, Data, ReqId, Conn, Table, Store, Ctx>
[src]
id: Id,
config: Config,
table: Table,
conn_mgr: Conn,
datastore: Store
) -> Dht<Id, Info, Data, ReqId, Conn, Table, Store, Ctx>
pub fn connect(
&mut self,
target: Entry<Id, Info>,
ctx: Ctx
) -> impl Future<Item = (), Error = Error>
[src]
&mut self,
target: Entry<Id, Info>,
ctx: Ctx
) -> impl Future<Item = (), Error = Error>
Connect to a known node This is used for bootstrapping onto the DHT
pub fn lookup(
&mut self,
target: Id,
ctx: Ctx
) -> impl Future<Item = Entry<Id, Info>, Error = Error>
[src]
&mut self,
target: Id,
ctx: Ctx
) -> impl Future<Item = Entry<Id, Info>, Error = Error>
Look up a node in the database by Id
pub fn find(
&mut self,
target: Id,
ctx: Ctx
) -> impl Future<Item = Vec<Data>, Error = Error>
[src]
&mut self,
target: Id,
ctx: Ctx
) -> impl Future<Item = Vec<Data>, Error = Error>
Find a value from the DHT
pub fn store(
&mut self,
target: Id,
data: Vec<Data>,
ctx: Ctx
) -> impl Future<Item = (), Error = Error>
[src]
&mut self,
target: Id,
data: Vec<Data>,
ctx: Ctx
) -> impl Future<Item = (), Error = Error>
Store a value in the DHT
pub fn refresh(&mut self) -> impl Future<Item = (), Error = Error>
[src]
Refresh node table
pub fn receive(
&mut self,
from: &Entry<Id, Info>,
req: &Request<Id, Data>
) -> impl Future<Item = Response<Id, Info, Data>, Error = Error>
[src]
&mut self,
from: &Entry<Id, Info>,
req: &Request<Id, Data>
) -> impl Future<Item = Response<Id, Info, Data>, Error = Error>
Receive and reply to requests
pub fn search(
&mut self,
id: Id,
op: Operation,
seed: &[Entry<Id, Info>],
ctx: Ctx
) -> impl Future<Item = Search<Id, Info, Data, Table, Conn, ReqId, Ctx>, Error = Error>
[src]
&mut self,
id: Id,
op: Operation,
seed: &[Entry<Id, Info>],
ctx: Ctx
) -> impl Future<Item = Search<Id, Info, Data, Table, Conn, ReqId, Ctx>, Error = Error>
Create a basic search using the DHT This is provided for integration of the Dht with other components
Trait Implementations
impl<Id: Clone, Info: Clone, Data: Clone, ReqId: Clone, Conn: Clone, Table: Clone, Store: Clone, Ctx: Clone> Clone for Dht<Id, Info, Data, ReqId, Conn, Table, Store, Ctx>
[src]
fn clone(&self) -> Dht<Id, Info, Data, ReqId, Conn, Table, Store, Ctx>
[src]
default fn clone_from(&mut self, source: &Self)
1.0.0[src]
Performs copy-assignment from source
. Read more
impl<Id, Info, Data, ReqId, Conn, Table, Store, Ctx> Future for Dht<Id, Info, Data, ReqId, Conn, Table, Store, Ctx>
[src]
Stream trait implemented to allow polling on dht object
type Item = ()
The type of value that this future will resolved with if it is successful. Read more
type Error = ()
The type of error that this future will resolve with if it fails in a normal fashion. Read more
fn poll(&mut self) -> Poll<Self::Item, Self::Error>
[src]
default fn wait(self) -> Result<Self::Item, Self::Error>
[src]
Block the current thread until this future is resolved. Read more
default fn map<F, U>(self, f: F) -> Map<Self, F> where
F: FnOnce(Self::Item) -> U,
[src]
F: FnOnce(Self::Item) -> U,
Map this future's result to a different type, returning a new future of the resulting type. Read more
default fn map_err<F, E>(self, f: F) -> MapErr<Self, F> where
F: FnOnce(Self::Error) -> E,
[src]
F: FnOnce(Self::Error) -> E,
Map this future's error to a different error, returning a new future. Read more
default fn from_err<E>(self) -> FromErr<Self, E> where
E: From<Self::Error>,
[src]
E: From<Self::Error>,
Map this future's error to any error implementing From
for this future's Error
, returning a new future. Read more
default fn then<F, B>(self, f: F) -> Then<Self, B, F> where
B: IntoFuture,
F: FnOnce(Result<Self::Item, Self::Error>) -> B,
[src]
B: IntoFuture,
F: FnOnce(Result<Self::Item, Self::Error>) -> B,
Chain on a computation for when a future finished, passing the result of the future to the provided closure f
. Read more
default fn and_then<F, B>(self, f: F) -> AndThen<Self, B, F> where
B: IntoFuture<Error = Self::Error>,
F: FnOnce(Self::Item) -> B,
[src]
B: IntoFuture<Error = Self::Error>,
F: FnOnce(Self::Item) -> B,
Execute another future after this one has resolved successfully. Read more
default fn or_else<F, B>(self, f: F) -> OrElse<Self, B, F> where
B: IntoFuture<Item = Self::Item>,
F: FnOnce(Self::Error) -> B,
[src]
B: IntoFuture<Item = Self::Item>,
F: FnOnce(Self::Error) -> B,
Execute another future if this one resolves with an error. Read more
default fn select<B>(self, other: B) -> Select<Self, <B as IntoFuture>::Future> where
B: IntoFuture<Item = Self::Item, Error = Self::Error>,
[src]
B: IntoFuture<Item = Self::Item, Error = Self::Error>,
Waits for either one of two futures to complete. Read more
default fn select2<B>(
self,
other: B
) -> Select2<Self, <B as IntoFuture>::Future> where
B: IntoFuture,
[src]
self,
other: B
) -> Select2<Self, <B as IntoFuture>::Future> where
B: IntoFuture,
Waits for either one of two differently-typed futures to complete. Read more
default fn join<B>(self, other: B) -> Join<Self, <B as IntoFuture>::Future> where
B: IntoFuture<Error = Self::Error>,
[src]
B: IntoFuture<Error = Self::Error>,
Joins the result of two futures, waiting for them both to complete. Read more
default fn join3<B, C>(
self,
b: B,
c: C
) -> Join3<Self, <B as IntoFuture>::Future, <C as IntoFuture>::Future> where
B: IntoFuture<Error = Self::Error>,
C: IntoFuture<Error = Self::Error>,
[src]
self,
b: B,
c: C
) -> Join3<Self, <B as IntoFuture>::Future, <C as IntoFuture>::Future> where
B: IntoFuture<Error = Self::Error>,
C: IntoFuture<Error = Self::Error>,
Same as join
, but with more futures.
default fn join4<B, C, D>(
self,
b: B,
c: C,
d: D
) -> Join4<Self, <B as IntoFuture>::Future, <C as IntoFuture>::Future, <D as IntoFuture>::Future> where
B: IntoFuture<Error = Self::Error>,
C: IntoFuture<Error = Self::Error>,
D: IntoFuture<Error = Self::Error>,
[src]
self,
b: B,
c: C,
d: D
) -> Join4<Self, <B as IntoFuture>::Future, <C as IntoFuture>::Future, <D as IntoFuture>::Future> where
B: IntoFuture<Error = Self::Error>,
C: IntoFuture<Error = Self::Error>,
D: IntoFuture<Error = Self::Error>,
Same as join
, but with more futures.
default fn join5<B, C, D, E>(
self,
b: B,
c: C,
d: D,
e: E
) -> Join5<Self, <B as IntoFuture>::Future, <C as IntoFuture>::Future, <D as IntoFuture>::Future, <E as IntoFuture>::Future> where
B: IntoFuture<Error = Self::Error>,
C: IntoFuture<Error = Self::Error>,
D: IntoFuture<Error = Self::Error>,
E: IntoFuture<Error = Self::Error>,
[src]
self,
b: B,
c: C,
d: D,
e: E
) -> Join5<Self, <B as IntoFuture>::Future, <C as IntoFuture>::Future, <D as IntoFuture>::Future, <E as IntoFuture>::Future> where
B: IntoFuture<Error = Self::Error>,
C: IntoFuture<Error = Self::Error>,
D: IntoFuture<Error = Self::Error>,
E: IntoFuture<Error = Self::Error>,
Same as join
, but with more futures.
default fn into_stream(self) -> IntoStream<Self>
[src]
Convert this future into a single element stream. Read more
default fn flatten(self) -> Flatten<Self> where
Self::Item: IntoFuture,
<Self::Item as IntoFuture>::Error: From<Self::Error>,
[src]
Self::Item: IntoFuture,
<Self::Item as IntoFuture>::Error: From<Self::Error>,
Flatten the execution of this future when the successful result of this future is itself another future. Read more
default fn flatten_stream(self) -> FlattenStream<Self> where
Self::Item: Stream,
<Self::Item as Stream>::Error == Self::Error,
[src]
Self::Item: Stream,
<Self::Item as Stream>::Error == Self::Error,
Flatten the execution of this future when the successful result of this future is a stream. Read more
default fn fuse(self) -> Fuse<Self>
[src]
Fuse a future such that poll
will never again be called once it has completed. Read more
default fn inspect<F>(self, f: F) -> Inspect<Self, F> where
F: FnOnce(&Self::Item),
[src]
F: FnOnce(&Self::Item),
Do something with the item of a future, passing it on. Read more
default fn catch_unwind(self) -> CatchUnwind<Self> where
Self: UnwindSafe,
[src]
Self: UnwindSafe,
Catches unwinding panics while polling the future. Read more
default fn shared(self) -> Shared<Self>
[src]
Create a cloneable handle to this future where all handles will resolve to the same result. Read more
Auto Trait Implementations
impl<Id, Info, Data, ReqId, Conn, Table, Store, Ctx> Send for Dht<Id, Info, Data, ReqId, Conn, Table, Store, Ctx> where
Conn: Send,
Ctx: Send,
Data: Send,
Id: Send,
Info: Send,
ReqId: Send,
Store: Send,
Table: Send,
Conn: Send,
Ctx: Send,
Data: Send,
Id: Send,
Info: Send,
ReqId: Send,
Store: Send,
Table: Send,
impl<Id, Info, Data, ReqId, Conn, Table, Store, Ctx> Sync for Dht<Id, Info, Data, ReqId, Conn, Table, Store, Ctx> where
Conn: Sync,
Ctx: Sync,
Data: Sync,
Id: Sync,
Info: Sync,
ReqId: Sync,
Store: Sync,
Table: Sync,
Conn: Sync,
Ctx: Sync,
Data: Sync,
Id: Sync,
Info: Sync,
ReqId: Sync,
Store: Sync,
Table: Sync,
Blanket Implementations
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
impl<T> From for T
[src]
impl<T, U> Into for T where
U: From<T>,
[src]
U: From<T>,
impl<T, U> TryFrom for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T> Borrow for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> BorrowMut for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T, U> TryInto for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<F> IntoFuture for F where
F: Future,
[src]
F: Future,
type Future = F
The future that this type can be converted into.
type Item = <F as Future>::Item
The item that the future may resolve with.
type Error = <F as Future>::Error
The error that the future may resolve with.
fn into_future(self) -> F
[src]
impl<F> FutureExt for F where
F: Future,
[src]
F: Future,
default fn timeout(self, dur: Duration) -> Timeout<Self> where
Self::Error: From<Error>,
[src]
Self::Error: From<Error>,
Creates a new future which will take at most dur
time to resolve from the point at which this method is called. Read more
default fn timeout_at(self, at: Instant) -> Timeout<Self> where
Self::Error: From<Error>,
[src]
Self::Error: From<Error>,
Creates a new future which will resolve no later than at
specified. Read more