mirror of
https://github.com/signalwire/freeswitch.git
synced 2025-04-14 00:00:44 +00:00
2nd pass to add secure RTP
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@1104 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
parent
62fcb3bcc7
commit
82c1907380
@ -101,12 +101,14 @@ SWITCH_DECLARE_DATA extern switch_directories SWITCH_GLOBAL_dirs;
|
|||||||
SWITCH_RTP_FLAG_NOBLOCK - Do not block
|
SWITCH_RTP_FLAG_NOBLOCK - Do not block
|
||||||
SWITCH_RTP_FLAG_IO - IO is ready
|
SWITCH_RTP_FLAG_IO - IO is ready
|
||||||
SWITCH_RTP_FLAG_USE_TIMER - Timeout Reads and replace with a CNG Frame
|
SWITCH_RTP_FLAG_USE_TIMER - Timeout Reads and replace with a CNG Frame
|
||||||
|
SWITCH_RTP_FLAG_SECURE - Secure RTP
|
||||||
</pre>
|
</pre>
|
||||||
*/
|
*/
|
||||||
typedef enum {
|
typedef enum {
|
||||||
SWITCH_RTP_FLAG_NOBLOCK = ( 1 << 0),
|
SWITCH_RTP_FLAG_NOBLOCK = ( 1 << 0),
|
||||||
SWITCH_RTP_FLAG_IO = (1 << 1),
|
SWITCH_RTP_FLAG_IO = (1 << 1),
|
||||||
SWITCH_RTP_FLAG_USE_TIMER = (1 << 2)
|
SWITCH_RTP_FLAG_USE_TIMER = (1 << 2),
|
||||||
|
SWITCH_RTP_FLAG_SECURE = (1 << 3)
|
||||||
} switch_rtp_flag_t;
|
} switch_rtp_flag_t;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -276,6 +276,7 @@ SWITCH_DECLARE(switch_status) switch_rtp_create(switch_rtp **new_rtp_session,
|
|||||||
if (crypto_key) {
|
if (crypto_key) {
|
||||||
int len;
|
int len;
|
||||||
|
|
||||||
|
switch_set_flag(rtp_session, SWITCH_RTP_FLAG_SECURE);
|
||||||
crypto_policy_set_rtp_default(&policy.rtp);
|
crypto_policy_set_rtp_default(&policy.rtp);
|
||||||
crypto_policy_set_rtcp_default(&policy.rtcp);
|
crypto_policy_set_rtcp_default(&policy.rtcp);
|
||||||
policy.ssrc.type = ssrc_specific;
|
policy.ssrc.type = ssrc_specific;
|
||||||
@ -463,6 +464,11 @@ static int rtp_common_read(switch_rtp *rtp_session, void *data, int *payload_typ
|
|||||||
for(;;) {
|
for(;;) {
|
||||||
bytes = sizeof(rtp_msg_t);
|
bytes = sizeof(rtp_msg_t);
|
||||||
status = switch_socket_recvfrom(rtp_session->from_addr, rtp_session->sock, 0, (void *)&rtp_session->recv_msg, &bytes);
|
status = switch_socket_recvfrom(rtp_session->from_addr, rtp_session->sock, 0, (void *)&rtp_session->recv_msg, &bytes);
|
||||||
|
if (switch_test_flag(rtp_session, SWITCH_RTP_FLAG_SECURE)) {
|
||||||
|
int sbytes = (int)bytes;
|
||||||
|
srtp_unprotect(rtp_session->recv_ctx, &rtp_session->send_msg, &sbytes);
|
||||||
|
bytes = sbytes;
|
||||||
|
}
|
||||||
|
|
||||||
if (switch_test_flag(rtp_session, SWITCH_RTP_FLAG_USE_TIMER)) {
|
if (switch_test_flag(rtp_session, SWITCH_RTP_FLAG_USE_TIMER)) {
|
||||||
if (!switch_test_flag(rtp_session, SWITCH_RTP_FLAG_IO)) {
|
if (!switch_test_flag(rtp_session, SWITCH_RTP_FLAG_IO)) {
|
||||||
@ -562,6 +568,12 @@ static int rtp_common_write(switch_rtp *rtp_session, void *data, uint32_t datale
|
|||||||
}
|
}
|
||||||
|
|
||||||
bytes = datalen + rtp_header_len;
|
bytes = datalen + rtp_header_len;
|
||||||
|
if (switch_test_flag(rtp_session, SWITCH_RTP_FLAG_SECURE)) {
|
||||||
|
int sbytes = (int)bytes;
|
||||||
|
srtp_protect(rtp_session->send_ctx, &rtp_session->send_msg, &sbytes);
|
||||||
|
bytes = sbytes;
|
||||||
|
}
|
||||||
|
|
||||||
switch_socket_sendto(rtp_session->sock, rtp_session->remote_addr, 0, (void*)&rtp_session->send_msg, &bytes);
|
switch_socket_sendto(rtp_session->sock, rtp_session->remote_addr, 0, (void*)&rtp_session->send_msg, &bytes);
|
||||||
|
|
||||||
if (rtp_session->ice_user) {
|
if (rtp_session->ice_user) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user