stun-proto

Crates.iostun-proto
lib.rsstun-proto
version1.0.0-alpha4
created_at2024-06-16 12:19:38.753809+00
updated_at2025-09-23 01:15:59.863854+00
descriptionSTUN protocol in a sans-IO fashion
homepage
repositoryhttps://github.com/ystreet/stun-proto
max_upload_size
id1273492
size105,900
Matthew Waters (ystreet)

documentation

https://docs.rs/stun-proto

README

Build status codecov Dependencies crates.io docs.rs

stun-proto

Repository containing a sans-IO implementation of the STUN (RFC5389/RFC8489) protocol written in the Rust programming language.

Why sans-io?

A couple of reasons: reusability, and testability.

Without being bogged down in the details of how IO happens, the same sans-IO implementation can be used without prescribing the IO pattern that an application must follow. Instead, the application (or parent library) has much more freedom in how bytes are transferred between peers. It's also possible to us a sans-IO library in either a synchronous or within an asynchronous runtime.

sans-IO also allows easy testing of any specific state the sans-IO implementation might find itself in. Combined with a comprehensive test-suite, this provides assurance that the implementation behaves as expected under all circumstances.

For other examples of sans-IO implementations, take a look at:

Relevant standards

  • RFC3489: STUN - Simple Traversal of User Datagram Protocol (UDP) Through Network Address Translators (NATs)
  • RFC5389: Session Traversal Utilities for NAT (STUN)
  • RFC5769: Test Vectors for Session Traversal Utilities for NAT (STUN)
  • RFC8489: Session Traversal Utilities for NAT (STUN)

If you are looking for an implementation of a TURN client, have a look at turn-client-proto. If you are looking for an implementation of a TURN server, have a look at turn-server-proto. Both turn-client-proto and turn-server-proto aim to implement the following RFCs.

  • RFC5766: Traversal Using Relays around NAT (TURN): Relay Extensions to Session Traversal Utilities for NAT (STUN)
  • RFC6062: Traversal Using Relays around NAT (TURN) Extensions for TCP Allocations
  • RFC6156: Traversal Using Relays around NAT (TURN) Extension for IPv6
  • RFC8656: Traversal Using Relays around NAT (TURN): Relay Extensions to Session Traversal Utilities for NAT (STUN)

If you are looking for an implementation of ICE, have a look at rice-proto which aims to implement the following RFCs.

  • RFC5245: Interactive Connectivity Establishment (ICE): A Protocol for Network Address Translator (NAT) Traversal for Offer/Answer Protocols
  • RFC8445: Interactive Connectivity Establishment (ICE): A Protocol for Network Address Translator (NAT) Traversal
Commit count: 203

cargo fmt