Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
Z
ZLMediaKit
概览
Overview
Details
Activity
Cycle Analytics
版本库
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
问题
0
Issues
0
列表
Board
标记
里程碑
合并请求
0
Merge Requests
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
Snippets
成员
Collapse sidebar
Close sidebar
活动
图像
聊天
创建新问题
作业
提交
Issue Boards
Open sidebar
张翔宇
ZLMediaKit
Commits
7ba44d1a
Commit
7ba44d1a
authored
Sep 10, 2021
by
ziyue
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
webrtc单端口模式支持线程安全,支持链接迁移
parent
c025b509
隐藏空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
55 行增加
和
27 行删除
+55
-27
3rdpart/ZLToolKit
+1
-1
server/main.cpp
+11
-0
webrtc/WebRtcSession.cpp
+40
-22
webrtc/WebRtcSession.h
+3
-4
没有找到文件。
ZLToolKit
@
b8e06622
Subproject commit
a827f0bdcb4221c19ab1a243ebd1f01fa7dc50f
2
Subproject commit
b8e066222b757a2c11b5e44c49ef6982acb95fe
2
server/main.cpp
查看文件 @
7ba44d1a
...
...
@@ -309,6 +309,17 @@ int start_main(int argc,char *argv[]) {
#if defined(ENABLE_WEBRTC)
//webrtc udp服务器
UdpServer
::
Ptr
rtcSrv
=
std
::
make_shared
<
UdpServer
>
();
rtcSrv
->
setOnCreateSocket
([](
const
EventPoller
::
Ptr
&
poller
,
const
Buffer
::
Ptr
&
buf
,
struct
sockaddr
*
,
int
)
{
if
(
!
buf
)
{
return
Socket
::
createSocket
(
poller
,
false
);
}
auto
new_poller
=
WebRtcSession
::
getPoller
(
buf
);
if
(
!
new_poller
)
{
//该数据对应的webrtc对象未找到,丢弃之
return
Socket
::
Ptr
();
}
return
Socket
::
createSocket
(
new_poller
,
false
);
});
uint16_t
rtcPort
=
mINI
::
Instance
()[
RTC
::
kPort
];
#endif//defined(ENABLE_WEBRTC)
...
...
webrtc/WebRtcSession.cpp
查看文件 @
7ba44d1a
...
...
@@ -21,26 +21,54 @@ WebRtcSession::~WebRtcSession() {
InfoP
(
this
);
}
static
string
getUserName
(
const
Buffer
::
Ptr
&
buffer
)
{
auto
buf
=
buffer
->
data
();
auto
len
=
buffer
->
size
();
if
(
!
RTC
::
StunPacket
::
IsStun
((
const
uint8_t
*
)
buf
,
len
))
{
return
""
;
}
std
::
unique_ptr
<
RTC
::
StunPacket
>
packet
(
RTC
::
StunPacket
::
Parse
((
const
uint8_t
*
)
buf
,
len
));
if
(
!
packet
)
{
return
""
;
}
if
(
packet
->
GetClass
()
!=
RTC
::
StunPacket
::
Class
::
REQUEST
||
packet
->
GetMethod
()
!=
RTC
::
StunPacket
::
Method
::
BINDING
)
{
return
""
;
}
//收到binding request请求
auto
vec
=
split
(
packet
->
GetUsername
(),
":"
);
return
vec
[
0
];
}
EventPoller
::
Ptr
WebRtcSession
::
getPoller
(
const
Buffer
::
Ptr
&
buffer
)
{
auto
user_name
=
getUserName
(
buffer
);
if
(
user_name
.
empty
())
{
return
nullptr
;
}
auto
ret
=
WebRtcTransportImp
::
getTransport
(
user_name
);
return
ret
?
ret
->
getPoller
()
:
nullptr
;
}
void
WebRtcSession
::
onRecv
(
const
Buffer
::
Ptr
&
buffer
)
{
auto
buf
=
buffer
->
data
();
auto
len
=
buffer
->
size
();
if
(
!
_transport
&&
RTC
::
StunPacket
::
IsStun
((
const
uint8_t
*
)
buf
,
len
))
{
std
::
unique_ptr
<
RTC
::
StunPacket
>
packet
(
RTC
::
StunPacket
::
Parse
((
const
uint8_t
*
)
buf
,
len
));
if
(
!
packet
)
{
WarnL
<<
"parse stun error"
;
if
(
!
_transport
)
{
auto
user_name
=
getUserName
(
buffer
);
if
(
user_name
.
empty
())
{
//逻辑分支不太可能走到这里
WarnL
<<
user_name
;
return
;
}
if
(
packet
->
GetClass
()
==
RTC
::
StunPacket
::
Class
::
REQUEST
&&
packet
->
GetMethod
()
==
RTC
::
StunPacket
::
Method
::
BINDING
)
{
//收到binding request请求
_transport
=
createTransport
(
packet
->
GetUsername
());
_transport
=
WebRtcTransportImp
::
getTransport
(
user_name
);
if
(
!
_transport
)
{
//逻辑分支不太可能走到这里
WarnL
<<
user_name
;
return
;
}
_transport
->
setSession
(
this
);
}
if
(
_transport
)
{
_transport
->
inputSockData
(
buf
,
len
,
&
_peer_addr
);
}
_transport
->
inputSockData
(
buf
,
len
,
&
_peer_addr
);
}
void
WebRtcSession
::
onError
(
const
SockException
&
err
)
{
...
...
@@ -53,13 +81,3 @@ void WebRtcSession::onError(const SockException &err) {
void
WebRtcSession
::
onManager
()
{
}
std
::
shared_ptr
<
WebRtcTransport
>
WebRtcSession
::
createTransport
(
const
string
&
user_name
)
{
if
(
user_name
.
empty
())
{
return
nullptr
;
}
auto
vec
=
split
(
user_name
,
":"
);
auto
ret
=
WebRtcTransportImp
::
getTransport
(
vec
[
0
]);
ret
->
setSession
(
this
);
return
ret
;
}
webrtc/WebRtcSession.h
查看文件 @
7ba44d1a
...
...
@@ -20,6 +20,8 @@ using namespace toolkit;
class
WebRtcSession
:
public
UdpSession
{
public
:
static
EventPoller
::
Ptr
getPoller
(
const
Buffer
::
Ptr
&
);
WebRtcSession
(
const
Socket
::
Ptr
&
sock
);
~
WebRtcSession
()
override
;
...
...
@@ -28,11 +30,8 @@ public:
void
onManager
()
override
;
private
:
std
::
shared_ptr
<
WebRtcTransport
>
createTransport
(
const
string
&
user_name
);
private
:
struct
sockaddr
_peer_addr
;
std
::
shared_ptr
<
WebRtcTransport
>
_transport
;
std
::
shared_ptr
<
WebRtcTransport
Imp
>
_transport
;
};
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论