Botan 3.8.1
Crypto and TLS for C&
|
#include <tls_server_impl_13.h>
Public Member Functions | |
std::string | application_protocol () const override |
void | close () |
bool | expects_downgrade () const |
std::optional< std::string > | external_psk_identity () const override |
std::unique_ptr< Downgrade_Information > | extract_downgrade_info () |
size_t | from_peer (std::span< const uint8_t > data) override |
bool | is_active () const override |
bool | is_closed () const override |
bool | is_closed_for_reading () const override |
bool | is_closed_for_writing () const override |
bool | is_downgrading () const |
bool | is_handshake_complete () const override |
SymmetricKey | key_material_export (std::string_view label, std::string_view context, size_t length) const override |
bool | new_session_ticket_supported () const override |
std::vector< X509_Certificate > | peer_cert_chain () const override |
std::shared_ptr< const Public_Key > | peer_raw_public_key () const override |
void | renegotiate (bool) override |
bool | secure_renegotiation_supported () const override |
void | send_alert (const Alert &alert) override |
void | send_fatal_alert (Alert::Type type) |
size_t | send_new_session_tickets (size_t tickets) override |
void | send_warning_alert (Alert::Type type) |
Server_Impl_13 (const std::shared_ptr< Callbacks > &callbacks, const std::shared_ptr< Session_Manager > &session_manager, const std::shared_ptr< Credentials_Manager > &credentials_manager, const std::shared_ptr< const Policy > &policy, const std::shared_ptr< RandomNumberGenerator > &rng) | |
bool | timeout_check () override |
void | to_peer (std::span< const uint8_t > data) override |
void | update_traffic_keys (bool request_peer_update=false) override |
Protected Attributes | |
std::unique_ptr< Cipher_State > | m_cipher_state |
std::unique_ptr< Downgrade_Information > | m_downgrade_info |
const Connection_Side | m_side |
Transcript_Hash_State | m_transcript_hash |
SSL/TLS Server 1.3 implementation
Definition at line 22 of file tls_server_impl_13.h.
|
explicit |
Definition at line 19 of file tls_server_impl_13.cpp.
References Botan::TLS::Channel_Impl_13::callbacks(), Botan::TLS::Channel_Impl_13::Channel_Impl_13(), Botan::TLS::Channel_Impl_13::credentials_manager(), Botan::TLS::Channel_Impl_13::policy(), Botan::TLS::Channel_Impl_13::rng(), and Botan::TLS::Channel_Impl_13::session_manager().
|
inlineprotectedinherited |
Definition at line 256 of file tls_channel_impl_13.h.
References m_transcript_hash.
Referenced by send_handshake_message().
|
inlineprotectedinherited |
Definition at line 260 of file tls_channel_impl_13.h.
Referenced by Botan::TLS::Server_Impl_13::send_new_session_tickets(), and send_post_handshake_message().
|
overridevirtual |
Return the protocol notification set for this connection, if any (ALPN). This value is not tied to the session and a later renegotiation of the same session can choose a new protocol.
Implements Botan::TLS::Channel_Impl.
Definition at line 34 of file tls_server_impl_13.cpp.
References application_protocol(), and is_handshake_complete().
Referenced by application_protocol().
|
inlineprotectedinherited |
Definition at line 264 of file tls_channel_impl_13.h.
Referenced by Channel_Impl_13(), Botan::TLS::Client_Impl_13::Client_Impl_13(), from_peer(), Botan::TLS::Server_Impl_13::send_new_session_tickets(), and Botan::TLS::Server_Impl_13::Server_Impl_13().
|
inlineinherited |
Send a close notification alert
Definition at line 81 of file tls_channel_impl.h.
References send_warning_alert().
|
inlineprotectedinherited |
Definition at line 268 of file tls_channel_impl_13.h.
Referenced by Channel_Impl_13(), and Botan::TLS::Server_Impl_13::Server_Impl_13().
|
protectedinherited |
Indicate that we have to expect a downgrade to TLS 1.2. In which case the current implementation (i.e. Client_Impl_13 or Server_Impl_13) will need to be replaced by their respective counter parts.
This will prepare an internal structure where any information required to downgrade can be preserved.
Definition at line 402 of file tls_channel_impl_13.cpp.
References Botan::TLS::Channel::IO_BUF_DEFAULT_SIZE, and Botan::TLS::Channel_Impl::m_downgrade_info.
|
inlineinherited |
Definition at line 279 of file tls_channel_impl.h.
References m_downgrade_info.
Referenced by Botan::TLS::Client_Impl_13::Client_Impl_13(), and Botan::TLS::Channel_Impl_13::from_peer().
|
overridevirtual |
Implements Botan::TLS::Channel_Impl.
Definition at line 70 of file tls_server_impl_13.cpp.
References external_psk_identity().
Referenced by external_psk_identity().
|
inlineinherited |
Definition at line 277 of file tls_channel_impl.h.
References m_downgrade_info.
|
overridevirtualinherited |
Inject TLS traffic received from counterparty
Implements Botan::TLS::Channel_Impl.
Definition at line 68 of file tls_channel_impl_13.cpp.
References Botan::TLS::Alert, Botan::TLS::ApplicationData, BOTAN_ASSERT, BOTAN_STATE_CHECK, callbacks(), Botan::TLS::ChangeCipherSpec, Botan::TLS::Channel_Impl::expects_downgrade(), Botan::TLS::Handshake, Botan::holds_any_of(), Botan::TLS::Channel_Impl::is_downgrading(), Botan::TLS::Channel_Impl::is_handshake_complete(), m_cipher_state, Botan::TLS::Channel_Impl::m_downgrade_info, m_transcript_hash, policy(), Botan::TLS::Channel_Impl::preserve_peer_transcript(), process_dummy_change_cipher_spec(), process_handshake_msg(), process_post_handshake_msg(), Botan::TLS::Channel_Impl::send_fatal_alert(), Botan::TLS::Callbacks::tls_record_received(), and Botan::TLS::TLS_Exception::type().
|
overridevirtualinherited |
Note that the connection is active until the application has called close()
, even if a CloseNotify has been received from the peer.
Implements Botan::TLS::Channel_Impl.
Definition at line 304 of file tls_channel_impl_13.cpp.
References m_cipher_state.
Referenced by to_peer().
|
inlineoverridevirtualinherited |
Implements Botan::TLS::Channel_Impl.
Definition at line 167 of file tls_channel_impl_13.h.
References is_closed_for_reading(), and is_closed_for_writing().
|
inlineoverridevirtualinherited |
Implements Botan::TLS::Channel_Impl.
Definition at line 169 of file tls_channel_impl_13.h.
Referenced by is_closed().
|
inlineoverridevirtualinherited |
Implements Botan::TLS::Channel_Impl.
Definition at line 171 of file tls_channel_impl_13.h.
Referenced by is_closed().
|
inlineinherited |
Indicates whether a downgrade to TLS 1.2 or lower is in progress
Definition at line 272 of file tls_channel_impl.h.
References m_downgrade_info.
Referenced by Botan::TLS::Channel_Impl_13::from_peer(), Botan::TLS::Channel_Impl_13::key_material_export(), and Botan::TLS::Channel_Impl_13::update_traffic_keys().
|
overridevirtual |
Implements Botan::TLS::Channel_Impl.
Definition at line 166 of file tls_server_impl_13.cpp.
References is_handshake_complete().
Referenced by application_protocol(), is_handshake_complete(), new_session_ticket_supported(), and send_new_session_tickets().
|
overridevirtualinherited |
Key material export (RFC 5705)
label | a disambiguating label string |
context | a per-association context value |
length | the length of the desired key in bytes |
Implements Botan::TLS::Channel_Impl.
Definition at line 309 of file tls_channel_impl_13.cpp.
References BOTAN_STATE_CHECK, Botan::TLS::Channel_Impl::is_downgrading(), and m_cipher_state.
|
overridevirtual |
Reimplemented from Botan::TLS::Channel_Impl.
Definition at line 74 of file tls_server_impl_13.cpp.
References is_handshake_complete(), Botan::TLS::PSK_Key_Exchange_Modes::modes(), new_session_ticket_supported(), Botan::TLS::PSK_DHE_KE, and Botan::value_exists().
Referenced by new_session_ticket_supported().
|
inlineprotectedinherited |
Schedule a traffic key update to opportunistically happen before the channel sends application data the next time. Such a key update will never request a reciprocal key update from the peer.
Definition at line 238 of file tls_channel_impl_13.h.
Referenced by handle().
|
overridevirtual |
Implements Botan::TLS::Channel_Impl.
Definition at line 45 of file tls_server_impl_13.cpp.
References peer_cert_chain().
Referenced by peer_cert_chain(), and send_new_session_tickets().
|
overridevirtual |
Implements Botan::TLS::Channel_Impl.
Definition at line 58 of file tls_server_impl_13.cpp.
References peer_raw_public_key().
Referenced by peer_raw_public_key(), and send_new_session_tickets().
|
inlineprotectedinherited |
Definition at line 272 of file tls_channel_impl_13.h.
Referenced by Channel_Impl_13(), Botan::TLS::Client_Impl_13::Client_Impl_13(), from_peer(), Botan::TLS::Server_Impl_13::send_new_session_tickets(), and Botan::TLS::Server_Impl_13::Server_Impl_13().
|
inlineprotectedvirtualinherited |
This method can be used by subclasses to indicate that send_record should prepend a CCS before the actual record. This is useful for middlebox compatibility mode. See RFC 8446 D.4.
Definition at line 229 of file tls_channel_impl_13.h.
|
inlineprotectedinherited |
Definition at line 232 of file tls_channel_impl.h.
References BOTAN_STATE_CHECK, and m_downgrade_info.
Referenced by Botan::TLS::Client_Impl_13::Client_Impl_13().
|
inlineprotectedinherited |
Definition at line 227 of file tls_channel_impl.h.
References BOTAN_STATE_CHECK, and m_downgrade_info.
Referenced by Botan::TLS::Channel_Impl_13::from_peer().
|
inlineoverridevirtualinherited |
Attempt to renegotiate the session
Implements Botan::TLS::Channel_Impl.
Definition at line 185 of file tls_channel_impl_13.h.
|
inlineprotectedinherited |
Implementations use this to signal that the peer indicated a protocol version downgrade. After calling request_downgrade()
no further state changes must be perfomed by the implementation. Particularly, no further handshake messages must be emitted. Instead, they must yield control flow back to the underlying Channel implementation to perform the protocol version downgrade.
Definition at line 253 of file tls_channel_impl.h.
References BOTAN_STATE_CHECK, and m_downgrade_info.
Referenced by request_downgrade_for_resumption().
|
inlineprotectedinherited |
Definition at line 258 of file tls_channel_impl.h.
References BOTAN_ASSERT_NOMSG, BOTAN_STATE_CHECK, Botan::TLS::Protocol_Version::is_pre_tls_13(), m_downgrade_info, request_downgrade(), Botan::TLS::Session_with_Handle::session, and Botan::TLS::Session_Base::version().
Referenced by Botan::TLS::Client_Impl_13::Client_Impl_13().
|
inlineprotectedinherited |
Definition at line 270 of file tls_channel_impl_13.h.
Referenced by Channel_Impl_13(), Botan::TLS::Client_Impl_13::Client_Impl_13(), Botan::TLS::Server_Impl_13::send_new_session_tickets(), and Botan::TLS::Server_Impl_13::Server_Impl_13().
|
inlineoverridevirtualinherited |
Implements Botan::TLS::Channel_Impl.
Definition at line 201 of file tls_channel_impl_13.h.
|
overridevirtualinherited |
Send a TLS alert message. If the alert is fatal, the internal state (keys, etc) will be reset.
alert | the Alert to send |
Implements Botan::TLS::Channel_Impl.
Definition at line 279 of file tls_channel_impl_13.cpp.
References Botan::TLS::Alert, Botan::TLS::Alert::is_valid(), m_cipher_state, and Botan::TLS::Alert::serialize().
|
protectedinherited |
Definition at line 248 of file tls_channel_impl_13.cpp.
References Botan::TLS::ChangeCipherSpec.
|
inlineinherited |
Send a fatal alert
Definition at line 76 of file tls_channel_impl.h.
References Botan::TLS::Alert, and send_alert().
Referenced by Botan::TLS::Channel_Impl_12::from_peer(), and Botan::TLS::Channel_Impl_13::from_peer().
|
inlineprotectedinherited |
Definition at line 241 of file tls_channel_impl_13.h.
References Botan::TLS::Channel_Impl_13::AggregatedHandshakeMessages::add(), aggregate_handshake_messages(), Botan::generalize_to(), and Botan::TLS::Channel_Impl_13::AggregatedMessages::send().
Referenced by Botan::TLS::Client_Impl_13::Client_Impl_13(), and send_handshake_message().
|
inlineprotectedinherited |
Definition at line 246 of file tls_channel_impl_13.h.
References Botan::generalize_to(), and send_handshake_message().
|
overridevirtual |
Send tickets
new session tickets to the peer. This is only supported on TLS 1.3 servers.
If the server's Session_Manager does not accept the generated Session objects, the server implementation won't be able to send new tickets. Additionally, anything but TLS 1.3 servers will return 0 (because they don't support sending such session tickets).
Reimplemented from Botan::TLS::Channel_Impl.
Definition at line 90 of file tls_server_impl_13.cpp.
References Botan::TLS::Channel_Impl_13::aggregate_post_handshake_messages(), BOTAN_STATE_CHECK, Botan::TLS::Channel_Impl_13::callbacks(), is_handshake_complete(), Botan::TLS::Channel_Impl_13::m_cipher_state, peer_cert_chain(), peer_raw_public_key(), Botan::TLS::Channel_Impl_13::policy(), Botan::TLS::Channel_Impl_13::rng(), send_new_session_tickets(), and Botan::TLS::Channel_Impl_13::session_manager().
Referenced by send_new_session_tickets().
|
inlineprotectedinherited |
Definition at line 250 of file tls_channel_impl_13.h.
References Botan::TLS::Channel_Impl_13::AggregatedPostHandshakeMessages::add(), aggregate_post_handshake_messages(), and Botan::TLS::Channel_Impl_13::AggregatedMessages::send().
Referenced by update_traffic_keys().
|
inlineinherited |
Send a warning alert
Definition at line 71 of file tls_channel_impl.h.
References Botan::TLS::Alert, and send_alert().
Referenced by close().
|
inlineprotectedinherited |
Definition at line 266 of file tls_channel_impl_13.h.
Referenced by Channel_Impl_13(), Botan::TLS::Client_Impl_13::Client_Impl_13(), Botan::TLS::Server_Impl_13::send_new_session_tickets(), and Botan::TLS::Server_Impl_13::Server_Impl_13().
|
inlineprotectedinherited |
Definition at line 240 of file tls_channel_impl.h.
References BOTAN_STATE_CHECK, and m_downgrade_info.
|
protectedinherited |
Set the record size limits as negotiated by the "record_size_limit" extension (RFC 8449).
outgoing_limit | the maximal number of plaintext bytes to be sent in a protected record |
incoming_limit | the maximal number of plaintext bytes to be accepted in a received protected record |
Definition at line 422 of file tls_channel_impl_13.cpp.
|
protectedinherited |
Set the expected certificate type needed to parse Certificate messages in the handshake layer. See RFC 7250 and 8446 4.4.2 for further details.
Definition at line 426 of file tls_channel_impl_13.cpp.
|
inlineoverridevirtualinherited |
Perform a handshake timeout check. This does nothing unless this is a DTLS channel with a pending handshake state, in which case we check for timeout and potentially retransmit handshake packets.
In the TLS 1.3 implementation, this always returns false.
Implements Botan::TLS::Channel_Impl.
Definition at line 215 of file tls_channel_impl_13.h.
|
overridevirtualinherited |
Inject plaintext intended for counterparty Throws an exception if is_active() is false
Implements Botan::TLS::Channel_Impl.
Definition at line 258 of file tls_channel_impl_13.cpp.
References Botan::TLS::ApplicationData, is_active(), and update_traffic_keys().
|
overridevirtualinherited |
Attempt to update the session's traffic key material Note that this is possible with a TLS 1.3 channel, only.
request_peer_update | if true, require a reciprocal key update |
Implements Botan::TLS::Channel_Impl.
Definition at line 317 of file tls_channel_impl_13.cpp.
References BOTAN_ASSERT_NONNULL, BOTAN_STATE_CHECK, Botan::TLS::Channel_Impl::is_downgrading(), Botan::TLS::Channel_Impl::is_handshake_complete(), m_cipher_state, and send_post_handshake_message().
Referenced by to_peer().
|
protectedinherited |
Definition at line 288 of file tls_channel_impl_13.h.
Referenced by from_peer(), handle(), is_active(), key_material_export(), send_alert(), Botan::TLS::Server_Impl_13::send_new_session_tickets(), and update_traffic_keys().
|
protectedinherited |
Definition at line 225 of file tls_channel_impl.h.
Referenced by Botan::TLS::Channel_Impl_13::expect_downgrade(), expects_downgrade(), extract_downgrade_info(), Botan::TLS::Channel_Impl_13::from_peer(), is_downgrading(), preserve_client_hello(), preserve_peer_transcript(), request_downgrade(), request_downgrade_for_resumption(), and set_io_buffer_size().
|
protectedinherited |
Definition at line 286 of file tls_channel_impl_13.h.
Referenced by Channel_Impl_13().
|
protectedinherited |
Definition at line 287 of file tls_channel_impl_13.h.
Referenced by aggregate_handshake_messages(), and from_peer().