Botan 3.11.1
Crypto and TLS for C&
Botan::TLS::Supported_Groups Class Referencefinal

#include <tls_extensions.h>

Inheritance diagram for Botan::TLS::Supported_Groups:
Botan::TLS::Extension

Public Member Functions

std::vector< Group_Paramsdh_groups () const
std::vector< Group_Paramsec_groups () const
bool empty () const override
const std::vector< Group_Params > & groups () const
virtual bool is_implemented () const
std::vector< uint8_t > serialize (Connection_Side whoami) const override
 Supported_Groups (const std::vector< Group_Params > &groups)
 Supported_Groups (TLS_Data_Reader &reader, uint16_t extension_size)
Extension_Code type () const override

Static Public Member Functions

static Extension_Code static_type ()

Detailed Description

Supported Groups Extension (RFC 7919)

Definition at line 231 of file tls_extensions.h.

Constructor & Destructor Documentation

◆ Supported_Groups() [1/2]

Botan::TLS::Supported_Groups::Supported_Groups ( const std::vector< Group_Params > & groups)
explicit

Definition at line 531 of file tls_extensions.cpp.

531: m_groups(groups) {}
const std::vector< Group_Params > & groups() const

References groups().

◆ Supported_Groups() [2/2]

Botan::TLS::Supported_Groups::Supported_Groups ( TLS_Data_Reader & reader,
uint16_t extension_size )

Definition at line 575 of file tls_extensions.cpp.

575 {
576 const uint16_t len = reader.get_uint16_t();
577
578 if(len + 2 != extension_size) {
579 throw Decoding_Error("Inconsistent length field in supported groups list");
580 }
581
582 if(len % 2 == 1) {
583 throw Decoding_Error("Supported groups list of strange size");
584 }
585
586 const size_t elems = len / 2;
587
588 for(size_t i = 0; i != elems; ++i) {
589 const auto group = static_cast<Group_Params>(reader.get_uint16_t());
590 // Note: RFC 8446 does not explicitly enforce that groups must be unique.
591 if(!value_exists(m_groups, group)) {
592 m_groups.push_back(group);
593 }
594 }
595}
bool value_exists(const std::vector< T > &vec, const V &val)
Definition stl_util.h:43

References Botan::TLS::TLS_Data_Reader::get_uint16_t(), and Botan::value_exists().

Member Function Documentation

◆ dh_groups()

std::vector< Group_Params > Botan::TLS::Supported_Groups::dh_groups ( ) const

Definition at line 547 of file tls_extensions.cpp.

547 {
548 std::vector<Group_Params> dh;
549 for(auto g : m_groups) {
550 if(g.is_in_ffdhe_range()) {
551 dh.push_back(g);
552 }
553 }
554 return dh;
555}

◆ ec_groups()

std::vector< Group_Params > Botan::TLS::Supported_Groups::ec_groups ( ) const

Definition at line 537 of file tls_extensions.cpp.

537 {
538 std::vector<Group_Params> ec;
539 for(auto g : m_groups) {
540 if(g.is_pure_ecc_group()) {
541 ec.push_back(g);
542 }
543 }
544 return ec;
545}

Referenced by Botan::TLS::Client_Hello_13::Client_Hello_13().

◆ empty()

bool Botan::TLS::Supported_Groups::empty ( ) const
inlineoverridevirtual
Returns
if we should encode this extension or not

Implements Botan::TLS::Extension.

Definition at line 251 of file tls_extensions.h.

251{ return m_groups.empty(); }

◆ groups()

const std::vector< Group_Params > & Botan::TLS::Supported_Groups::groups ( ) const

Definition at line 533 of file tls_extensions.cpp.

533 {
534 return m_groups;
535}

Referenced by Supported_Groups().

◆ is_implemented()

virtual bool Botan::TLS::Extension::is_implemented ( ) const
inlinevirtualinherited
Returns
true if this extension is known and implemented by Botan

Reimplemented in Botan::TLS::Unknown_Extension.

Definition at line 95 of file tls_extensions.h.

95{ return true; }

◆ serialize()

std::vector< uint8_t > Botan::TLS::Supported_Groups::serialize ( Connection_Side whoami) const
overridevirtual
Returns
serialized binary for the extension

Implements Botan::TLS::Extension.

Definition at line 557 of file tls_extensions.cpp.

557 {
558 std::vector<uint8_t> buf(2);
559
560 for(auto g : m_groups) {
561 const uint16_t id = g.wire_code();
562
563 if(id > 0) {
564 buf.push_back(get_byte<0>(id));
565 buf.push_back(get_byte<1>(id));
566 }
567 }
568
569 buf[0] = get_byte<0>(static_cast<uint16_t>(buf.size() - 2));
570 buf[1] = get_byte<1>(static_cast<uint16_t>(buf.size() - 2));
571
572 return buf;
573}
constexpr uint8_t get_byte(T input)
Definition loadstor.h:79

References Botan::get_byte().

◆ static_type()

Extension_Code Botan::TLS::Supported_Groups::static_type ( )
inlinestatic

Definition at line 233 of file tls_extensions.h.

References Botan::TLS::SupportedGroups.

Referenced by type().

◆ type()

Extension_Code Botan::TLS::Supported_Groups::type ( ) const
inlineoverridevirtual
Returns
code number of the extension

Implements Botan::TLS::Extension.

Definition at line 235 of file tls_extensions.h.

235{ return static_type(); }
static Extension_Code static_type()

References static_type().


The documentation for this class was generated from the following files: