#ifndef TGCALLS_NATIVE_NETWORKING_IMPL_H #define TGCALLS_NATIVE_NETWORKING_IMPL_H #ifdef WEBRTC_WIN // Compiler errors in conflicting Windows headers if not included here. #include #endif // WEBRTC_WIN #include "rtc_base/copy_on_write_buffer.h" #include "rtc_base/third_party/sigslot/sigslot.h" #include "api/candidate.h" #include "media/base/media_channel.h" #include "rtc_base/ssl_fingerprint.h" #include "pc/sctp_data_channel.h" #include "p2p/base/port.h" #include "api/transport/field_trial_based_config.h" #include #include #include "Message.h" #include "ThreadLocalObject.h" #include "Instance.h" namespace rtc { class BasicPacketSocketFactory; class BasicNetworkManager; class PacketTransportInternal; struct NetworkRoute; } // namespace rtc namespace cricket { class BasicPortAllocator; class P2PTransportChannel; class IceTransportInternal; class DtlsTransport; class RelayPortFactoryInterface; } // namespace cricket namespace webrtc { class TurnCustomizer; class DtlsSrtpTransport; class RtpTransport; class AsyncDnsResolverFactoryInterface; } // namespace webrtc namespace tgcalls { struct Message; class SctpDataChannelProviderInterfaceImpl; class Threads; class NativeNetworkingImpl : public sigslot::has_slots<>, public std::enable_shared_from_this { public: struct RouteDescription { explicit RouteDescription(std::string const &localDescription_, std::string const &remoteDescription_) : localDescription(localDescription_), remoteDescription(remoteDescription_) { } std::string localDescription; std::string remoteDescription; bool operator==(RouteDescription const &rhs) const { if (localDescription != rhs.localDescription) { return false; } if (remoteDescription != rhs.remoteDescription) { return false; } return true; } bool operator!=(const RouteDescription& rhs) const { return !(*this == rhs); } }; struct ConnectionDescription { struct CandidateDescription { std::string protocol; std::string type; std::string address; bool operator==(CandidateDescription const &rhs) const { if (protocol != rhs.protocol) { return false; } if (type != rhs.type) { return false; } if (address != rhs.address) { return false; } return true; } bool operator!=(const CandidateDescription& rhs) const { return !(*this == rhs); } }; CandidateDescription local; CandidateDescription remote; bool operator==(ConnectionDescription const &rhs) const { if (local != rhs.local) { return false; } if (remote != rhs.remote) { return false; } return true; } bool operator!=(const ConnectionDescription& rhs) const { return !(*this == rhs); } }; struct State { bool isReadyToSendData = false; bool isFailed = false; absl::optional route; absl::optional connection; }; struct Configuration { bool isOutgoing = false; bool enableStunMarking = false; bool enableTCP = false; bool enableP2P = false; std::vector rtcServers; absl::optional proxy; std::function stateUpdated; std::function candidateGathered; std::function transportMessageReceived; std::function rtcpPacketReceived; std::function dataChannelStateUpdated; std::function dataChannelMessageReceived; std::shared_ptr threads; }; static webrtc::CryptoOptions getDefaulCryptoOptions(); static ConnectionDescription::CandidateDescription connectionDescriptionFromCandidate(cricket::Candidate const &candidate); NativeNetworkingImpl(Configuration &&configuration); ~NativeNetworkingImpl(); void start(); void stop(); PeerIceParameters getLocalIceParameters(); std::unique_ptr getLocalFingerprint(); void setRemoteParams(PeerIceParameters const &remoteIceParameters, rtc::SSLFingerprint *fingerprint, std::string const &sslSetup); void addCandidates(std::vector const &candidates); void sendDataChannelMessage(std::string const &message); webrtc::RtpTransport *getRtpTransport(); private: void resetDtlsSrtpTransport(); void checkConnectionTimeout(); void candidateGathered(cricket::IceTransportInternal *transport, const cricket::Candidate &candidate); void candidateGatheringState(cricket::IceTransportInternal *transport); void OnTransportWritableState_n(rtc::PacketTransportInternal *transport); void OnTransportReceivingState_n(rtc::PacketTransportInternal *transport); void transportStateChanged(cricket::IceTransportInternal *transport); void transportReadyToSend(cricket::IceTransportInternal *transport); void transportRouteChanged(absl::optional route); void candidatePairChanged(cricket::CandidatePairChangeEvent const &event); void DtlsReadyToSend(bool DtlsReadyToSend); void UpdateAggregateStates_n(); void RtpPacketReceived_n(rtc::CopyOnWriteBuffer *packet, int64_t packet_time_us, bool isUnresolved); void OnRtcpPacketReceived_n(rtc::CopyOnWriteBuffer *packet, int64_t packet_time_us); void sctpReadyToSendData(); void sctpDataReceived(const cricket::ReceiveDataParams& params, const rtc::CopyOnWriteBuffer& buffer); void notifyStateUpdated(); std::shared_ptr _threads; bool _isOutgoing = false; bool _enableStunMarking = false; bool _enableTCP = false; bool _enableP2P = false; std::vector _rtcServers; absl::optional _proxy; std::function _stateUpdated; std::function _candidateGathered; std::function _transportMessageReceived; std::function _rtcpPacketReceived; std::function _dataChannelStateUpdated; std::function _dataChannelMessageReceived; std::unique_ptr _networkMonitorFactory; std::unique_ptr _socketFactory; std::unique_ptr _networkManager; std::unique_ptr _turnCustomizer; std::unique_ptr _relayPortFactory; std::unique_ptr _portAllocator; std::unique_ptr _asyncResolverFactory; std::unique_ptr _transportChannel; std::unique_ptr _dtlsTransport; std::unique_ptr _dtlsSrtpTransport; std::unique_ptr _dataChannelInterface; rtc::scoped_refptr _localCertificate; PeerIceParameters _localIceParameters; absl::optional _remoteIceParameters; bool _isConnected = false; bool _isFailed = false; int64_t _lastDisconnectedTimestamp = 0; absl::optional _currentRouteDescription; absl::optional _currentConnectionDescription; }; } // namespace tgcalls #endif