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
|
// 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_encrypter.h"
#include "net/third_party/quiche/src/quiche/quic/core/quic_data_writer.h"
#include "net/third_party/quiche/src/quiche/quic/core/quic_utils.h"
using quic::DiversificationNonce;
using quic::Perspective;
using quic::QuicPacketNumber;
namespace net {
namespace {
const size_t kPaddingSize = 12;
} // namespace
MockEncrypter::MockEncrypter(Perspective perspective) {}
bool MockEncrypter::SetKey(std::string_view key) {
return key.empty();
}
bool MockEncrypter::SetNoncePrefix(std::string_view nonce_prefix) {
return nonce_prefix.empty();
}
bool MockEncrypter::SetIV(std::string_view iv) {
return iv.empty();
}
bool MockEncrypter::EncryptPacket(uint64_t /*packet_number*/,
std::string_view associated_data,
std::string_view plaintext,
char* output,
size_t* output_length,
size_t max_output_length) {
size_t ciphertext_size = plaintext.size() + kPaddingSize;
if (max_output_length < ciphertext_size) {
return false;
}
memcpy(output, plaintext.data(), ciphertext_size);
*output_length = ciphertext_size;
return true;
}
bool MockEncrypter::SetHeaderProtectionKey(std::string_view key) {
return key.empty();
}
std::string MockEncrypter::GenerateHeaderProtectionMask(
std::string_view sample) {
return std::string(5, 0);
}
size_t MockEncrypter::GetKeySize() const {
return 0;
}
size_t MockEncrypter::GetNoncePrefixSize() const {
return 0;
}
size_t MockEncrypter::GetIVSize() const {
return 0;
}
size_t MockEncrypter::GetMaxPlaintextSize(size_t ciphertext_size) const {
return ciphertext_size - kPaddingSize;
}
size_t MockEncrypter::GetCiphertextSize(size_t plaintext_size) const {
return plaintext_size + kPaddingSize;
}
quic::QuicPacketCount MockEncrypter::GetConfidentialityLimit() const {
return std::numeric_limits<quic::QuicPacketCount>::max();
}
std::string_view MockEncrypter::GetKey() const {
return std::string_view();
}
std::string_view MockEncrypter::GetNoncePrefix() const {
return std::string_view();
}
} // namespace net
|