13#ifndef BOTAN_TLS_EXTENSIONS_H_
14#define BOTAN_TLS_EXTENSIONS_H_
16#include <botan/assert.h>
17#include <botan/tls_algos.h>
18#include <botan/tls_magic.h>
19#include <botan/tls_signature_scheme.h>
20#include <botan/tls_version.h>
113 std::string
host_name()
const {
return m_sni_host_name; }
117 bool empty()
const override {
return false; }
119 static bool hostname_acceptable_for_sni(std::string_view hostname);
122 std::string m_sni_host_name;
134 const std::vector<std::string>&
protocols()
const {
return m_protocols; }
136 std::string single_protocol()
const;
142 m_protocols(1, std::string(protocol)) {}
154 bool empty()
const override {
return m_protocols.empty(); }
157 std::vector<std::string> m_protocols;
176 const std::vector<Certificate_Type>& server_preference);
196 std::vector<Certificate_Type> m_certificate_types;
237 const std::vector<Group_Params>& groups()
const;
240 std::vector<Group_Params> ec_groups()
const;
243 std::vector<Group_Params> dh_groups()
const;
251 bool empty()
const override {
return m_groups.empty(); }
254 std::vector<Group_Params> m_groups;
270 bool empty()
const override {
return m_schemes.empty(); }
277 std::vector<Signature_Scheme> m_schemes;
303 bool empty()
const override {
return m_schemes.empty(); }
310 std::vector<Signature_Scheme> m_schemes;
322 const std::vector<uint16_t>&
profiles()
const {
return m_pp; }
326 bool empty()
const override {
return m_pp.empty(); }
335 std::vector<uint16_t> m_pp;
338class Certificate_Status_Request_Internal;
351 bool empty()
const override {
return false; }
362 std::vector<std::vector<uint8_t>> ocsp_key_ids);
368 uint16_t extension_size,
375 std::unique_ptr<Certificate_Status_Request_Internal> m_impl;
389 bool empty()
const override {
return m_versions.empty(); }
399 const std::vector<Protocol_Version>&
versions()
const {
return m_versions; }
402 std::vector<Protocol_Version> m_versions;
422 uint16_t
limit()
const {
return m_limit; }
426 bool empty()
const override {
return m_limit == 0; }
441 const std::vector<uint8_t>&
value() {
return m_value; }
443 bool empty()
const override {
return false; }
451 std::vector<uint8_t> m_value;
461 const std::vector<std::unique_ptr<Extension>>&
all()
const {
return m_extensions; }
463 template <
typename T>
465 return dynamic_cast<T*
>(
get(T::static_type()));
468 template <
typename T>
470 return get<T>() !=
nullptr;
475 size_t size()
const {
return m_extensions.size(); }
477 bool empty()
const {
return m_extensions.empty(); }
479 void add(std::unique_ptr<Extension> extn);
494 bool contains_other_than(
const std::set<Extension_Code>& allowed_extensions,
495 bool allow_unknown_extensions =
false)
const;
510 template <
typename T>
514 auto ext =
take(T::static_type());
516 out_ptr.reset(
dynamic_cast<T*
>(ext.get()));
551 std::vector<std::unique_ptr<Extension>> m_extensions;
#define BOTAN_UNSTABLE_API
#define BOTAN_ASSERT_NOMSG(expr)
Application_Layer_Protocol_Notification(std::string_view protocol)
const std::vector< std::string > & protocols() const
Application_Layer_Protocol_Notification(const std::vector< std::string > &protocols)
Extension_Code type() const override
bool empty() const override
static Extension_Code static_type()
const std::vector< uint8_t > & get_request_extensions() const
~Certificate_Status_Request() override
const std::vector< uint8_t > & get_responder_id_list() const
Certificate_Status_Request()
static Extension_Code static_type()
const std::vector< uint8_t > & get_ocsp_response() const
Extension_Code type() const override
bool empty() const override
bool empty() const override
Certificate_Type selected_certificate_type() const
Certificate_Type_Base(std::vector< Certificate_Type > supported_cert_types)
void validate_selection(const Certificate_Type_Base &from_server) const
std::vector< uint8_t > serialize(Connection_Side whoami) const override
Extension_Code type() const override
Client_Certificate_Type(const Client_Certificate_Type &cct, const Policy &policy)
Certificate_Type_Base(std::vector< Certificate_Type > supported_cert_types)
static Extension_Code static_type()
virtual std::vector< uint8_t > serialize(Connection_Side whoami) const =0
virtual bool is_implemented() const
virtual Extension_Code type() const =0
virtual bool empty() const =0
virtual ~Extension()=default
Extensions(Extensions &&)=default
void add(Extension *extn)
bool contains_implemented_extensions_other_than(const std::set< Extension_Code > &allowed_extensions) const
Extensions & operator=(const Extensions &)=delete
Extensions(const Extensions &)=delete
void deserialize(TLS_Data_Reader &reader, Connection_Side from, Handshake_Type message_type)
Extensions(TLS_Data_Reader &reader, Connection_Side side, Handshake_Type message_type)
Extensions & operator=(Extensions &&)=default
bool remove_extension(Extension_Code type)
std::set< Extension_Code > extension_types() const
bool has(Extension_Code type) const
const std::vector< std::unique_ptr< Extension > > & all() const
bool contains_other_than(const std::set< Extension_Code > &allowed_extensions, bool allow_unknown_extensions=false) const
Record_Size_Limit(uint16_t limit)
Extension_Code type() const override
static Extension_Code static_type()
bool empty() const override
Extension_Code type() const override
SRTP_Protection_Profiles(uint16_t pp)
bool empty() const override
SRTP_Protection_Profiles(const std::vector< uint16_t > &pp)
const std::vector< uint16_t > & profiles() const
static Extension_Code static_type()
static Extension_Code static_type()
Server_Certificate_Type(const Server_Certificate_Type &sct, const Policy &policy)
Certificate_Type_Base(std::vector< Certificate_Type > supported_cert_types)
Extension_Code type() const override
static Extension_Code static_type()
Extension_Code type() const override
std::string host_name() const
bool empty() const override
Server_Name_Indicator(std::string_view host_name)
static Extension_Code static_type()
bool empty() const override
Signature_Algorithms_Cert(std::vector< Signature_Scheme > schemes)
const std::vector< Signature_Scheme > & supported_schemes() const
Extension_Code type() const override
Signature_Algorithms(std::vector< Signature_Scheme > schemes)
const std::vector< Signature_Scheme > & supported_schemes() const
bool empty() const override
static Extension_Code static_type()
Extension_Code type() const override
bool empty() const override
Supported_Groups(const std::vector< Group_Params > &groups)
Extension_Code type() const override
static Extension_Code static_type()
static Extension_Code static_type()
Supported_Versions(Protocol_Version version, const Policy &policy)
const std::vector< Protocol_Version > & versions() const
bool empty() const override
Supported_Versions(Protocol_Version version)
Extension_Code type() const override
bool empty() const override
std::vector< uint8_t > serialize(Connection_Side whoami) const override
Unknown_Extension(Extension_Code type, TLS_Data_Reader &reader, uint16_t extension_size)
const std::vector< uint8_t > & value()
bool is_implemented() const override
Extension_Code type() const override
@ CertSignatureAlgorithms
@ ApplicationLayerProtocolNegotiation
@ CertificateStatusRequest
constexpr auto out_ptr(T &outptr) noexcept