mirror of
https://github.com/kunkundi/crossdesk.git
synced 2025-10-27 04:35:34 +08:00
Libnice test pass
This commit is contained in:
@@ -6,7 +6,7 @@
|
||||
|
||||
#include "log.h"
|
||||
|
||||
IceAgent::IceAgent(std::string &stun_ip, uint16_t stun_port,
|
||||
IceAgent::IceAgent(bool offer_peer, std::string &stun_ip, uint16_t stun_port,
|
||||
std::string &turn_ip, uint16_t turn_port,
|
||||
std::string &turn_username, std::string &turn_password)
|
||||
: stun_ip_(stun_ip),
|
||||
|
||||
@@ -8,8 +8,8 @@
|
||||
|
||||
class IceAgent {
|
||||
public:
|
||||
IceAgent(std::string& stun_ip, uint16_t stun_port, std::string& turn_ip,
|
||||
uint16_t turn_port, std::string& turn_username,
|
||||
IceAgent(bool offer_peer, std::string& stun_ip, uint16_t stun_port,
|
||||
std::string& turn_ip, uint16_t turn_port, std::string& turn_username,
|
||||
std::string& turn_password);
|
||||
~IceAgent();
|
||||
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
|
||||
#include "log.h"
|
||||
|
||||
IceAgent::IceAgent(std::string &stun_ip, uint16_t stun_port,
|
||||
IceAgent::IceAgent(bool offer_peer, std::string &stun_ip, uint16_t stun_port,
|
||||
std::string &turn_ip, uint16_t turn_port,
|
||||
std::string &turn_username, std::string &turn_password)
|
||||
: stun_ip_(stun_ip),
|
||||
@@ -14,49 +14,88 @@ IceAgent::IceAgent(std::string &stun_ip, uint16_t stun_port,
|
||||
turn_ip_(turn_ip),
|
||||
turn_port_(turn_port),
|
||||
turn_username_(turn_username),
|
||||
turn_password_(turn_password) {}
|
||||
turn_password_(turn_password),
|
||||
controlling_(offer_peer) {}
|
||||
|
||||
IceAgent::~IceAgent() {}
|
||||
IceAgent::~IceAgent() {
|
||||
exit_thread_ = TRUE;
|
||||
g_thread_join(gexamplethread_);
|
||||
}
|
||||
|
||||
void *IceAgent::CreateNcieAgent(void *data) {
|
||||
if (!data) {
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
IceAgent *ice_agent_ptr = (IceAgent *)data;
|
||||
|
||||
ice_agent_ptr->gloop_ = g_main_loop_new(NULL, FALSE);
|
||||
|
||||
// Create the nice agent_
|
||||
ice_agent_ptr->agent_ =
|
||||
nice_agent_new_reliable(g_main_loop_get_context(ice_agent_ptr->gloop_),
|
||||
NICE_COMPATIBILITY_RFC5245);
|
||||
if (ice_agent_ptr->agent_ == NULL) {
|
||||
LOG_ERROR("Failed to create agent_");
|
||||
}
|
||||
|
||||
g_object_set(ice_agent_ptr->agent_, "stun-server",
|
||||
ice_agent_ptr->stun_ip_.c_str(), NULL);
|
||||
g_object_set(ice_agent_ptr->agent_, "stun-server-port",
|
||||
ice_agent_ptr->stun_port_, NULL);
|
||||
|
||||
g_object_set(ice_agent_ptr->agent_, "controlling-mode",
|
||||
ice_agent_ptr->controlling_, NULL);
|
||||
|
||||
// Connect to the signals
|
||||
g_signal_connect(ice_agent_ptr->agent_, "candidate-gathering-done",
|
||||
G_CALLBACK(ice_agent_ptr->on_gathering_done_),
|
||||
ice_agent_ptr->user_ptr_);
|
||||
g_signal_connect(ice_agent_ptr->agent_, "new-selected-pair",
|
||||
G_CALLBACK(ice_agent_ptr->on_candidate_),
|
||||
ice_agent_ptr->user_ptr_);
|
||||
g_signal_connect(ice_agent_ptr->agent_, "component-state-changed",
|
||||
G_CALLBACK(ice_agent_ptr->on_state_changed_),
|
||||
ice_agent_ptr->user_ptr_);
|
||||
|
||||
// Create a new stream with one component
|
||||
ice_agent_ptr->stream_id_ = nice_agent_add_stream(ice_agent_ptr->agent_, 1);
|
||||
if (ice_agent_ptr->stream_id_ == 0) {
|
||||
LOG_ERROR("Failed to add stream");
|
||||
}
|
||||
|
||||
// nice_agent_set_stream_name(ice_agent_ptr->agent_, stream_id_, "video");
|
||||
|
||||
// Attach to the component to receive the data
|
||||
// Without this call, candidates cannot be gathered
|
||||
nice_agent_attach_recv(ice_agent_ptr->agent_, ice_agent_ptr->stream_id_, 1,
|
||||
g_main_loop_get_context(ice_agent_ptr->gloop_),
|
||||
ice_agent_ptr->on_recv_, ice_agent_ptr->user_ptr_);
|
||||
|
||||
g_main_loop_run(ice_agent_ptr->gloop_);
|
||||
}
|
||||
|
||||
int IceAgent::CreateIceAgent(nice_cb_state_changed_t on_state_changed,
|
||||
nice_cb_candidate_t on_candidate,
|
||||
nice_cb_gathering_done_t on_gathering_done,
|
||||
nice_cb_recv_t on_recv, void *user_ptr) {
|
||||
on_state_changed_ = on_state_changed;
|
||||
on_candidate_ = on_candidate;
|
||||
on_gathering_done_ = on_gathering_done;
|
||||
on_recv_ = on_recv;
|
||||
user_ptr_ = user_ptr;
|
||||
|
||||
g_networking_init();
|
||||
|
||||
gloop_ = g_main_loop_new(NULL, FALSE);
|
||||
// Create the nice agent_
|
||||
agent_ = nice_agent_new(g_main_loop_get_context(gloop_),
|
||||
NICE_COMPATIBILITY_RFC5245);
|
||||
if (agent_ == NULL) {
|
||||
LOG_ERROR("Failed to create agent_");
|
||||
}
|
||||
// gloop_ = g_main_loop_new(NULL, FALSE);
|
||||
exit_thread_ = FALSE;
|
||||
// gexamplethread_ = g_thread_new("example thread", &CreateNcieAgent, this);
|
||||
|
||||
g_object_set(agent_, "stun-server", stun_ip_.c_str(), NULL);
|
||||
g_object_set(agent_, "stun-server-port", stun_port_, NULL);
|
||||
|
||||
g_object_set(agent_, "controlling-mode", controlling_, NULL);
|
||||
|
||||
// Connect to the signals
|
||||
g_signal_connect(agent_, "candidate-gathering-done",
|
||||
G_CALLBACK(on_gathering_done), NULL);
|
||||
g_signal_connect(agent_, "new-selected-pair", G_CALLBACK(on_candidate), NULL);
|
||||
g_signal_connect(agent_, "component-state-changed",
|
||||
G_CALLBACK(on_state_changed), NULL);
|
||||
|
||||
// Create a new stream with one component
|
||||
stream_id_ = nice_agent_add_stream(agent_, 1);
|
||||
if (stream_id_ == 0) {
|
||||
LOG_ERROR("Failed to add stream");
|
||||
}
|
||||
nice_agent_set_stream_name(agent_, stream_id_, "video");
|
||||
|
||||
// Attach to the component to receive the data
|
||||
// Without this call, candidates cannot be gathered
|
||||
nice_agent_attach_recv(agent_, stream_id_, 1, g_main_loop_get_context(gloop_),
|
||||
on_recv, NULL);
|
||||
// g_main_loop_run(gloop_);
|
||||
g_thread_.reset(new std::thread(std::bind(&IceAgent::CreateNcieAgent, this)));
|
||||
|
||||
LOG_INFO("Nice agent init finish");
|
||||
g_usleep(100000);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
@@ -2,6 +2,7 @@
|
||||
#define _ICE_AGENT_H_
|
||||
|
||||
#include <iostream>
|
||||
#include <thread>
|
||||
|
||||
#include "gio/gnetworking.h"
|
||||
#include "nice/agent.h"
|
||||
@@ -23,8 +24,8 @@ typedef void (*nice_cb_recv_t)(NiceAgent* agent, guint stream_id,
|
||||
|
||||
class IceAgent {
|
||||
public:
|
||||
IceAgent(std::string& stun_ip, uint16_t stun_port, std::string& turn_ip,
|
||||
uint16_t turn_port, std::string& turn_username,
|
||||
IceAgent(bool offer_peer, std::string& stun_ip, uint16_t stun_port,
|
||||
std::string& turn_ip, uint16_t turn_port, std::string& turn_username,
|
||||
std::string& turn_password);
|
||||
~IceAgent();
|
||||
|
||||
@@ -47,20 +48,32 @@ class IceAgent {
|
||||
|
||||
int Send(const char* data, size_t size);
|
||||
|
||||
private:
|
||||
static void* CreateNcieAgent(void* data);
|
||||
|
||||
public:
|
||||
std::string stun_ip_ = "";
|
||||
uint16_t stun_port_ = 0;
|
||||
std::string turn_ip_ = "";
|
||||
uint16_t turn_port_ = 0;
|
||||
std::string turn_username_ = "";
|
||||
std::string turn_password_ = "";
|
||||
|
||||
std::unique_ptr<std::thread> g_thread_;
|
||||
NiceAgent* agent_ = nullptr;
|
||||
GMainLoop* gloop_;
|
||||
GThread* gexamplethread_;
|
||||
gboolean exit_thread_;
|
||||
bool controlling_ = false;
|
||||
uint32_t stream_id_ = 0;
|
||||
// char local_sdp_[NICE_MAX_SDP_STRING_LEN];
|
||||
char* local_sdp_ = nullptr;
|
||||
NiceComponentState state_;
|
||||
|
||||
nice_cb_state_changed_t on_state_changed_;
|
||||
nice_cb_candidate_t on_candidate_;
|
||||
nice_cb_gathering_done_t on_gathering_done_;
|
||||
nice_cb_recv_t on_recv_;
|
||||
void* user_ptr_;
|
||||
};
|
||||
|
||||
#endif
|
||||
@@ -96,7 +96,7 @@ int PeerConnection::Init(PeerConnectionParams params,
|
||||
};
|
||||
|
||||
on_ice_status_change_ = [this](std::string ice_status) {
|
||||
if ("completed" == ice_status) {
|
||||
if ("completed" == ice_status || "ready" == ice_status) {
|
||||
ice_ready_ = true;
|
||||
on_connection_status_(ConnectionStatus::Connected);
|
||||
b_force_i_frame_ = true;
|
||||
|
||||
@@ -111,8 +111,9 @@ int IceTransmission::InitIceTransmission(std::string &stun_ip, int stun_port,
|
||||
remote_user_id_.size());
|
||||
});
|
||||
|
||||
ice_agent_ = std::make_unique<IceAgent>(
|
||||
stun_ip, stun_port, turn_ip, turn_port, turn_username, turn_password);
|
||||
ice_agent_ =
|
||||
std::make_unique<IceAgent>(offer_peer_, stun_ip, stun_port, turn_ip,
|
||||
turn_port, turn_username, turn_password);
|
||||
|
||||
#ifdef USE_NICE
|
||||
ice_agent_->CreateIceAgent(
|
||||
|
||||
Reference in New Issue
Block a user