Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: stun protocol & stun connection #9

Merged
merged 44 commits into from
May 24, 2024
Merged
Changes from 1 commit
Commits
Show all changes
44 commits
Select commit Hold shift + click to select a range
a53c04f
feat: stun protocol & stun connection
lchenut Mar 8, 2024
6778672
rename getResponse into getPong and test it
lchenut Mar 15, 2024
7be3d0a
add Username attribute
lchenut Mar 15, 2024
f4ca113
genUfrag procedure
lchenut Mar 15, 2024
81a2a51
Add generateRandomSeq to generate a transaction id
lchenut Mar 21, 2024
52296d1
First draft of getPing
lchenut Mar 21, 2024
2b70ad7
Merge remote-tracking branch 'origin/master' into stun-protocol
lchenut Apr 2, 2024
50fde87
Use UdpPacketInfo tuple
lchenut Apr 2, 2024
82203f2
Change closing debug message
lchenut Apr 2, 2024
fa5d674
Add proper exception tracking
lchenut Apr 2, 2024
3d070b5
Change StunConn init behavior
lchenut Apr 2, 2024
762acd8
Add a last UdpPacketInfo
lchenut Apr 2, 2024
5ce6796
Add comments
lchenut Apr 2, 2024
5e9a335
refactor: change connection management
lchenut Apr 5, 2024
832a343
Add a lot of comments/Finish refactor
lchenut Apr 11, 2024
18e302b
Add copyright headers on test files
lchenut Apr 15, 2024
7eb2940
simplify newRng proc for testing
lchenut Apr 15, 2024
f075c40
add exception tracking for stun transport asynchronous proc
lchenut Apr 15, 2024
5100b40
remove ping/pong example building in the ci
lchenut Apr 15, 2024
5c3afe1
rename getPong test
lchenut Apr 15, 2024
4660ac0
remove maximum connections
lchenut Apr 17, 2024
7c36e98
Add ICE stun attributes
lchenut Apr 23, 2024
cf84596
Stun rework
lchenut Apr 26, 2024
b22d6a5
feat: getBindingRequest
lchenut Apr 26, 2024
aada110
fix oversight & add comments
lchenut Apr 26, 2024
9e95f56
Test rework
lchenut Apr 26, 2024
bdf32d9
Adds continue in stunMessageHandler loop
lchenut Apr 29, 2024
6f2dae5
remove `doAssert(false)` from Stun.connect()
lchenut Apr 29, 2024
bccc27f
Update TODO
lchenut Apr 29, 2024
47319e4
fix comment typo
lchenut Apr 29, 2024
9508b79
fix: test lacking precision
lchenut Apr 30, 2024
65bbfba
docs: add StunConn.init() comments
lchenut Apr 30, 2024
d0c4013
chore: make teststun more readable
lchenut Apr 30, 2024
559c857
feat: use withValue instead of getOrDefault in Stun.connect()
lchenut Apr 30, 2024
735cde8
feat: add check if Fingerprint is valid
lchenut Apr 30, 2024
11b4d42
refactor: getAttribute and username/password provider
lchenut May 21, 2024
3a5b206
chore: removes genUfrag, should be in libp2p instead
lchenut May 23, 2024
955b1d2
chore: remove redundant test
lchenut May 24, 2024
285d7fb
chore: change warn log to debug
lchenut May 24, 2024
ea2e56a
docs: update getBindingResponse/Request comments
lchenut May 24, 2024
a1a1acc
chore: renames init into new
lchenut May 24, 2024
0aab612
fix: compilation warnings
lchenut May 24, 2024
f3af915
chore: change closed line to be at the end of the close procedure
lchenut May 24, 2024
96749ab
feat: limit queues size
lchenut May 24, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 1 addition & 8 deletions webrtc/stun/stun_transport.nim
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,6 @@ import stun_connection, stun_protocol, ../udp_connection
logScope:
topics = "webrtc stun stun_transport"

const
StunMaxConnections = 1024
StunMaxPendingConnections = 256

type
Stun* = ref object
connections: Table[TransportAddress, StunConn]
Expand Down Expand Up @@ -65,9 +61,6 @@ proc stunReadLoop(self: Stun) {.async: (raises: [CancelledError]).} =
let (buf, raddr) = await self.conn.read()
var stunConn: StunConn
if not self.connections.hasKey(raddr):
if self.connections.len() >= StunMaxConnections:
trace "Try to accept a connection while full"
continue
stunConn = StunConn.init(self.conn, raddr, true)
self.connections[raddr] = stunConn
await self.pendingConn.addLast(stunConn)
Expand Down Expand Up @@ -100,5 +93,5 @@ proc init*(
var self = T(conn: conn, rng: rng)
self.rng.generate(self.iceTieBreaker)
self.readingLoop = stunReadLoop()
self.pendingConn = newAsyncQueue[StunConn](StunMaxPendingConnections)
self.pendingConn = newAsyncQueue[StunConn]()
diegomrsantos marked this conversation as resolved.
Show resolved Hide resolved
return self
Loading