Libnice test pass

This commit is contained in:
dijunkun
2023-10-14 19:13:40 +08:00
parent 5b46218f9b
commit a1940c9cf7
7 changed files with 96 additions and 43 deletions

View File

@@ -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),

View File

@@ -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();

View File

@@ -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;
}

View File

@@ -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

View File

@@ -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;

View File

@@ -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(