Go to the documentation of this file.
119 #include "../crypto/internal.h"
144 #if !defined(BORINGSSL_UNSAFE_FUZZER_MODE)
145 return !ssl->
s3->aead_write_ctx->is_null_cipher() &&
155 for (
size_t i = seq_len - 1;
i < seq_len;
i--) {
173 return header_len + ssl->
s3->aead_read_ctx->ExplicitNonceLen();
192 ssl->
s3->early_data_skipped += consumed;
193 if (ssl->
s3->early_data_skipped < consumed) {
233 if (ssl->
s3->aead_read_ctx->is_null_cipher()) {
238 version_ok =
version == ssl->
s3->aead_read_ctx->RecordVersion();
266 if (ssl->
s3->have_version &&
270 ciphertext_len == 1 &&
272 ssl->
s3->empty_record_count++;
283 if (ssl->
s3->skip_early_data &&
284 ssl->
s3->aead_read_ctx->is_null_cipher() &&
290 if (!ssl->
s3->aead_read_ctx->Open(
293 if (ssl->
s3->skip_early_data && !ssl->
s3->aead_read_ctx->is_null_cipher()) {
303 ssl->
s3->skip_early_data =
false;
312 !ssl->
s3->aead_read_ctx->is_null_cipher() &&
317 size_t plaintext_limit =
319 if (
out->size() > plaintext_limit) {
346 ssl->
s3->empty_record_count++;
355 ssl->
s3->empty_record_count = 0;
370 ssl->
s3->warning_alert_count = 0;
378 const size_t in_len) {
381 size_t extra_in_len = 0;
389 size_t suffix_len, ciphertext_len;
390 if (!aead->
SuffixLen(&suffix_len, in_len, extra_in_len) ||
391 !aead->
CiphertextLen(&ciphertext_len, in_len, extra_in_len)) {
403 out_prefix[0] =
type;
408 out_prefix[1] = record_version >> 8;
409 out_prefix[2] = record_version & 0xff;
410 out_prefix[3] = ciphertext_len >> 8;
411 out_prefix[4] = ciphertext_len & 0xff;
415 out_prefix[0], record_version, ssl->
s3->write_sequence,
416 header,
in, in_len, extra_in, extra_in_len) ||
437 ret += ssl->
s3->aead_write_ctx->ExplicitNonceLen();
444 size_t extra_in_len = 0;
445 if (!ssl->
s3->aead_write_ctx->is_null_cipher() &&
459 return ssl->
s3->aead_write_ctx->SuffixLen(out_suffix_len, in_len, extra_in_len);
474 assert(ssl->
s3->aead_write_ctx->ExplicitNonceLen() == 0);
478 uint8_t *split_body = out_prefix + prefix_len;
479 uint8_t *split_suffix = split_body + 1;
486 size_t split_record_suffix_len;
487 if (!ssl->
s3->aead_write_ctx->SuffixLen(&split_record_suffix_len, 1, 0)) {
491 const size_t split_record_len = prefix_len + 1 + split_record_suffix_len;
493 ssl->
s3->aead_write_ctx->cipher()) ==
527 if (in_len + prefix_len < in_len ||
528 prefix_len + in_len + suffix_len < prefix_len + in_len) {
532 if (max_out_len < in_len + prefix_len + suffix_len) {
544 *out_len = prefix_len + in_len + suffix_len;
551 if (
in.size() != 2) {
562 uint16_t alert = (alert_level << 8) | alert_descr;
576 if (ssl->
s3->have_version &&
584 ssl->
s3->warning_alert_count++;
606 size_t *out_record_len,
uint8_t *out_alert,
615 return OpenRecordResult::kError;
627 return OpenRecordResult::kError;
630 return OpenRecordResult::kOK;
632 return OpenRecordResult::kDiscard;
634 return OpenRecordResult::kIncompleteRecord;
636 return OpenRecordResult::kAlertCloseNotify;
638 return OpenRecordResult::kError;
641 return OpenRecordResult::kError;
675 out.size() !=
in.size() ||
682 in.data(),
in.size());
687 using namespace bssl;
695 ret += ssl->
s3->aead_write_ctx->MaxOverhead();
697 if (!ssl->
s3->aead_write_ctx->is_null_cipher() &&
#define SSL3_VERSION_MAJOR
ssl_open_record_t tls_open_record(SSL *ssl, uint8_t *out_type, Span< uint8_t > *out, size_t *out_consumed, uint8_t *out_alert, Span< uint8_t > in)
#define SSL_AD_UNEXPECTED_MESSAGE
#define SSL_AD_USER_CANCELLED
@ ssl_open_record_partial
bool tls_seal_record(SSL *ssl, uint8_t *out, size_t *out_len, size_t max_out_len, uint8_t type, const uint8_t *in, size_t in_len)
#define SSL_AD_REASON_OFFSET
static bool tls_seal_scatter_suffix_len(const SSL *ssl, size_t *out_suffix_len, uint8_t type, size_t in_len)
#define SSL_R_WRONG_VERSION_NUMBER
static bool do_seal_record(SSL *ssl, uint8_t *out_prefix, uint8_t *out, uint8_t *out_suffix, uint8_t type, const uint8_t *in, const size_t in_len)
#define OPENSSL_PUT_ERROR(library, reason)
static bool tls_seal_scatter_record(SSL *ssl, uint8_t *out_prefix, uint8_t *out, uint8_t *out_suffix, uint8_t type, const uint8_t *in, size_t in_len)
#define SSL_CIPHER_is_block_cipher
#define SSL_AD_INTERNAL_ERROR
bool tls_can_accept_handshake_data(const SSL *ssl, uint8_t *out_alert)
static size_t tls_seal_scatter_prefix_len(const SSL *ssl, uint8_t type, size_t in_len)
bool SealRecord(SSL *ssl, const Span< uint8_t > out_prefix, const Span< uint8_t > out, Span< uint8_t > out_suffix, const Span< const uint8_t > in)
#define SSL_R_TOO_MANY_EMPTY_FRAGMENTS
enum ssl_open_record_t ssl_process_alert(SSL *ssl, uint8_t *out_alert, Span< const uint8_t > in)
#define SSL_R_OUTPUT_ALIASES_INPUT
uint16_t RecordVersion() const
#define SSL_AD_ILLEGAL_PARAMETER
static const BSSL_NAMESPACE_BEGIN uint8_t kMaxEmptyRecords
#define SSL_R_DECRYPTION_FAILED_OR_BAD_RECORD_MAC
static const size_t kMaxEarlyDataSkipped
void ssl_do_msg_callback(const SSL *ssl, int is_write, int content_type, Span< const uint8_t > in)
#define SSL3_RT_MAX_ENCRYPTED_LENGTH
static ssl_open_record_t skip_early_data(SSL *ssl, uint8_t *out_alert, size_t consumed)
#define SSL3_RT_MAX_PLAIN_LENGTH
#define DTLS1_RT_HEADER_LENGTH
#define SSL_R_TOO_MUCH_SKIPPED_EARLY_DATA
@ ssl_open_record_discard
#define ERR_add_error_dataf
#define SSL_R_UNEXPECTED_RECORD
size_t ssl_record_prefix_len(const SSL *ssl)
static void * OPENSSL_memcpy(void *dst, const void *src, size_t n)
#define BSSL_NAMESPACE_END
struct absl::base_internal::@2940::AllocList::Header header
#define SSL_AD_BAD_RECORD_MAC
#define ERR_R_INTERNAL_ERROR
uint16_t ssl_protocol_version(const SSL *ssl)
size_t ssl_seal_align_prefix_len(const SSL *ssl)
#define SSL_AD_PROTOCOL_VERSION
uint16_t ProtocolVersion() const
#define SSL_R_INVALID_OUTER_RECORD_TYPE
OpenRecordResult OpenRecord(SSL *ssl, Span< uint8_t > *out, size_t *out_record_len, uint8_t *out_alert, const Span< uint8_t > in)
#define SSL_AD_CLOSE_NOTIFY
#define SSL_R_UNKNOWN_ALERT_TYPE
size_t SSL_max_seal_overhead(const SSL *ssl)
#define SSL_R_TOO_MANY_WARNING_ALERTS
#define SSL3_RT_HANDSHAKE
#define SSL_CB_READ_ALERT
@ ssl_open_record_close_notify
bool ssl_record_sequence_update(uint8_t *seq, size_t seq_len)
bool SuffixLen(size_t *out_suffix_len, size_t in_len, size_t extra_in_len) const
static const uint8_t kMaxWarningAlerts
size_t SealRecordSuffixLen(const SSL *ssl, const size_t plaintext_len)
#define SSL_MODE_CBC_RECORD_SPLITTING
#define SSL3_RT_CHANGE_CIPHER_SPEC
unsigned char suffix[65536]
@ ssl_open_record_success
#define SSL_AD_RECORD_OVERFLOW
#define SSL_AD_DECODE_ERROR
UniquePtr< SSL_SESSION > ret
bool is_null_cipher() const
@ dtls1_use_current_epoch
static const char prefix[]
bool SealScatter(uint8_t *out_prefix, uint8_t *out, uint8_t *out_suffix, uint8_t type, uint16_t record_version, const uint8_t seqnum[8], Span< const uint8_t > header, const uint8_t *in, size_t in_len, const uint8_t *extra_in, size_t extra_in_len)
#define SSL_R_ENCRYPTED_LENGTH_TOO_LONG
bool tls_has_unprocessed_handshake_data(const SSL *ssl)
#define SSL_R_BUFFER_TOO_SMALL
@ ssl_shutdown_close_notify
#define SSL3_RT_MAX_ENCRYPTED_OVERHEAD
void ssl_do_info_callback(const SSL *ssl, int type, int value)
static int buffers_alias(const uint8_t *a, size_t a_len, const uint8_t *b, size_t b_len)
size_t SealRecordPrefixLen(const SSL *ssl, const size_t record_len)
#define SSL_R_DATA_LENGTH_TOO_LONG
static bool ssl_needs_record_splitting(const SSL *ssl)
#define SSL3_RT_APPLICATION_DATA
#define SSL_R_RECORD_TOO_LARGE
size_t dtls_max_seal_overhead(const SSL *ssl, enum dtls1_use_epoch_t use_epoch)
#define SSL_AD_DECRYPT_ERROR
constexpr Span< T > MakeSpan(T *ptr, size_t size) noexcept
#define SSL3_RT_HEADER_LENGTH
bool CiphertextLen(size_t *out_len, size_t in_len, size_t extra_in_len) const
size_t ssl_cipher_get_record_split_len(const SSL_CIPHER *cipher)
grpc
Author(s):
autogenerated on Thu Mar 13 2025 03:01:40