Botan 3.11.0
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 504 of file tls_extensions.cpp.

504: 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 548 of file tls_extensions.cpp.

548 {
549 const uint16_t len = reader.get_uint16_t();
550
551 if(len + 2 != extension_size) {
552 throw Decoding_Error("Inconsistent length field in supported groups list");
553 }
554
555 if(len % 2 == 1) {
556 throw Decoding_Error("Supported groups list of strange size");
557 }
558
559 const size_t elems = len / 2;
560
561 for(size_t i = 0; i != elems; ++i) {
562 const auto group = static_cast<Group_Params>(reader.get_uint16_t());
563 // Note: RFC 8446 does not explicitly enforce that groups must be unique.
564 if(!value_exists(m_groups, group)) {
565 m_groups.push_back(group);
566 }
567 }
568}
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 520 of file tls_extensions.cpp.

520 {
521 std::vector<Group_Params> dh;
522 for(auto g : m_groups) {
523 if(g.is_in_ffdhe_range()) {
524 dh.push_back(g);
525 }
526 }
527 return dh;
528}

◆ ec_groups()

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

Definition at line 510 of file tls_extensions.cpp.

510 {
511 std::vector<Group_Params> ec;
512 for(auto g : m_groups) {
513 if(g.is_pure_ecc_group()) {
514 ec.push_back(g);
515 }
516 }
517 return ec;
518}

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 506 of file tls_extensions.cpp.

506 {
507 return m_groups;
508}

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 530 of file tls_extensions.cpp.

530 {
531 std::vector<uint8_t> buf(2);
532
533 for(auto g : m_groups) {
534 const uint16_t id = g.wire_code();
535
536 if(id > 0) {
537 buf.push_back(get_byte<0>(id));
538 buf.push_back(get_byte<1>(id));
539 }
540 }
541
542 buf[0] = get_byte<0>(static_cast<uint16_t>(buf.size() - 2));
543 buf[1] = get_byte<1>(static_cast<uint16_t>(buf.size() - 2));
544
545 return buf;
546}
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: