| /* |
| * Copyright (c) 2018 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. |
| */ |
| #ifndef CALL_PACKET_RECEIVER_H_ |
| #define CALL_PACKET_RECEIVER_H_ |
| |
| #include "absl/functional/any_invocable.h" |
| #include "api/media_types.h" |
| #include "modules/rtp_rtcp/source/rtp_packet_received.h" |
| #include "rtc_base/checks.h" |
| #include "rtc_base/copy_on_write_buffer.h" |
| |
| namespace webrtc { |
| |
| class PacketReceiver { |
| public: |
| // Demux RTCP packets. Must be called on the worker thread. |
| virtual void DeliverRtcpPacket(rtc::CopyOnWriteBuffer packet) = 0; |
| |
| // Invoked once when a packet packet is received that can not be demuxed. |
| // If the method returns true, a new attempt is made to demux the packet. |
| using OnUndemuxablePacketHandler = |
| absl::AnyInvocable<bool(const RtpPacketReceived& parsed_packet)>; |
| |
| // Must be called on the worker thread. |
| // If `media_type` is not Audio or Video, packets may be used for BWE |
| // calculations but are not demuxed. |
| virtual void DeliverRtpPacket( |
| MediaType media_type, |
| RtpPacketReceived packet, |
| OnUndemuxablePacketHandler undemuxable_packet_handler) = 0; |
| |
| protected: |
| virtual ~PacketReceiver() {} |
| }; |
| |
| } // namespace webrtc |
| |
| #endif // CALL_PACKET_RECEIVER_H_ |