This change integrates the FrameDecryptorInterface and the FrameEncryptorInterface into the audio media path. If a FrameEncryptorInterface is set on an outgoing audio RTPSender then each outgoing audio payload will first pass through the provided FrameEncryptor which will have a chance to modify the payload contents for the purposes of encryption. If a FrameDecryptorInterface is set on an incoming audio RtpReceiver then each incoming audio payload will first pass through the provided FrameDecryptor which have a chance to modify the payload contents for the purpose of decryption. While AEAD is supported by the FrameDecryptor/FrameEncryptor interfaces this CL does not use it and so it is left as null. Bug: webrtc:9681 Change-Id: Ic383a9dce280528739f9d271357c2220e0a0dccf Reviewed-on: https://webrtc-review.googlesource.com/c/101702 Commit-Queue: Benjamin Wright <benwright@webrtc.org> Reviewed-by: Fredrik Solenberg <solenberg@webrtc.org> Reviewed-by: Steve Anton <steveanton@webrtc.org> Reviewed-by: Emad Omara <emadomara@webrtc.org> Cr-Commit-Position: refs/heads/master@{#25001}
70 lines
2.0 KiB
C++
70 lines
2.0 KiB
C++
/*
|
|
* Copyright 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.
|
|
*/
|
|
|
|
#include "api/test/fake_frame_decryptor.h"
|
|
#include <vector>
|
|
#include "rtc_base/checks.h"
|
|
|
|
namespace webrtc {
|
|
|
|
FakeFrameDecryptor::FakeFrameDecryptor(uint8_t fake_key,
|
|
uint8_t expected_postfix_byte)
|
|
: fake_key_(fake_key), expected_postfix_byte_(expected_postfix_byte) {}
|
|
|
|
int FakeFrameDecryptor::Decrypt(cricket::MediaType media_type,
|
|
const std::vector<uint32_t>& csrcs,
|
|
rtc::ArrayView<const uint8_t> additional_data,
|
|
rtc::ArrayView<const uint8_t> encrypted_frame,
|
|
rtc::ArrayView<uint8_t> frame,
|
|
size_t* bytes_written) {
|
|
if (fail_decryption_) {
|
|
return 1;
|
|
}
|
|
|
|
RTC_CHECK_EQ(frame.size() + 1, encrypted_frame.size());
|
|
for (size_t i = 0; i < frame.size(); i++) {
|
|
frame[i] ^= fake_key_;
|
|
}
|
|
|
|
if (encrypted_frame[frame.size()] != expected_postfix_byte_) {
|
|
return 1;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
size_t FakeFrameDecryptor::GetMaxPlaintextByteSize(
|
|
cricket::MediaType media_type,
|
|
size_t encrypted_frame_size) {
|
|
return encrypted_frame_size - 1;
|
|
}
|
|
|
|
void FakeFrameDecryptor::SetFakeKey(uint8_t fake_key) {
|
|
fake_key_ = fake_key;
|
|
}
|
|
|
|
uint8_t FakeFrameDecryptor::GetFakeKey() const {
|
|
return fake_key_;
|
|
}
|
|
|
|
void FakeFrameDecryptor::SetExpectedPostfixByte(uint8_t expected_postfix_byte) {
|
|
expected_postfix_byte_ = expected_postfix_byte;
|
|
}
|
|
|
|
uint8_t FakeFrameDecryptor::GetExpectedPostfixByte() const {
|
|
return expected_postfix_byte_;
|
|
}
|
|
|
|
void FakeFrameDecryptor::SetFailDecryption(bool fail_decryption) {
|
|
fail_decryption_ = fail_decryption;
|
|
}
|
|
|
|
} // namespace webrtc
|