Struct trust_dns_proto::DnsFuture [] [src]

#[must_use = "futures do nothing unless polled"]
pub struct DnsFuture<S, E, MF> where
    S: Stream<Item = Vec<u8>, Error = Error>,
    E: FromProtoError,
    MF: MessageFinalizer
{ /* fields omitted */ }

A DNS Client implemented over futures-rs.

This Client is generic and capable of wrapping UDP, TCP, and other underlying DNS protocol implementations.

Methods

impl<S, E, MF> DnsFuture<S, E, MF> where
    S: Stream<Item = Vec<u8>, Error = Error> + 'static,
    E: FromProtoError + 'static,
    MF: MessageFinalizer + 'static, 
[src]

[src]

Spawns a new DnsFuture Stream. This uses a default timeout of 5 seconds for all requests.

Arguments

  • stream - A stream of bytes that can be used to send/receive DNS messages (see TcpClientStream or UdpClientStream)
  • loop_handle - A Handle to the Tokio reactor Core, this is the Core on which the the Stream will be spawned
  • stream_handle - The handle for the stream on which bytes can be sent/received.
  • signer - An optional signer for requests, needed for Updates with Sig0, otherwise not needed

[src]

Spawns a new DnsFuture Stream.

Arguments

  • stream - A stream of bytes that can be used to send/receive DNS messages (see TcpClientStream or UdpClientStream)
  • loop_handle - A Handle to the Tokio reactor Core, this is the Core on which the the Stream will be spawned
  • timeout_duration - All requests may fail due to lack of response, this is the time to wait for a response before canceling the request.
  • stream_handle - The handle for the stream on which bytes can be sent/received.
  • signer - An optional signer for requests, needed for Updates with Sig0, otherwise not needed

Trait Implementations

impl<S, E, MF> Future for DnsFuture<S, E, MF> where
    S: Stream<Item = Vec<u8>, Error = Error> + 'static,
    E: FromProtoError + 'static,
    MF: MessageFinalizer + 'static, 
[src]

The type of value that this future will resolved with if it is successful. Read more

The type of error that this future will resolve with if it fails in a normal fashion. Read more

[src]

Query this future to see if its value has become available, registering interest if it is not. Read more

[src]

Block the current thread until this future is resolved. Read more

[src]

Map this future's result to a different type, returning a new future of the resulting type. Read more

[src]

Map this future's error to a different error, returning a new future. Read more

[src]

Map this future's error to any error implementing From for this future's Error, returning a new future. Read more

[src]

Chain on a computation for when a future finished, passing the result of the future to the provided closure f. Read more

[src]

Execute another future after this one has resolved successfully. Read more

[src]

Execute another future if this one resolves with an error. Read more

[src]

Waits for either one of two futures to complete. Read more

[src]

Waits for either one of two differently-typed futures to complete. Read more

[src]

Joins the result of two futures, waiting for them both to complete. Read more

[src]

Same as join, but with more futures.

[src]

Same as join, but with more futures.

[src]

Same as join, but with more futures.

[src]

Convert this future into a single element stream. Read more

[src]

Flatten the execution of this future when the successful result of this future is itself another future. Read more

[src]

Flatten the execution of this future when the successful result of this future is a stream. Read more

[src]

Fuse a future such that poll will never again be called once it has completed. Read more

[src]

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

[src]

Catches unwinding panics while polling the future. Read more

[src]

Create a cloneable handle to this future where all handles will resolve to the same result. Read more

Auto Trait Implementations

impl<S, E, MF> !Send for DnsFuture<S, E, MF>

impl<S, E, MF> !Sync for DnsFuture<S, E, MF>