blob: 156bbe557bc5b47a6948b8d0aefd410671751bc4 [file] [log] [blame]
Harald Alvestrand05e4d082019-12-03 14:04:21 +01001/*
2 * Copyright 2019 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11#ifndef PC_DATA_CHANNEL_CONTROLLER_H_
12#define PC_DATA_CHANNEL_CONTROLLER_H_
13
14#include <map>
15#include <memory>
16#include <string>
17#include <vector>
18
19#include "pc/channel.h"
20#include "pc/data_channel.h"
Harald Alvestrand246724b2019-12-03 22:31:42 +010021#include "rtc_base/weak_ptr.h"
Harald Alvestrand05e4d082019-12-03 14:04:21 +010022
23namespace webrtc {
24
25class PeerConnection;
26
27class DataChannelController : public DataChannelProviderInterface,
28 public DataChannelSink {
29 public:
30 explicit DataChannelController(PeerConnection* pc) : pc_(pc) {}
31
Harald Alvestrandab813162020-01-09 13:29:56 +010032 // Not copyable or movable.
33 DataChannelController(DataChannelController&) = delete;
34 DataChannelController& operator=(const DataChannelController& other) = delete;
35 DataChannelController(DataChannelController&&) = delete;
36 DataChannelController& operator=(DataChannelController&& other) = delete;
37
Harald Alvestrand05e4d082019-12-03 14:04:21 +010038 // Implements DataChannelProviderInterface.
39 bool SendData(const cricket::SendDataParams& params,
40 const rtc::CopyOnWriteBuffer& payload,
41 cricket::SendDataResult* result) override;
42 bool ConnectDataChannel(DataChannel* webrtc_data_channel) override;
43 void DisconnectDataChannel(DataChannel* webrtc_data_channel) override;
44 void AddSctpDataStream(int sid) override;
45 void RemoveSctpDataStream(int sid) override;
46 bool ReadyToSendData() const override;
47
48 // Implements DataChannelSink.
49 void OnDataReceived(int channel_id,
50 DataMessageType type,
51 const rtc::CopyOnWriteBuffer& buffer) override;
52 void OnChannelClosing(int channel_id) override;
53 void OnChannelClosed(int channel_id) override;
54 void OnReadyToSend() override;
Harald Alvestrand2697ac12019-12-16 10:37:04 +010055 void OnTransportClosed() override;
Harald Alvestrand05e4d082019-12-03 14:04:21 +010056
57 // Called from PeerConnection::SetupDataChannelTransport_n
58 void SetupDataChannelTransport_n();
59 // Called from PeerConnection::TeardownDataChannelTransport_n
60 void TeardownDataChannelTransport_n();
61
62 // Called from PeerConnection::OnTransportChanged
63 // to make required changes to datachannels' transports.
64 void OnTransportChanged(
65 DataChannelTransportInterface* data_channel_transport);
66
67 // Creates channel and adds it to the collection of DataChannels that will
68 // be offered in a SessionDescription.
69 rtc::scoped_refptr<DataChannel> InternalCreateDataChannel(
70 const std::string& label,
71 const InternalDataChannelInit*
72 config) /* RTC_RUN_ON(signaling_thread()) */;
73 void AllocateSctpSids(rtc::SSLRole role);
74
75 DataChannel* FindDataChannelBySid(int sid) const;
76
77 // Checks if any data channel has been added.
78 bool HasDataChannels() const;
79 bool HasSctpDataChannels() const {
80 RTC_DCHECK_RUN_ON(signaling_thread());
81 return !sctp_data_channels_.empty();
82 }
83 bool HasRtpDataChannels() const {
84 RTC_DCHECK_RUN_ON(signaling_thread());
85 return !rtp_data_channels_.empty();
86 }
87
Harald Alvestrand05e4d082019-12-03 14:04:21 +010088 void UpdateLocalRtpDataChannels(const cricket::StreamParamsVec& streams);
89 void UpdateRemoteRtpDataChannels(const cricket::StreamParamsVec& streams);
90
91 // Accessors
Tomas Gunnarsson7d3cfbf2020-06-15 13:47:42 +020092 cricket::DataChannelType data_channel_type() const;
93 void set_data_channel_type(cricket::DataChannelType type);
Harald Alvestrand05e4d082019-12-03 14:04:21 +010094 cricket::RtpDataChannel* rtp_data_channel() const {
95 return rtp_data_channel_;
96 }
97 void set_rtp_data_channel(cricket::RtpDataChannel* channel) {
98 rtp_data_channel_ = channel;
99 }
Tomas Gunnarsson7d3cfbf2020-06-15 13:47:42 +0200100 DataChannelTransportInterface* data_channel_transport() const;
101 void set_data_channel_transport(DataChannelTransportInterface* transport);
Harald Alvestrand05e4d082019-12-03 14:04:21 +0100102 const std::map<std::string, rtc::scoped_refptr<DataChannel>>*
Tomas Gunnarsson7d3cfbf2020-06-15 13:47:42 +0200103 rtp_data_channels() const;
Harald Alvestrand05e4d082019-12-03 14:04:21 +0100104 const std::vector<rtc::scoped_refptr<DataChannel>>* sctp_data_channels()
Tomas Gunnarsson7d3cfbf2020-06-15 13:47:42 +0200105 const;
Harald Alvestrand05e4d082019-12-03 14:04:21 +0100106
107 sigslot::signal1<DataChannel*>& SignalDataChannelCreated() {
108 RTC_DCHECK_RUN_ON(signaling_thread());
109 return SignalDataChannelCreated_;
110 }
111 // Called when the transport for the data channels is closed or destroyed.
112 void OnTransportChannelClosed();
113
114 void OnSctpDataChannelClosed(DataChannel* channel);
115
116 private:
117 // Parses and handles open messages. Returns true if the message is an open
118 // message, false otherwise.
119 bool HandleOpenMessage_s(const cricket::ReceiveDataParams& params,
120 const rtc::CopyOnWriteBuffer& buffer)
121 RTC_RUN_ON(signaling_thread());
122 // Called when a valid data channel OPEN message is received.
123 void OnDataChannelOpenMessage(const std::string& label,
124 const InternalDataChannelInit& config)
125 RTC_RUN_ON(signaling_thread());
126
127 void CreateRemoteRtpDataChannel(const std::string& label,
128 uint32_t remote_ssrc)
129 RTC_RUN_ON(signaling_thread());
130
131 void UpdateClosingRtpDataChannels(
132 const std::vector<std::string>& active_channels,
133 bool is_local_update) RTC_RUN_ON(signaling_thread());
134
Tomas Gunnarsson7d3cfbf2020-06-15 13:47:42 +0200135 // Called from SendData when data_channel_transport() is true.
136 bool DataChannelSendData(const cricket::SendDataParams& params,
137 const rtc::CopyOnWriteBuffer& payload,
138 cricket::SendDataResult* result);
139
Harald Alvestrand05e4d082019-12-03 14:04:21 +0100140 rtc::Thread* network_thread() const;
141 rtc::Thread* signaling_thread() const;
142
143 // Specifies which kind of data channel is allowed. This is controlled
144 // by the chrome command-line flag and constraints:
145 // 1. If chrome command-line switch 'enable-sctp-data-channels' is enabled,
146 // constraint kEnableDtlsSrtp is true, and constaint kEnableRtpDataChannels is
147 // not set or false, SCTP is allowed (DCT_SCTP);
148 // 2. If constraint kEnableRtpDataChannels is true, RTP is allowed (DCT_RTP);
149 // 3. If both 1&2 are false, data channel is not allowed (DCT_NONE).
150 cricket::DataChannelType data_channel_type_ =
151 cricket::DCT_NONE; // TODO(bugs.webrtc.org/9987): Accessed on both
152 // signaling and network thread.
153
154 // Plugin transport used for data channels. Pointer may be accessed and
155 // checked from any thread, but the object may only be touched on the
156 // network thread.
157 // TODO(bugs.webrtc.org/9987): Accessed on both signaling and network
158 // thread.
159 DataChannelTransportInterface* data_channel_transport_ = nullptr;
160
161 // Cached value of whether the data channel transport is ready to send.
162 bool data_channel_transport_ready_to_send_
163 RTC_GUARDED_BY(signaling_thread()) = false;
164
165 // |rtp_data_channel_| is used if in RTP data channel mode,
166 // |data_channel_transport_| when using SCTP.
167 cricket::RtpDataChannel* rtp_data_channel_ = nullptr;
168 // TODO(bugs.webrtc.org/9987): Accessed on both
169 // signaling and some other thread.
170
171 SctpSidAllocator sid_allocator_ /* RTC_GUARDED_BY(signaling_thread()) */;
172 std::vector<rtc::scoped_refptr<DataChannel>> sctp_data_channels_
173 RTC_GUARDED_BY(signaling_thread());
174 std::vector<rtc::scoped_refptr<DataChannel>> sctp_data_channels_to_free_
175 RTC_GUARDED_BY(signaling_thread());
176
177 // Map of label -> DataChannel
178 std::map<std::string, rtc::scoped_refptr<DataChannel>> rtp_data_channels_
179 RTC_GUARDED_BY(signaling_thread());
180
181 // Signals from |data_channel_transport_|. These are invoked on the
182 // signaling thread.
Tomas Gunnarsson7d3cfbf2020-06-15 13:47:42 +0200183 // TODO(bugs.webrtc.org/11547): These '_s' signals likely all belong on the
184 // network thread.
Harald Alvestrand05e4d082019-12-03 14:04:21 +0100185 sigslot::signal1<bool> SignalDataChannelTransportWritable_s
186 RTC_GUARDED_BY(signaling_thread());
187 sigslot::signal2<const cricket::ReceiveDataParams&,
188 const rtc::CopyOnWriteBuffer&>
189 SignalDataChannelTransportReceivedData_s
190 RTC_GUARDED_BY(signaling_thread());
191 sigslot::signal1<int> SignalDataChannelTransportChannelClosing_s
192 RTC_GUARDED_BY(signaling_thread());
193 sigslot::signal1<int> SignalDataChannelTransportChannelClosed_s
194 RTC_GUARDED_BY(signaling_thread());
195
196 sigslot::signal1<DataChannel*> SignalDataChannelCreated_
197 RTC_GUARDED_BY(signaling_thread());
198
199 // Used to invoke data channel transport signals on the signaling thread.
200 std::unique_ptr<rtc::AsyncInvoker> data_channel_transport_invoker_
201 RTC_GUARDED_BY(network_thread());
202
203 // Owning PeerConnection.
204 PeerConnection* const pc_;
Harald Alvestrand246724b2019-12-03 22:31:42 +0100205 rtc::WeakPtrFactory<DataChannelController> weak_factory_{this};
Harald Alvestrand05e4d082019-12-03 14:04:21 +0100206};
207
208} // namespace webrtc
209
210#endif // PC_DATA_CHANNEL_CONTROLLER_H_