/* Copyright 2019 The WebRTC project authors. All Rights Reserved. * * Use of this source code is governed by a BSD-style license * that can be found in the LICENSE file in the root of the source * tree. An additional intellectual property rights grant can be found * in the file PATENTS. All contributing project authors may * be found in the AUTHORS file in the root of the source tree. */ // This is an experimental interface and is subject to change without notice. #ifndef API_TRANSPORT_DATA_CHANNEL_TRANSPORT_INTERFACE_H_ #define API_TRANSPORT_DATA_CHANNEL_TRANSPORT_INTERFACE_H_ #include "absl/types/optional.h" #include "api/rtc_error.h" #include "rtc_base/copy_on_write_buffer.h" namespace webrtc { // Supported types of application data messages. enum class DataMessageType { // Application data buffer with the binary bit unset. kText, // Application data buffer with the binary bit set. kBinary, // Transport-agnostic control messages, such as open or open-ack messages. kControl, }; // Parameters for sending data. The parameters may change from message to // message, even within a single channel. For example, control messages may be // sent reliably and in-order, even if the data channel is configured for // unreliable delivery. struct SendDataParams { DataMessageType type = DataMessageType::kText; // Whether to deliver the message in order with respect to other ordered // messages with the same channel_id. bool ordered = false; // If set, the maximum number of times this message may be // retransmitted by the transport before it is dropped. // Setting this value to zero disables retransmission. // Valid values are in the range [0-UINT16_MAX]. // `max_rtx_count` and `max_rtx_ms` may not be set simultaneously. absl::optional max_rtx_count; // If set, the maximum number of milliseconds for which the transport // may retransmit this message before it is dropped. // Setting this value to zero disables retransmission. // Valid values are in the range [0-UINT16_MAX]. // `max_rtx_count` and `max_rtx_ms` may not be set simultaneously. absl::optional max_rtx_ms; }; // Sink for callbacks related to a data channel. class DataChannelSink { public: virtual ~DataChannelSink() = default; // Callback issued when data is received by the transport. virtual void OnDataReceived(int channel_id, DataMessageType type, const rtc::CopyOnWriteBuffer& buffer) = 0; // Callback issued when a remote data channel begins the closing procedure. // Messages sent after the closing procedure begins will not be transmitted. virtual void OnChannelClosing(int channel_id) = 0; // Callback issued when a (remote or local) data channel completes the closing // procedure. Closing channels become closed after all pending data has been // transmitted. virtual void OnChannelClosed(int channel_id) = 0; // Callback issued when the data channel becomes ready to send. // This callback will be issued immediately when the data channel sink is // registered if the transport is ready at that time. This callback may be // invoked again following send errors (eg. due to the transport being // temporarily blocked or unavailable). virtual void OnReadyToSend() = 0; // Callback issued when the data channel becomes unusable (closed). // TODO(https://crbug.com/webrtc/10360): Make pure virtual when all // consumers updated. virtual void OnTransportClosed(RTCError error) {} }; // Transport for data channels. class DataChannelTransportInterface { public: virtual ~DataChannelTransportInterface() = default; // Opens a data `channel_id` for sending. May return an error if the // specified `channel_id` is unusable. Must be called before `SendData`. virtual RTCError OpenChannel(int channel_id) = 0; // Sends a data buffer to the remote endpoint using the given send parameters. // `buffer` may not be larger than 256 KiB. Returns an error if the send // fails. virtual RTCError SendData(int channel_id, const SendDataParams& params, const rtc::CopyOnWriteBuffer& buffer) = 0; // Closes `channel_id` gracefully. Returns an error if `channel_id` is not // open. Data sent after the closing procedure begins will not be // transmitted. The channel becomes closed after pending data is transmitted. virtual RTCError CloseChannel(int channel_id) = 0; // Sets a sink for data messages and channel state callbacks. Before media // transport is destroyed, the sink must be unregistered by setting it to // nullptr. virtual void SetDataSink(DataChannelSink* sink) = 0; // Returns whether this data channel transport is ready to send. // Note: the default implementation always returns false (as it assumes no one // has implemented the interface). This default implementation is temporary. virtual bool IsReadyToSend() const = 0; }; } // namespace webrtc #endif // API_TRANSPORT_DATA_CHANNEL_TRANSPORT_INTERFACE_H_