Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
S
sfu
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Alain Takoudjou
sfu
Commits
e7f9a8f3
Commit
e7f9a8f3
authored
May 26, 2020
by
Juliusz Chroboczek
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Make downTrack and downConnection into interfaces.
parent
d9f2a936
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
42 additions
and
40 deletions
+42
-40
client.go
client.go
+12
-12
conn.go
conn.go
+29
-27
group.go
group.go
+1
-1
No files found.
client.go
View file @
e7f9a8f3
...
...
@@ -618,7 +618,7 @@ func delUpConn(c *client, id string) bool {
return
true
}
func
getDownConn
(
c
*
client
,
id
string
)
*
d
ownConnection
{
func
getDownConn
(
c
*
client
,
id
string
)
*
rtpD
ownConnection
{
if
c
.
down
==
nil
{
return
nil
}
...
...
@@ -644,7 +644,7 @@ func getConn(c *client, id string) iceConnection {
return
nil
}
func
addDownConn
(
c
*
client
,
id
string
,
remote
*
upConnection
)
(
*
d
ownConnection
,
error
)
{
func
addDownConn
(
c
*
client
,
id
string
,
remote
*
upConnection
)
(
*
rtpD
ownConnection
,
error
)
{
pc
,
err
:=
groups
.
api
.
NewPeerConnection
(
iceConfiguration
())
if
err
!=
nil
{
return
nil
,
err
...
...
@@ -659,9 +659,9 @@ func addDownConn(c *client, id string, remote *upConnection) (*downConnection, e
})
if
c
.
down
==
nil
{
c
.
down
=
make
(
map
[
string
]
*
d
ownConnection
)
c
.
down
=
make
(
map
[
string
]
*
rtpD
ownConnection
)
}
conn
:=
&
d
ownConnection
{
conn
:=
&
rtpD
ownConnection
{
id
:
id
,
client
:
c
,
pc
:
pc
,
...
...
@@ -705,7 +705,7 @@ func delDownConn(c *client, id string) bool {
return
true
}
func
addDownTrack
(
c
*
client
,
conn
*
d
ownConnection
,
remoteTrack
*
upTrack
,
remoteConn
*
upConnection
)
(
*
webrtc
.
RTPSender
,
error
)
{
func
addDownTrack
(
c
*
client
,
conn
*
rtpD
ownConnection
,
remoteTrack
*
upTrack
,
remoteConn
*
upConnection
)
(
*
webrtc
.
RTPSender
,
error
)
{
local
,
err
:=
conn
.
pc
.
NewTrack
(
remoteTrack
.
track
.
PayloadType
(),
remoteTrack
.
track
.
SSRC
(),
...
...
@@ -721,7 +721,7 @@ func addDownTrack(c *client, conn *downConnection, remoteTrack *upTrack, remoteC
return
nil
,
err
}
track
:=
&
d
ownTrack
{
track
:=
&
rtpD
ownTrack
{
track
:
local
,
remote
:
remoteTrack
,
maxLossBitrate
:
new
(
bitrate
),
...
...
@@ -742,7 +742,7 @@ const (
maxLossRate
=
1
<<
30
)
func
(
track
*
d
ownTrack
)
updateRate
(
loss
uint8
,
now
uint64
)
{
func
(
track
*
rtpD
ownTrack
)
updateRate
(
loss
uint8
,
now
uint64
)
{
rate
:=
track
.
maxLossBitrate
.
Get
(
now
)
if
rate
>
maxLossRate
{
// no recent feedback, reset
...
...
@@ -771,7 +771,7 @@ func (track *downTrack) updateRate(loss uint8, now uint64) {
track
.
maxLossBitrate
.
Set
(
rate
,
now
)
}
func
rtcpDownListener
(
conn
*
downConnection
,
track
*
d
ownTrack
,
s
*
webrtc
.
RTPSender
)
{
func
rtcpDownListener
(
conn
*
rtpDownConnection
,
track
*
rtpD
ownTrack
,
s
*
webrtc
.
RTPSender
)
{
for
{
ps
,
err
:=
s
.
ReadRTCP
()
if
err
!=
nil
{
...
...
@@ -820,7 +820,7 @@ func rtcpDownListener(conn *downConnection, track *downTrack, s *webrtc.RTPSende
}
}
func
trackKinds
(
down
*
d
ownConnection
)
(
audio
bool
,
video
bool
)
{
func
trackKinds
(
down
*
rtpD
ownConnection
)
(
audio
bool
,
video
bool
)
{
if
down
.
pc
==
nil
{
return
}
...
...
@@ -926,7 +926,7 @@ func sendNACK(pc *webrtc.PeerConnection, ssrc uint32, first uint16, bitmap uint1
return
pc
.
WriteRTCP
([]
rtcp
.
Packet
{
packet
})
}
func
sendRecovery
(
p
*
rtcp
.
TransportLayerNack
,
track
*
d
ownTrack
)
{
func
sendRecovery
(
p
*
rtcp
.
TransportLayerNack
,
track
*
rtpD
ownTrack
)
{
var
packet
rtp
.
Packet
buf
:=
make
([]
byte
,
packetcache
.
BufSize
)
for
_
,
nack
:=
range
p
.
Nacks
{
...
...
@@ -949,7 +949,7 @@ func sendRecovery(p *rtcp.TransportLayerNack, track *downTrack) {
}
}
func
negotiate
(
c
*
client
,
down
*
d
ownConnection
)
error
{
func
negotiate
(
c
*
client
,
down
*
rtpD
ownConnection
)
error
{
offer
,
err
:=
down
.
pc
.
CreateOffer
(
nil
)
if
err
!=
nil
{
return
err
...
...
@@ -1094,7 +1094,7 @@ func (c *client) isRequested(label string) bool {
return
c
.
requested
[
label
]
!=
0
}
func
addDownConnTracks
(
c
*
client
,
remote
*
upConnection
,
tracks
[]
*
upTrack
)
(
*
d
ownConnection
,
error
)
{
func
addDownConnTracks
(
c
*
client
,
remote
*
upConnection
,
tracks
[]
*
upTrack
)
(
*
rtpD
ownConnection
,
error
)
{
requested
:=
false
for
_
,
t
:=
range
tracks
{
if
c
.
isRequested
(
t
.
label
)
{
...
...
conn.go
View file @
e7f9a8f3
...
...
@@ -33,7 +33,7 @@ type upTrack struct {
writerDone
chan
struct
{}
// closed when the loop dies
mu
sync
.
Mutex
local
[]
*
downTrack
local
[]
downTrack
}
func
(
up
*
upTrack
)
notifyLocal
()
{
...
...
@@ -44,7 +44,7 @@ func (up *upTrack) notifyLocal() {
}
}
func
(
up
*
upTrack
)
addLocal
(
local
*
downTrack
)
{
func
(
up
*
upTrack
)
addLocal
(
local
downTrack
)
{
up
.
mu
.
Lock
()
for
_
,
t
:=
range
up
.
local
{
if
t
==
local
{
...
...
@@ -57,7 +57,7 @@ func (up *upTrack) addLocal(local *downTrack) {
up
.
notifyLocal
()
}
func
(
up
*
upTrack
)
delLocal
(
local
*
downTrack
)
bool
{
func
(
up
*
upTrack
)
delLocal
(
local
downTrack
)
bool
{
up
.
mu
.
Lock
()
for
i
,
l
:=
range
up
.
local
{
if
l
==
local
{
...
...
@@ -71,10 +71,10 @@ func (up *upTrack) delLocal(local *downTrack) bool {
return
false
}
func
(
up
*
upTrack
)
getLocal
()
[]
*
downTrack
{
func
(
up
*
upTrack
)
getLocal
()
[]
downTrack
{
up
.
mu
.
Lock
()
defer
up
.
mu
.
Unlock
()
local
:=
make
([]
*
downTrack
,
len
(
up
.
local
))
local
:=
make
([]
downTrack
,
len
(
up
.
local
))
copy
(
local
,
up
.
local
)
return
local
}
...
...
@@ -102,14 +102,10 @@ type upConnection struct {
iceCandidates
[]
*
webrtc
.
ICECandidateInit
mu
sync
.
Mutex
local
[]
*
downConnection
local
[]
downConnection
}
func
(
up
*
upConnection
)
getPC
()
*
webrtc
.
PeerConnection
{
return
up
.
pc
}
func
(
up
*
upConnection
)
addLocal
(
local
*
downConnection
)
{
func
(
up
*
upConnection
)
addLocal
(
local
downConnection
)
{
up
.
mu
.
Lock
()
defer
up
.
mu
.
Unlock
()
for
_
,
t
:=
range
up
.
local
{
...
...
@@ -121,7 +117,7 @@ func (up *upConnection) addLocal(local *downConnection) {
up
.
local
=
append
(
up
.
local
,
local
)
}
func
(
up
*
upConnection
)
delLocal
(
local
*
downConnection
)
bool
{
func
(
up
*
upConnection
)
delLocal
(
local
downConnection
)
bool
{
up
.
mu
.
Lock
()
defer
up
.
mu
.
Unlock
()
for
i
,
l
:=
range
up
.
local
{
...
...
@@ -133,10 +129,10 @@ func (up *upConnection) delLocal(local *downConnection) bool {
return
false
}
func
(
up
*
upConnection
)
getLocal
()
[]
*
downConnection
{
func
(
up
*
upConnection
)
getLocal
()
[]
downConnection
{
up
.
mu
.
Lock
()
defer
up
.
mu
.
Unlock
()
local
:=
make
([]
*
downConnection
,
len
(
up
.
local
))
local
:=
make
([]
downConnection
,
len
(
up
.
local
))
copy
(
local
,
up
.
local
)
return
local
}
...
...
@@ -239,7 +235,13 @@ func (s *receiverStats) Get(now uint64) (uint8, uint32) {
return
uint8
(
atomic
.
LoadUint32
(
&
s
.
loss
)),
atomic
.
LoadUint32
(
&
s
.
jitter
)
}
type
downTrack
struct
{
type
downTrack
interface
{
WriteRTP
(
packat
*
rtp
.
Packet
)
error
Accumulate
(
bytes
uint32
)
GetMaxBitrate
(
now
uint64
)
uint64
}
type
rtpDownTrack
struct
{
track
*
webrtc
.
Track
remote
*
upTrack
maxLossBitrate
*
bitrate
...
...
@@ -248,15 +250,15 @@ type downTrack struct {
stats
*
receiverStats
}
func
(
down
*
d
ownTrack
)
WriteRTP
(
packet
*
rtp
.
Packet
)
error
{
func
(
down
*
rtpD
ownTrack
)
WriteRTP
(
packet
*
rtp
.
Packet
)
error
{
return
down
.
track
.
WriteRTP
(
packet
)
}
func
(
down
*
d
ownTrack
)
Accumulate
(
bytes
uint32
)
{
func
(
down
*
rtpD
ownTrack
)
Accumulate
(
bytes
uint32
)
{
down
.
rate
.
Add
(
bytes
)
}
func
(
down
*
d
ownTrack
)
GetMaxBitrate
(
now
uint64
)
uint64
{
func
(
down
*
rtpD
ownTrack
)
GetMaxBitrate
(
now
uint64
)
uint64
{
br1
:=
down
.
maxLossBitrate
.
Get
(
now
)
br2
:=
down
.
maxREMBBitrate
.
Get
(
now
)
if
br1
<
br2
{
...
...
@@ -265,24 +267,24 @@ func (down *downTrack) GetMaxBitrate(now uint64) uint64 {
return
br2
}
type
downConnection
struct
{
type
downConnection
interface
{
Close
()
error
}
type
rtpDownConnection
struct
{
id
string
client
*
client
pc
*
webrtc
.
PeerConnection
remote
*
upConnection
tracks
[]
*
d
ownTrack
tracks
[]
*
rtpD
ownTrack
iceCandidates
[]
*
webrtc
.
ICECandidateInit
}
func
(
down
*
d
ownConnection
)
Close
()
error
{
func
(
down
*
rtpD
ownConnection
)
Close
()
error
{
return
down
.
client
.
action
(
delConnAction
{
down
.
id
})
}
func
(
down
*
downConnection
)
getPC
()
*
webrtc
.
PeerConnection
{
return
down
.
pc
}
func
(
down
*
downConnection
)
addICECandidate
(
candidate
*
webrtc
.
ICECandidateInit
)
error
{
func
(
down
*
rtpDownConnection
)
addICECandidate
(
candidate
*
webrtc
.
ICECandidateInit
)
error
{
if
down
.
pc
.
RemoteDescription
()
!=
nil
{
return
down
.
pc
.
AddICECandidate
(
*
candidate
)
}
...
...
@@ -290,7 +292,7 @@ func (down *downConnection) addICECandidate(candidate *webrtc.ICECandidateInit)
return
nil
}
func
(
down
*
d
ownConnection
)
flushICECandidates
()
error
{
func
(
down
*
rtpD
ownConnection
)
flushICECandidates
()
error
{
err
:=
flushICECandidates
(
down
.
pc
,
down
.
iceCandidates
)
down
.
iceCandidates
=
nil
return
err
...
...
group.go
View file @
e7f9a8f3
...
...
@@ -33,7 +33,7 @@ type client struct {
actionCh
chan
interface
{}
mu
sync
.
Mutex
down
map
[
string
]
*
d
ownConnection
down
map
[
string
]
*
rtpD
ownConnection
up
map
[
string
]
*
upConnection
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment