Botan 3.11.0
Crypto and TLS for C&
msg_cert_status.cpp
Go to the documentation of this file.
1/*
2* Certificate Status
3* (C) 2016 Jack Lloyd
4*
5* Botan is released under the Simplified BSD License (see license.txt)
6*/
7
8#include <botan/tls_messages.h>
9
10#include <botan/internal/loadstor.h>
11
12namespace Botan::TLS {
13
14Certificate_Status::Certificate_Status(const std::vector<uint8_t>& buf, const Connection_Side /*side*/) {
15 if(buf.size() < 5) {
16 throw Decoding_Error("Invalid Certificate_Status message: too small");
17 }
18
19 if(buf[0] != 1) { // not OCSP
20 throw Decoding_Error("Unexpected Certificate_Status message: unexpected response type");
21 }
22
23 const size_t len = make_uint32(0, buf[1], buf[2], buf[3]);
24
25 // Verify the redundant length field...
26 if(buf.size() != len + 4) {
27 throw Decoding_Error("Invalid Certificate_Status: invalid length field");
28 }
29
30 m_response.assign(buf.begin() + 4, buf.end());
31}
32
33Certificate_Status::Certificate_Status(std::vector<uint8_t> raw_response_bytes) :
34 m_response(std::move(raw_response_bytes)) {}
35
36std::vector<uint8_t> Certificate_Status::serialize() const {
37 if(m_response.size() > 0xFFFFFF) { // unlikely
38 throw Encoding_Error("OCSP response too long to encode in TLS");
39 }
40
41 const uint32_t response_len = static_cast<uint32_t>(m_response.size());
42
43 std::vector<uint8_t> buf;
44 buf.reserve(1 + 3 + m_response.size());
45 buf.push_back(1); // type OCSP
46 for(size_t i = 1; i < 4; ++i) {
47 buf.push_back(get_byte_var(i, response_len));
48 }
49
50 buf.insert(buf.end(), m_response.begin(), m_response.end());
51 return buf;
52}
53
54} // namespace Botan::TLS
std::vector< uint8_t > serialize() const final
Certificate_Status(const std::vector< uint8_t > &buf, Connection_Side from)
constexpr uint32_t make_uint32(uint8_t i0, uint8_t i1, uint8_t i2, uint8_t i3)
Definition loadstor.h:104
constexpr uint8_t get_byte_var(size_t byte_num, T input)
Definition loadstor.h:69