1
0
mirror of https://github.com/facebookincubator/mvfst.git synced 2025-08-09 20:42:44 +03:00
Files
mvfst/quic/codec/PacketNumberCipher.cpp
Matt Joras 92c50dad6f Remove throws from PacketNumberCipher
Summary: Continuing the theme.

Reviewed By: kvtsoy

Differential Revision: D74944002

fbshipit-source-id: 9f23780aada2841ee88a365b93850fde4bb27a70
2025-05-19 13:49:37 -07:00

108 lines
3.3 KiB
C++

/*
* Copyright (c) Meta Platforms, Inc. and affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
#include <quic/codec/PacketNumberCipher.h>
#include <quic/codec/Decode.h>
#include <quic/codec/Types.h>
namespace quic {
folly::Expected<folly::Unit, QuicError> PacketNumberCipher::decipherHeader(
ByteRange sample,
MutableByteRange initialByte,
MutableByteRange packetNumberBytes,
uint8_t initialByteMask,
uint8_t /* packetNumLengthMask */) const {
CHECK_EQ(packetNumberBytes.size(), kMaxPacketNumEncodingSize);
auto maskResult = mask(sample);
if (maskResult.hasError()) {
return folly::makeUnexpected(maskResult.error());
}
HeaderProtectionMask headerMask = std::move(maskResult.value());
// Mask size should be > packet number length + 1.
DCHECK_GE(headerMask.size(), 5);
initialByte.data()[0] ^= headerMask.data()[0] & initialByteMask;
size_t packetNumLength = parsePacketNumberLength(*initialByte.data());
for (size_t i = 0; i < packetNumLength; ++i) {
packetNumberBytes.data()[i] ^= headerMask.data()[i + 1];
}
return folly::unit;
}
folly::Expected<folly::Unit, QuicError> PacketNumberCipher::cipherHeader(
ByteRange sample,
MutableByteRange initialByte,
MutableByteRange packetNumberBytes,
uint8_t initialByteMask,
uint8_t /* packetNumLengthMask */) const {
auto maskResult = mask(sample);
if (maskResult.hasError()) {
return folly::makeUnexpected(maskResult.error());
}
HeaderProtectionMask headerMask = std::move(maskResult.value());
// Mask size should be > packet number length + 1.
DCHECK_GE(headerMask.size(), kMaxPacketNumEncodingSize + 1);
size_t packetNumLength = parsePacketNumberLength(*initialByte.data());
initialByte.data()[0] ^= headerMask.data()[0] & initialByteMask;
for (size_t i = 0; i < packetNumLength; ++i) {
packetNumberBytes.data()[i] ^= headerMask.data()[i + 1];
}
return folly::unit;
}
folly::Expected<folly::Unit, QuicError> PacketNumberCipher::decryptLongHeader(
ByteRange sample,
MutableByteRange initialByte,
MutableByteRange packetNumberBytes) const {
return decipherHeader(
sample,
initialByte,
packetNumberBytes,
LongHeader::kTypeBitsMask,
LongHeader::kPacketNumLenMask);
}
folly::Expected<folly::Unit, QuicError> PacketNumberCipher::decryptShortHeader(
ByteRange sample,
MutableByteRange initialByte,
MutableByteRange packetNumberBytes) const {
return decipherHeader(
sample,
initialByte,
packetNumberBytes,
ShortHeader::kTypeBitsMask,
ShortHeader::kPacketNumLenMask);
}
folly::Expected<folly::Unit, QuicError> PacketNumberCipher::encryptLongHeader(
ByteRange sample,
MutableByteRange initialByte,
MutableByteRange packetNumberBytes) const {
return cipherHeader(
sample,
initialByte,
packetNumberBytes,
LongHeader::kTypeBitsMask,
LongHeader::kPacketNumLenMask);
}
folly::Expected<folly::Unit, QuicError> PacketNumberCipher::encryptShortHeader(
ByteRange sample,
MutableByteRange initialByte,
MutableByteRange packetNumberBytes) const {
return cipherHeader(
sample,
initialByte,
packetNumberBytes,
ShortHeader::kTypeBitsMask,
ShortHeader::kPacketNumLenMask);
}
} // namespace quic