/* * 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_DEGRADED_CALL_H_ #define CALL_DEGRADED_CALL_H_ #include #include #include #include #include "absl/types/optional.h" #include "api/call/transport.h" #include "api/fec_controller.h" #include "api/media_types.h" #include "api/rtp_headers.h" #include "api/test/simulated_network.h" #include "api/video_codecs/video_encoder_config.h" #include "call/audio_receive_stream.h" #include "call/audio_send_stream.h" #include "call/call.h" #include "call/fake_network_pipe.h" #include "call/flexfec_receive_stream.h" #include "call/packet_receiver.h" #include "call/rtp_transport_controller_send_interface.h" #include "call/simulated_network.h" #include "call/video_receive_stream.h" #include "call/video_send_stream.h" #include "modules/utility/include/process_thread.h" #include "rtc_base/copy_on_write_buffer.h" #include "rtc_base/network/sent_packet.h" #include "rtc_base/task_queue.h" #include "system_wrappers/include/clock.h" namespace webrtc { class DegradedCall : public Call, private PacketReceiver { public: explicit DegradedCall( std::unique_ptr call, absl::optional send_config, absl::optional receive_config, TaskQueueFactory* task_queue_factory); ~DegradedCall() override; // Implements Call. AudioSendStream* CreateAudioSendStream( const AudioSendStream::Config& config) override; void DestroyAudioSendStream(AudioSendStream* send_stream) override; AudioReceiveStream* CreateAudioReceiveStream( const AudioReceiveStream::Config& config) override; void DestroyAudioReceiveStream(AudioReceiveStream* receive_stream) override; VideoSendStream* CreateVideoSendStream( VideoSendStream::Config config, VideoEncoderConfig encoder_config) override; VideoSendStream* CreateVideoSendStream( VideoSendStream::Config config, VideoEncoderConfig encoder_config, std::unique_ptr fec_controller) override; void DestroyVideoSendStream(VideoSendStream* send_stream) override; VideoReceiveStream* CreateVideoReceiveStream( VideoReceiveStream::Config configuration) override; void DestroyVideoReceiveStream(VideoReceiveStream* receive_stream) override; FlexfecReceiveStream* CreateFlexfecReceiveStream( const FlexfecReceiveStream::Config& config) override; void DestroyFlexfecReceiveStream( FlexfecReceiveStream* receive_stream) override; void AddAdaptationResource(rtc::scoped_refptr resource) override; PacketReceiver* Receiver() override; RtpTransportControllerSendInterface* GetTransportControllerSend() override; Stats GetStats() const override; const WebRtcKeyValueConfig& trials() const override; TaskQueueBase* network_thread() const override; TaskQueueBase* worker_thread() const override; void SignalChannelNetworkState(MediaType media, NetworkState state) override; void OnAudioTransportOverheadChanged( int transport_overhead_per_packet) override; void OnSentPacket(const rtc::SentPacket& sent_packet) override; protected: // Implements PacketReceiver. DeliveryStatus DeliverPacket(MediaType media_type, rtc::CopyOnWriteBuffer packet, int64_t packet_time_us) override; private: class FakeNetworkPipeOnTaskQueue { public: FakeNetworkPipeOnTaskQueue( TaskQueueFactory* task_queue_factory, Clock* clock, std::unique_ptr network_behavior); void SendRtp(const uint8_t* packet, size_t length, const PacketOptions& options, Transport* transport); void SendRtcp(const uint8_t* packet, size_t length, Transport* transport); void AddActiveTransport(Transport* transport); void RemoveActiveTransport(Transport* transport); private: // Try to process packets on the fake network queue. // Returns true if call resulted in a delayed process, false if queue empty. bool Process(); Clock* const clock_; rtc::TaskQueue task_queue_; FakeNetworkPipe pipe_; absl::optional next_process_ms_ RTC_GUARDED_BY(&task_queue_); }; // For audio/video send stream, a TransportAdapter instance is used to // intercept packets to be sent, and put them into a common FakeNetworkPipe // in such as way that they will eventually (unless dropped) be forwarded to // the correct Transport for that stream. class FakeNetworkPipeTransportAdapter : public Transport { public: FakeNetworkPipeTransportAdapter(FakeNetworkPipeOnTaskQueue* fake_network, Call* call, Clock* clock, Transport* real_transport); ~FakeNetworkPipeTransportAdapter(); bool SendRtp(const uint8_t* packet, size_t length, const PacketOptions& options) override; bool SendRtcp(const uint8_t* packet, size_t length) override; private: FakeNetworkPipeOnTaskQueue* const network_pipe_; Call* const call_; Clock* const clock_; Transport* const real_transport_; }; Clock* const clock_; const std::unique_ptr call_; TaskQueueFactory* const task_queue_factory_; void SetClientBitratePreferences( const webrtc::BitrateSettings& preferences) override {} const absl::optional send_config_; SimulatedNetwork* send_simulated_network_; std::unique_ptr send_pipe_; std::map> audio_send_transport_adapters_; std::map> video_send_transport_adapters_; const absl::optional receive_config_; SimulatedNetwork* receive_simulated_network_; std::unique_ptr receive_pipe_; }; } // namespace webrtc #endif // CALL_DEGRADED_CALL_H_