1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109
|
// Copyright 2017 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifdef UNSAFE_BUFFERS_BUILD
// TODO(crbug.com/390223051): Remove C-library calls to fix the errors.
#pragma allow_unsafe_libc_calls
#endif
#include "net/quic/mock_decrypter.h"
#include <limits>
#include "net/third_party/quiche/src/quiche/quic/core/quic_utils.h"
#include "net/third_party/quiche/src/quiche/quic/platform/api/quic_bug_tracker.h"
using quic::DiversificationNonce;
using quic::Perspective;
using quic::QuicPacketNumber;
namespace net {
namespace {
const size_t kPaddingSize = 12;
} // namespace
MockDecrypter::MockDecrypter(Perspective perspective) {}
bool MockDecrypter::SetKey(std::string_view key) {
return key.empty();
}
bool MockDecrypter::SetNoncePrefix(std::string_view nonce_prefix) {
return nonce_prefix.empty();
}
bool MockDecrypter::SetIV(std::string_view iv) {
return iv.empty();
}
bool MockDecrypter::SetHeaderProtectionKey(std::string_view key) {
return key.empty();
}
size_t MockDecrypter::GetKeySize() const {
return 0;
}
size_t MockDecrypter::GetIVSize() const {
return 0;
}
size_t MockDecrypter::GetNoncePrefixSize() const {
return 0;
}
bool MockDecrypter::SetPreliminaryKey(std::string_view key) {
LOG(DFATAL) << "Should not be called";
return false;
}
bool MockDecrypter::SetDiversificationNonce(const DiversificationNonce& nonce) {
LOG(DFATAL) << "Should not be called";
return true;
}
bool MockDecrypter::DecryptPacket(uint64_t /*packet_number*/,
std::string_view associated_data,
std::string_view ciphertext,
char* output,
size_t* output_length,
size_t max_output_length) {
if (ciphertext.length() < kPaddingSize) {
return false;
}
size_t plaintext_size = ciphertext.length() - kPaddingSize;
if (plaintext_size > max_output_length) {
return false;
}
memcpy(output, ciphertext.data(), plaintext_size);
*output_length = plaintext_size;
return true;
}
std::string MockDecrypter::GenerateHeaderProtectionMask(
quic::QuicDataReader* sample_reader) {
return std::string(5, 0);
}
uint32_t MockDecrypter::cipher_id() const {
return 0;
}
quic::QuicPacketCount MockDecrypter::GetIntegrityLimit() const {
return std::numeric_limits<quic::QuicPacketCount>::max();
}
std::string_view MockDecrypter::GetKey() const {
return std::string_view();
}
std::string_view MockDecrypter::GetNoncePrefix() const {
return std::string_view();
}
} // namespace net
|