peer_connection.cpp 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  1. #include <assert.h>
  2. #include <iostream>
  3. #include <memory>
  4. #include "../common/comm.h"
  5. #include "api.h"
  6. #include "protocol.pb.h"
  7. #include "../common/socket_client.h"
  8. #include "../common/iobuffer.h"
  9. #include "peer_connection.h"
  10. //#include "VideoRenderer.h"
  11. //#include "message_queue.h"
  12. std::mutex CPeerConnection::_lock;
  13. CPeerConnection::CPeerConnection(ChannelType type, SocketClient* d) :_client(d),_type(type)
  14. {
  15. _nativeHandle = nullptr;
  16. bReadyChannel=false;
  17. }
  18. CPeerConnection::~CPeerConnection()
  19. {
  20. if (_nativeHandle != nullptr)
  21. {
  22. }
  23. }
  24. void CPeerConnection::Initialize(int32_t peer,int32_t index,int32_t MinPort,int32_t MaxPort)
  25. {
  26. //20231023
  27. //std::lock_guard<std::mutex> l(_lock);
  28. _nativeHandle = mrsPeerConnectionCreate(MinPort,MaxPort);
  29. std::cout<<"native handle"<<_nativeHandle<<std::endl;
  30. if (_nativeHandle == nullptr)
  31. {
  32. // mrsPeerConnectionClose(&_nativeHandle);
  33. // _nativeHandle = nullptr;
  34. return;
  35. }
  36. mrsPeerConnectionRegisterConnectedCallback(_nativeHandle, &CPeerConnection::ConnectionCallBack, this);
  37. mrsPeerConnectionRegisterLocalSdpReadytoSendCallback(_nativeHandle,peer,index, &CPeerConnection::LocalSdpReadytoSendCallback, this);
  38. mrsPeerConnectionRegisterIceCandidateReadytoSendCallback(_nativeHandle,peer,index, &CPeerConnection::IceCandidateReadytoSendCallback, this);
  39. mrsPeerConnectionRegisterChannelCallback(_nativeHandle, &CPeerConnection::MessageCallback, this, nullptr, nullptr, nullptr, nullptr);
  40. }
  41. void CPeerConnection::Close()
  42. {
  43. //20231023
  44. //std::lock_guard<std::mutex> l(_lock);
  45. if(_nativeHandle==nullptr) return;
  46. bReadyChannel = false;
  47. mrsPeerConnectionRegisterConnectedCallback(_nativeHandle, nullptr, nullptr);
  48. mrsPeerConnectionRegisterLocalSdpReadytoSendCallback(_nativeHandle,0,0, nullptr, nullptr);
  49. mrsPeerConnectionRegisterIceCandidateReadytoSendCallback(_nativeHandle,0, 0,nullptr, nullptr);
  50. mrsPeerConnectionRemoveDataChannel(_nativeHandle);
  51. mrsPeerConnectionClose(&_nativeHandle);
  52. _nativeHandle=nullptr;
  53. }
  54. void CPeerConnection::AddDataChannel(bool ordered, bool reliable)
  55. {
  56. mrsPeerConnectionAddDataChannel(_nativeHandle, ordered, reliable);
  57. }
  58. void CPeerConnection::RemoveDataChannel()
  59. {
  60. mrsPeerConnectionRemoveDataChannel(_nativeHandle);
  61. }
  62. void CPeerConnection::ConnectionCallBack(void* UserData)
  63. {
  64. CPeerConnection* lhs = static_cast<CPeerConnection*>(UserData);
  65. lhs->OnConnect();
  66. }
  67. void CPeerConnection::OnConnect()
  68. {
  69. bConnected = true;
  70. // printf("connect-------------------------------------------------\n");
  71. }
  72. const std::string kOffer = "offer";
  73. const std::string kAnswer = "answer";
  74. void CPeerConnection::LocalSdpReadytoSendCallback(void* user_data,int32_t peer,int32_t view, const char* type, const char* sdp_data)
  75. {
  76. auto lhs = static_cast<CPeerConnection*>(user_data);
  77. lhs->OnLocalSdpReadytoSend(peer,view,type, sdp_data);
  78. }
  79. void CPeerConnection::OnLocalSdpReadytoSend(int32_t peer,int32_t view,const char* type, const char* sdp)
  80. {
  81. // printf ("on local sdp ready to send");
  82. // std::cout << "local sdp " << sdp << std::endl;
  83. //std::string newsdp = ForceSdpCodecs(sdp, PreferredAudioCodec, PreferredAudioCodecExtraParamsRemote, PreferredVideoCodec, PreferredVideoCodecExtraParamsRemote);
  84. //std::cout<<type<<","<<__LINE__<<std::endl;
  85. if (kOffer == type)
  86. {
  87. _client->WriteOffer(peer,view, type, sdp);
  88. }
  89. else if(kAnswer==type)
  90. {
  91. _client->WriteAnswer(peer,view, type, sdp);
  92. }
  93. //mrsWe
  94. }
  95. // #include <sstream>
  96. // void CPeerConnection::OnLocalSdpReadytoSend(int32_t peer, int32_t view, const char* type, const char* sdp)
  97. // {
  98. // std::cout << "sdp " << sdp << std::endl;
  99. // std::cout << "-------------------------------------------" << std::endl;
  100. // // 解析 SDP 字符串
  101. // std::istringstream iss(sdp);
  102. // std::string line;
  103. // while (std::getline(iss, line))
  104. // {
  105. // // 检查是否为编码格式定义行
  106. // if (line.find("a=rtpmap:") == 0)
  107. // {
  108. // // 从行中提取编码格式信息
  109. // std::string token;
  110. // std::istringstream lineiss(line);
  111. // lineiss >> token; // "a=rtpmap:"
  112. // lineiss >> token; // 编码负载类型
  113. // lineiss >> token; // 编码名称
  114. // lineiss >> token; // 采样率
  115. // std::cout << "Supported codec: " << token << std::endl;
  116. // }
  117. // }
  118. // if (kOffer == type)
  119. // {
  120. // _client->WriteOffer(peer, view, type, sdp);
  121. // }
  122. // else if (kAnswer == type)
  123. // {
  124. // _client->WriteAnswer(peer, view, type, sdp);
  125. // }
  126. // }
  127. void CPeerConnection::SetRemoteDescription(const char* type, std::string sdp)
  128. {
  129. // printf("set remote Description\n");
  130. // std::cout << "sdp: " << sdp.c_str() << std::endl;
  131. // std::cout << "TYPE: " << &type << std::endl;
  132. //std::string newsdp = ForceSdpCodecs(sdp, PreferredAudioCodec, PreferredAudioCodecExtraParamsLocal, PreferredVideoCodec, PreferredVideoCodecExtraParamsLocal);
  133. auto ret = mrsPeerConnectionSetRemoteDescription(_nativeHandle, type, sdp.c_str());
  134. assert(ret == true);
  135. }
  136. void CPeerConnection::IceCandidateReadytoSendCallback(void* user_data,int32_t peer,int32_t index, const char* sdp, int32_t sdp_mline_index, const char* sdp_mid)
  137. {
  138. // printf("ice candidate ready to send callback\n");
  139. auto lhs = static_cast<CPeerConnection*>(user_data);
  140. lhs->OnIceCandidateReadytoSend(peer,index,sdp, sdp_mline_index, sdp_mid);
  141. }
  142. void CPeerConnection::OnIceCandidateReadytoSend(int32_t peer,int32_t index,const char* candidate, int32_t sdp_mline_index, const char* sdp_mid)
  143. {
  144. // printf("OnIceCandidateReadytoSend\n");
  145. _client->WriteCandidate(peer,index, candidate, sdp_mline_index, sdp_mid);
  146. }
  147. void CPeerConnection::AddIceCandidate(const char* sdp, int32_t sdp_mline_index, const char* sdp_mid)
  148. {
  149. // printf("AddIceCandidate\n");
  150. auto ret = mrsPeerConnectionAddIceCandidate(_nativeHandle, sdp, sdp_mline_index, sdp_mid);
  151. assert(ret == true);
  152. }
  153. bool CPeerConnection::CreateOffer()
  154. {
  155. // std::cout<<__FUNCTION__<<","<<__LINE__<<std::endl;
  156. printf("CREATE OFFER\n");
  157. auto ret = mrsPeerConnectionCreateOffer(_nativeHandle);// == mrsResult::kSuccess;
  158. assert(ret == true);
  159. return true;
  160. }
  161. bool CPeerConnection::CreateAnswer()
  162. {
  163. // printf("CREATE Answer\n");
  164. //std::cout<<__FUNCTION__<<","<<__LINE__<<std::endl;
  165. auto ret = mrsPeerConnectionCreateAnswer(_nativeHandle); ;
  166. assert(ret == true);
  167. return true;
  168. }
  169. void CPeerConnection::AddLocalArgb32VideoFrameReady(PeerConnectionARGBVideoFrameCallback fn, void* user_data)
  170. {
  171. mrsPeerConnectionRegisterARGBLocalVideoFrameCallback(_nativeHandle, fn, user_data);
  172. }
  173. void CPeerConnection::AddLocalAudioTrack()
  174. {
  175. mrsPeerConnectionAddLocalAudioTrack(_nativeHandle);
  176. }
  177. void CPeerConnection::RemoveLocalAudioTrack()
  178. {
  179. mrsPeerConnectionRemoveLocalAudioTrack(_nativeHandle);
  180. }
  181. void CPeerConnection::AddRemoteArgb32VideoFrameReady(PeerConnectionARGBVideoFrameCallback fn, void* user_data)
  182. {
  183. mrsPeerConnectionRegisterARGBRemoteVideoFrameCallback(_nativeHandle, fn, user_data);
  184. }
  185. #ifdef WEBRTC_LINUX
  186. void CPeerConnection::AddLocalVideoTrack(RenderPosition type,int32_t index)
  187. {
  188. //PeerConnectionHandle peerHandle, CaptureType type, int32_t fps)
  189. auto ret=mrsPeerConnectionAddLocalVideoTrack(_nativeHandle, type,index);
  190. }
  191. void CPeerConnection::SwitchCapture(bool front)
  192. {
  193. if(_nativeHandle!=nullptr)
  194. mrsPeerConnectionSwitchCapture(_nativeHandle, front);
  195. }
  196. void CPeerConnection::SetOtherCtx(void * data)
  197. {
  198. mrsPeerConnectionSetCtx(_nativeHandle,data);
  199. }
  200. void * CPeerConnection::GetCurrentCtx()
  201. {
  202. return mrsPeerConnectionCurrentCtx(_nativeHandle);
  203. }
  204. #else
  205. void CPeerConnection::SetDataReady()
  206. {
  207. bReadyChannel = true;
  208. }
  209. bool CPeerConnection::IsDataReady()
  210. {
  211. return bReadyChannel;
  212. }
  213. #endif
  214. void CPeerConnection::MessageCallback(void * user_data,const void * data,const int32_t size)
  215. {
  216. CPeerConnection* lhs=static_cast<CPeerConnection*>(user_data);
  217. lhs->OnPeerMessage(data,size);
  218. }
  219. void CPeerConnection::OnPeerMessage(const void * data,const int32_t size)
  220. {
  221. if(size<MessageHead::Size()) return;
  222. MessageHead Head;
  223. int8_t* Data=(int8_t *)data;
  224. Head.Deserialize(Data);
  225. if(size<MessageHead::Size()+Head.Length) return;
  226. auto ptr=Data+MessageHead::Size();
  227. if(Head.Command==RemoNet::CC_ASKDATACHANNEL)
  228. {
  229. bReadyChannel=true;
  230. //return;
  231. }
  232. if(!bReadyChannel) return;
  233. _client->OnPeerMessage(_type,Head.Command,Head.Length,ptr);
  234. }
  235. void CPeerConnection::SendData(CIOBuffer& pBuffer)
  236. {
  237. if(!bReadyChannel) return;
  238. auto ret=mrsPeerConnectionSendDataChannelMessage(_nativeHandle,pBuffer.Buffer,pBuffer.Length);
  239. if(ret==false)
  240. {
  241. printf("send failed to Peer \n");
  242. }
  243. }