macula_relay_registry (macula v0.20.5)
View SourceDistributed Relay Registry.
Tracks peers that can serve as relay nodes for NAT traversal. Peers with public IPs or NATs that allow incoming connections can register as relay-capable.
Relay Selection Criteria: - Peer must have public IP or full-cone NAT - Lower latency to requesting peer preferred - Load balancing across available relays - Geographic proximity (via RTT estimation)
Registry Storage: - Local ETS for fast lookup - DHT for distributed discovery - TTL-based cleanup for stale entries
Usage: register(NodeId, Endpoint) to register as relay-capable, find_relay(TargetNodeId) to find best relay for a target.
Summary
Functions
Find best relay for connecting to a target.
Find relay with options.
Get count of available relays.
Get all registered relays.
Check if a node is registered as relay.
Register current node as relay-capable.
Register as relay with options. Options: capacity - Maximum concurrent relay connections (default: 100)
Start the relay registry server.
Unregister as relay.
Types
-type find_opts() :: #{max_results => pos_integer(), exclude => [binary()], max_latency_ms => non_neg_integer()}.
-type relay_info() :: #{node_id := binary(), endpoint := {binary() | string(), inet:port_number()}, capacity := non_neg_integer(), current_load := non_neg_integer(), latency_ms => non_neg_integer(), registered_at := integer(), expires_at := integer()}.
Functions
-spec find_relay(binary()) -> {ok, relay_info()} | {error, no_relays_available}.
Find best relay for connecting to a target.
-spec find_relay(binary(), find_opts()) -> {ok, relay_info()} | {error, no_relays_available}.
Find relay with options.
-spec get_relay_count() -> non_neg_integer().
Get count of available relays.
-spec get_relays() -> [relay_info()].
Get all registered relays.
Check if a node is registered as relay.
-spec register(binary(), {binary() | string(), inet:port_number()}) -> ok | {error, term()}.
Register current node as relay-capable.
Register as relay with options. Options: capacity - Maximum concurrent relay connections (default: 100)
Start the relay registry server.
-spec unregister(binary()) -> ok.
Unregister as relay.