Botan 3.9.0
Crypto and TLS for C&
tls_null.h
Go to the documentation of this file.
1/*
2* TLS Null Cipher Handling
3* (C) 2024 Sebastian Ahrens, Dirk Dobkowitz, André Schomburg (Volkswagen AG)
4* (C) 2024 Lars Dürkop (CARIAD SE)
5*
6* Botan is released under the Simplified BSD License (see license.txt)
7*/
8
9#ifndef BOTAN_TLS_NULL_HMAC_AEAD_H_
10#define BOTAN_TLS_NULL_HMAC_AEAD_H_
11
12#include <botan/aead.h>
13#include <botan/mac.h>
14#include <botan/tls_version.h>
15
16namespace Botan::TLS {
17
18/**
19* TLS NULL+HMAC AEAD base class (GenericStreamCipher in TLS spec)
20*/
22 public:
23 std::string name() const final;
24
25 void set_associated_data_n(size_t idx, std::span<const uint8_t> ad) override;
26
27 size_t update_granularity() const final;
28
29 size_t ideal_granularity() const final;
30
32
33 bool valid_nonce_length(size_t nl) const final;
34
35 size_t tag_size() const final { return m_tag_size; }
36
37 void clear() final;
38
39 void reset() final;
40
41 bool has_keying_material() const final;
42
43 protected:
44 TLS_NULL_HMAC_AEAD_Mode(std::unique_ptr<MessageAuthenticationCode> mac, size_t mac_keylen);
45
46 size_t mac_keylen() const;
47
48 MessageAuthenticationCode& mac() const;
49
50 private:
51 void start_msg(const uint8_t nonce[], size_t nonce_len) final;
52 size_t process_msg(uint8_t buf[], size_t sz) final;
53
54 void key_schedule(std::span<const uint8_t> key) final;
55
56 const std::string m_mac_name;
57 size_t m_mac_keylen;
58 size_t m_tag_size;
59
60 secure_vector<uint8_t> m_key;
61 std::unique_ptr<MessageAuthenticationCode> m_mac;
62};
63
64/**
65* TLS_NULL_HMAC_AEAD Encryption
66*/
68 public:
69 TLS_NULL_HMAC_AEAD_Encryption(std::unique_ptr<MessageAuthenticationCode> mac, const size_t mac_keylen) :
71
72 void set_associated_data_n(size_t idx, std::span<const uint8_t> ad) override;
73
74 size_t output_length(size_t input_length) const override;
75
76 size_t minimum_final_size() const override { return 0; }
77
78 private:
79 void finish_msg(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
80};
81
82/**
83* TLS_NULL_HMAC_AEAD Decryption
84*/
86 public:
87 TLS_NULL_HMAC_AEAD_Decryption(std::unique_ptr<MessageAuthenticationCode> mac, const size_t mac_keylen) :
89
90 size_t output_length(size_t input_length) const override;
91
92 size_t minimum_final_size() const override { return tag_size(); }
93
94 void finish_msg(secure_vector<uint8_t>& final_block, size_t offset = 0) override;
95};
96
97} // namespace Botan::TLS
98
99#endif
#define BOTAN_TEST_API
Definition api.h:41
TLS_NULL_HMAC_AEAD_Decryption(std::unique_ptr< MessageAuthenticationCode > mac, const size_t mac_keylen)
Definition tls_null.h:87
size_t minimum_final_size() const override
Definition tls_null.h:92
size_t minimum_final_size() const override
Definition tls_null.h:76
TLS_NULL_HMAC_AEAD_Encryption(std::unique_ptr< MessageAuthenticationCode > mac, const size_t mac_keylen)
Definition tls_null.h:69
size_t update_granularity() const final
Definition tls_null.cpp:39
size_t ideal_granularity() const final
Definition tls_null.cpp:43
void set_associated_data_n(size_t idx, std::span< const uint8_t > ad) override
Definition tls_null.cpp:89
MessageAuthenticationCode & mac() const
Definition tls_null.cpp:63
Key_Length_Specification key_spec() const final
Definition tls_null.cpp:51
std::string name() const final
Definition tls_null.cpp:35
bool valid_nonce_length(size_t nl) const final
Definition tls_null.cpp:47
TLS_NULL_HMAC_AEAD_Mode(std::unique_ptr< MessageAuthenticationCode > mac, size_t mac_keylen)
Definition tls_null.cpp:22
size_t tag_size() const final
Definition tls_null.h:35
std::vector< T, secure_allocator< T > > secure_vector
Definition secmem.h:69