# ExICE
[data:image/s3,"s3://crabby-images/cf718/cf718547d7b1b20d35ee2e63745f9f40c4562b87" alt="Hex.pm"](https://hex.pm/packages/ex_ice)
[data:image/s3,"s3://crabby-images/d0296/d0296d36ed2e8cc8f91b7ae5c6fea1e4ff6c28e4" alt="API Docs"](https://hexdocs.pm/ex_ice)
[data:image/s3,"s3://crabby-images/f5c7d/f5c7d674ff14c69639db5d4bcf2ad445c61f715f" alt="CI"](https://github.com/elixir-webrtc/ex_ice/actions/workflows/ci.yml)
[data:image/s3,"s3://crabby-images/351c0/351c0da98d317997f3c0202b1ee71be705f6cb41" alt="codecov"](https://codecov.io/gh/elixir-webrtc/ex_ice)
Trickle ICE implementation.
Implements:
* [RFC 8445](https://datatracker.ietf.org/doc/html/rfc8445)
* [RFC 8838](https://datatracker.ietf.org/doc/html/rfc8838)
* [ICE mDNS](https://datatracker.ietf.org/doc/html/draft-ietf-rtcweb-mdns-ice-candidates) (client side)
## Features
* compatible both with aggressive and regular nomination
* role conflict resolution
* supports host, prflx, srflx and relay candidates
* transaction pacing
* keepalives (both incoming and outgoing) on valid and selected pairs
* mDNS client
## Limitations
* there is always only one stream and one component -
we don't plan to add support for multiple streams and components
as WebRTC multiplexes traffic on a single socket but PRs are welcomed
## Installation
```elixir
def deps do
[
{:ex_ice, "~> 0.9.4"}
]
end
```
## Usage
See our [example](https://github.com/elixir-webrtc/ex_ice/tree/master/example),
[integration tests](https://github.com/elixir-webrtc/ex_ice/blob/master/test/integration/p2p_test.exs),
and [documentation](https://hexdocs.pm/ex_ice/readme.html) for usage examples.
We also provide a very simple [signalling server](https://github.com/elixir-webrtc/ex_ice/tree/master/signalling_server), which can be used
to connect two ICE agents.