peerconnection.hpp 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. /**
  2. * Copyright (c) 2019 Paul-Louis Ageneau
  3. *
  4. * This library is free software; you can redistribute it and/or
  5. * modify it under the terms of the GNU Lesser General Public
  6. * License as published by the Free Software Foundation; either
  7. * version 2.1 of the License, or (at your option) any later version.
  8. *
  9. * This library is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  12. * Lesser General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU Lesser General Public
  15. * License along with this library; if not, write to the Free Software
  16. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  17. */
  18. #ifndef RTC_PEER_CONNECTION_H
  19. #define RTC_PEER_CONNECTION_H
  20. #include "candidate.hpp"
  21. #include "configuration.hpp"
  22. #include "datachannel.hpp"
  23. #include "description.hpp"
  24. #include "include.hpp"
  25. #include "message.hpp"
  26. #include "reliability.hpp"
  27. #include "rtc.hpp"
  28. #include <atomic>
  29. #include <functional>
  30. #include <list>
  31. #include <mutex>
  32. #include <shared_mutex>
  33. #include <thread>
  34. #include <unordered_map>
  35. namespace rtc {
  36. class Certificate;
  37. class IceTransport;
  38. class DtlsTransport;
  39. class SctpTransport;
  40. class PeerConnection : public std::enable_shared_from_this<PeerConnection> {
  41. public:
  42. enum class State : int {
  43. New = RTC_NEW,
  44. Connecting = RTC_CONNECTING,
  45. Connected = RTC_CONNECTED,
  46. Disconnected = RTC_DISCONNECTED,
  47. Failed = RTC_FAILED,
  48. Closed = RTC_CLOSED,
  49. Destroying = RTC_DESTROYING
  50. };
  51. enum class GatheringState : int {
  52. New = RTC_GATHERING_NEW,
  53. InProgress = RTC_GATHERING_INPROGRESS,
  54. Complete = RTC_GATHERING_COMPLETE,
  55. };
  56. PeerConnection(void);
  57. PeerConnection(const Configuration &config);
  58. ~PeerConnection();
  59. void close();
  60. const Configuration *config() const;
  61. State state() const;
  62. GatheringState gatheringState() const;
  63. std::optional<Description> localDescription() const;
  64. std::optional<Description> remoteDescription() const;
  65. std::optional<string> localAddress() const;
  66. std::optional<string> remoteAddress() const;
  67. void setRemoteDescription(Description description);
  68. void addRemoteCandidate(Candidate candidate);
  69. std::shared_ptr<DataChannel> createDataChannel(const string &label, const string &protocol = "",
  70. const Reliability &reliability = {});
  71. void onDataChannel(std::function<void(std::shared_ptr<DataChannel> dataChannel)> callback);
  72. void onLocalDescription(std::function<void(const Description &description)> callback);
  73. void onLocalCandidate(std::function<void(const Candidate &candidate)> callback);
  74. void onStateChange(std::function<void(State state)> callback);
  75. void onGatheringStateChange(std::function<void(GatheringState state)> callback);
  76. std::string connectionInfo;
  77. private:
  78. std::shared_ptr<IceTransport> initIceTransport(Description::Role role);
  79. std::shared_ptr<DtlsTransport> initDtlsTransport();
  80. std::shared_ptr<SctpTransport> initSctpTransport();
  81. void endLocalCandidates();
  82. bool checkFingerprint(const std::string &fingerprint) const;
  83. void forwardMessage(message_ptr message);
  84. void forwardBufferedAmount(uint16_t stream, size_t amount);
  85. std::shared_ptr<DataChannel> emplaceDataChannel(Description::Role role, const string &label,
  86. const string &protocol,
  87. const Reliability &reliability);
  88. std::shared_ptr<DataChannel> findDataChannel(uint16_t stream);
  89. void iterateDataChannels(std::function<void(std::shared_ptr<DataChannel> channel)> func);
  90. void openDataChannels();
  91. void closeDataChannels();
  92. void remoteCloseDataChannels();
  93. void processLocalDescription(Description description);
  94. void processLocalCandidate(Candidate candidate);
  95. void triggerDataChannel(std::weak_ptr<DataChannel> weakDataChannel);
  96. void changeState(State state);
  97. void changeGatheringState(GatheringState state);
  98. const Configuration mConfig;
  99. const std::shared_ptr<Certificate> mCertificate;
  100. std::optional<Description> mLocalDescription, mRemoteDescription;
  101. mutable std::recursive_mutex mLocalDescriptionMutex, mRemoteDescriptionMutex;
  102. std::shared_ptr<IceTransport> mIceTransport;
  103. std::shared_ptr<DtlsTransport> mDtlsTransport;
  104. std::shared_ptr<SctpTransport> mSctpTransport;
  105. std::recursive_mutex mInitMutex;
  106. std::unordered_map<unsigned int, std::weak_ptr<DataChannel>> mDataChannels;
  107. std::shared_mutex mDataChannelsMutex;
  108. std::atomic<State> mState;
  109. std::atomic<GatheringState> mGatheringState;
  110. synchronized_callback<std::shared_ptr<DataChannel>> mDataChannelCallback;
  111. synchronized_callback<const Description &> mLocalDescriptionCallback;
  112. synchronized_callback<const Candidate &> mLocalCandidateCallback;
  113. synchronized_callback<State> mStateChangeCallback;
  114. synchronized_callback<GatheringState> mGatheringStateChangeCallback;
  115. };
  116. } // namespace rtc
  117. std::ostream &operator<<(std::ostream &out, const rtc::PeerConnection::State &state);
  118. std::ostream &operator<<(std::ostream &out, const rtc::PeerConnection::GatheringState &state);
  119. #endif