[][src]Struct kad::dht::Dht

pub struct Dht<Id, Info, Data, ReqId, Conn, Table, Store, Ctx> { /* fields omitted */ }

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]

pub fn new(
    id: Id,
    config: Config,
    table: Table,
    conn_mgr: Conn,
    datastore: Store
) -> Dht<Id, Info, Data, ReqId, Conn, Table, Store, Ctx>
[src]

pub fn connect(
    &mut self,
    target: Entry<Id, Info>,
    ctx: Ctx
) -> impl Future<Item = (), Error = Error>
[src]

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]

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]

Find a value from the DHT

pub fn store(
    &mut self,
    target: Id,
    data: Vec<Data>,
    ctx: Ctx
) -> impl Future<Item = (), Error = Error>
[src]

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]

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]

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]

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

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]

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]

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]

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]

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]

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]

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]

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]

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]

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]

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]

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]

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]

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]

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]

Do something with the item of a future, passing it on. Read more

default fn catch_unwind(self) -> CatchUnwind<Self> where
    Self: UnwindSafe
[src]

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

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

Blanket Implementations

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

impl<T> From for T[src]

impl<T, U> Into for T where
    U: From<T>, 
[src]

impl<T, U> TryFrom for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T> Borrow for T where
    T: ?Sized
[src]

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> BorrowMut for T where
    T: ?Sized
[src]

impl<T, U> TryInto for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.

impl<F> IntoFuture for F where
    F: Future
[src]

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.

impl<F> FutureExt for F where
    F: Future
[src]

default fn timeout(self, dur: Duration) -> Timeout<Self> where
    Self::Error: From<Error>, 
[src]

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]

Creates a new future which will resolve no later than at specified. Read more