mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-14 14:20:45 +01:00

The explicitly defined constructor suppresses the assignment operator, which blocks the chromium roll. Bug: b/198565646 Change-Id: I35917d4b99ad86dcf8b9863e798f5a63d9073824 Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/231123 Reviewed-by: Niels Moller <nisse@webrtc.org> Commit-Queue: Björn Terelius <terelius@webrtc.org> Cr-Commit-Position: refs/heads/main@{#34904}
125 lines
5 KiB
C++
125 lines
5 KiB
C++
/* 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<int> 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<int> 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_
|