Coverage Report

Created: 2020-11-21 08:34

/src/botan/src/lib/tls/tls_version.cpp
Line
Count
Source (jump to first uncovered line)
1
/*
2
* TLS Protocol Version Management
3
* (C) 2012 Jack Lloyd
4
*
5
* Botan is released under the Simplified BSD License (see license.txt)
6
*/
7
8
#include <botan/tls_version.h>
9
#include <botan/tls_exceptn.h>
10
11
namespace Botan {
12
13
namespace TLS {
14
15
std::string Protocol_Version::to_string() const
16
132
   {
17
132
   const uint8_t maj = major_version();
18
132
   const uint8_t min = minor_version();
19
20
132
   if(maj == 3 && min == 0)
21
0
      return "SSL v3";
22
23
132
   if(maj == 3 && min >= 1) // TLS v1.x
24
20
      return "TLS v1." + std::to_string(min-1);
25
26
112
   if(maj == 254) // DTLS 1.x
27
9
      return "DTLS v1." + std::to_string(255 - min);
28
29
   // Some very new or very old protocol (or bogus data)
30
103
   return "Unknown " + std::to_string(maj) + "." + std::to_string(min);
31
103
   }
32
33
bool Protocol_Version::is_datagram_protocol() const
34
578k
   {
35
578k
   return major_version() > 250;
36
578k
   }
37
38
bool Protocol_Version::operator>(const Protocol_Version& other) const
39
21.4k
   {
40
21.4k
   if(this->is_datagram_protocol() != other.is_datagram_protocol())
41
13
      throw TLS_Exception(Alert::PROTOCOL_VERSION,
42
13
                          "Version comparing " + to_string() +
43
13
                          " with " + other.to_string());
44
45
21.4k
   if(this->is_datagram_protocol())
46
141
      return m_version < other.m_version; // goes backwards
47
48
21.3k
   return m_version > other.m_version;
49
21.3k
   }
50
51
bool Protocol_Version::known_version() const
52
58.9k
   {
53
58.9k
   return (m_version == Protocol_Version::TLS_V10 ||
54
58.9k
           m_version == Protocol_Version::TLS_V11 ||
55
58.9k
           m_version == Protocol_Version::TLS_V12 ||
56
58.8k
           m_version == Protocol_Version::DTLS_V10 ||
57
58.8k
           m_version == Protocol_Version::DTLS_V12);
58
58.9k
   }
59
60
bool Protocol_Version::supports_negotiable_signature_algorithms() const
61
6.82k
   {
62
6.82k
   return (m_version != Protocol_Version::TLS_V10 &&
63
6.82k
           m_version != Protocol_Version::TLS_V11 &&
64
6.82k
           m_version != Protocol_Version::DTLS_V10);
65
6.82k
   }
66
67
bool Protocol_Version::supports_explicit_cbc_ivs() const
68
2.80k
   {
69
2.80k
   return (m_version != Protocol_Version::TLS_V10);
70
2.80k
   }
71
72
bool Protocol_Version::supports_ciphersuite_specific_prf() const
73
24.2k
   {
74
24.2k
   return (m_version != Protocol_Version::TLS_V10 &&
75
24.2k
           m_version != Protocol_Version::TLS_V11 &&
76
24.2k
           m_version != Protocol_Version::DTLS_V10);
77
24.2k
   }
78
79
bool Protocol_Version::supports_aead_modes() const
80
5.56M
   {
81
5.56M
   return (m_version != Protocol_Version::TLS_V10 &&
82
5.56M
           m_version != Protocol_Version::TLS_V11 &&
83
5.56M
           m_version != Protocol_Version::DTLS_V10);
84
5.56M
   }
85
86
}
87
88
}