Skip to content

Commit

Permalink
feat: implementing trickle ice
Browse files Browse the repository at this point in the history
  • Loading branch information
rprata committed Apr 22, 2022
1 parent f08956b commit 39dee70
Showing 1 changed file with 40 additions and 6 deletions.
46 changes: 40 additions & 6 deletions src/aioice/ice.py
Original file line number Diff line number Diff line change
Expand Up @@ -296,6 +296,7 @@ def __init__(
turn_transport: str = "udp",
use_ipv4: bool = True,
use_ipv6: bool = True,
use_trickle_ice: bool = False,
) -> None:
self.ice_controlling = ice_controlling
#: Local username, automatically set to a random value.
Expand Down Expand Up @@ -341,6 +342,8 @@ def __init__(
self._use_ipv4 = use_ipv4
self._use_ipv6 = use_ipv6

self._use_trickle_ice = use_trickle_ice

@property
def local_candidates(self) -> List[Candidate]:
"""
Expand Down Expand Up @@ -843,9 +846,9 @@ def _find_pair(
return pair
return None

async def get_component_candidates(
self, component: int, addresses: List[str], timeout: int = 5
) -> List[Candidate]:
async def _get_host_candidates(
self, component: int, addresses: List[str]
) -> Tuple[List[Candidate], List[StunProtocol]]:
candidates = []
loop = asyncio.get_event_loop()

Expand Down Expand Up @@ -882,7 +885,13 @@ async def get_component_candidates(
candidates.append(protocol.local_candidate)
self._protocols += host_protocols

# query STUN server for server-reflexive candidates (IPv4 only)
return candidates, host_protocols

async def _query_stun_server(
self, host_protocols: List[StunProtocol], timeout: int = 5
) -> List[Candidate]:
candidates = []

if self.stun_server:
tasks = []
for protocol in host_protocols:
Expand All @@ -899,8 +908,11 @@ async def get_component_candidates(
]
for task in pending:
task.cancel()
return candidates

async def _connect_turn_server(self, component: int) -> Optional[Candidate]:
candidate = None

# connect to TURN server
if self.turn_server:
# create transport
_, protocol = await turn.create_turn_endpoint(
Expand Down Expand Up @@ -928,7 +940,29 @@ async def get_component_candidates(
related_address=related_address[0],
related_port=related_address[1],
)
candidates.append(protocol.local_candidate)
candidate = protocol.local_candidate
return candidate

async def get_component_candidates(
self, component: int, addresses: List[str], timeout: int = 5
) -> List[Candidate]:
candidates = []

host_candidates, host_protocols = await self._get_host_candidates(
component, addresses
)
candidates += host_candidates

# query STUN server for server-reflexive candidates (IPv4 only)
srflx_candidates = await self._query_stun_server(
host_protocols=host_protocols, timeout=timeout
)
candidates += srflx_candidates

# connect to TURN server
relay_candidate = await self._connect_turn_server(component=component)
if relay_candidate:
candidates.append(relay_candidate)

return candidates

Expand Down

0 comments on commit 39dee70

Please sign in to comment.