1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
//! Default values used in the relay.

pub use iroh_base::relay_map::{DEFAULT_RELAY_QUIC_PORT, DEFAULT_STUN_PORT};

/// The default HTTP port used by the Relay server.
pub const DEFAULT_HTTP_PORT: u16 = 80;

/// The default HTTPS port used by the Relay server.
pub const DEFAULT_HTTPS_PORT: u16 = 443;

/// The default metrics port used by the Relay server.
pub const DEFAULT_METRICS_PORT: u16 = 9090;

/// Contains all timeouts that we use in `iroh`.
pub(crate) mod timeouts {
    use std::time::Duration;

    /// Timeout used by the relay client while connecting to the relay server,
    /// using `TcpStream::connect`
    pub(crate) const DIAL_NODE_TIMEOUT: Duration = Duration::from_millis(1500);
    /// Timeout for expecting a pong from the relay server
    pub(crate) const PING_TIMEOUT: Duration = Duration::from_secs(5);
    /// Timeout for the entire relay connection, which includes dns, dialing
    /// the server, upgrading the connection, and completing the handshake
    pub(crate) const CONNECT_TIMEOUT: Duration = Duration::from_secs(10);
    /// Timeout for our async dns resolver
    pub(crate) const DNS_TIMEOUT: Duration = Duration::from_secs(1);

    /// Maximum time the client will wait to receive on the connection, since
    /// the last message. Longer than this time and the client will consider
    /// the connection dead.
    pub(crate) const CLIENT_RECV_TIMEOUT: Duration = Duration::from_secs(120);

    /// Maximum time the server will attempt to get a successful write to the connection.
    #[cfg(feature = "server")]
    #[cfg_attr(iroh_docsrs, doc(cfg(feature = "server")))]
    pub(crate) const SERVER_WRITE_TIMEOUT: Duration = Duration::from_secs(2);
}