Coverage Report

Created: 2020-06-30 13:58

/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
126
   {
17
126
   const uint8_t maj = major_version();
18
126
   const uint8_t min = minor_version();
19
126
20
126
   if(maj == 3 && min == 0)
21
0
      return "SSL v3";
22
126
23
126
   if(maj == 3 && min >= 1) // TLS v1.x
24
19
      return "TLS v1." + std::to_string(min-1);
25
107
26
107
   if(maj == 254) // DTLS 1.x
27
9
      return "DTLS v1." + std::to_string(255 - min);
28
98
29
98
   // Some very new or very old protocol (or bogus data)
30
98
   return "Unknown " + std::to_string(maj) + "." + std::to_string(min);
31
98
   }
32
33
bool Protocol_Version::is_datagram_protocol() const
34
570k
   {
35
570k
   return major_version() > 250;
36
570k
   }
37
38
bool Protocol_Version::operator>(const Protocol_Version& other) const
39
20.3k
   {
40
20.3k
   if(this->is_datagram_protocol() != other.is_datagram_protocol())
41
11
      throw TLS_Exception(Alert::PROTOCOL_VERSION,
42
11
                          "Version comparing " + to_string() +
43
11
                          " with " + other.to_string());
44
20.3k
45
20.3k
   if(this->is_datagram_protocol())
46
81
      return m_version < other.m_version; // goes backwards
47
20.2k
48
20.2k
   return m_version > other.m_version;
49
20.2k
   }
50
51
bool Protocol_Version::known_version() const
52
56.5k
   {
53
56.5k
   return (m_version == Protocol_Version::TLS_V10 ||
54
56.5k
           m_version == Protocol_Version::TLS_V11 ||
55
56.5k
           m_version == Protocol_Version::TLS_V12 ||
56
56.5k
           m_version == Protocol_Version::DTLS_V10 ||
57
56.5k
           m_version == Protocol_Version::DTLS_V12);
58
56.5k
   }
59
60
bool Protocol_Version::supports_negotiable_signature_algorithms() const
61
6.77k
   {
62
6.77k
   return (m_version != Protocol_Version::TLS_V10 &&
63
6.77k
           m_version != Protocol_Version::TLS_V11 &&
64
6.77k
           m_version != Protocol_Version::DTLS_V10);
65
6.77k
   }
66
67
bool Protocol_Version::supports_explicit_cbc_ivs() const
68
2.06k
   {
69
2.06k
   return (m_version != Protocol_Version::TLS_V10);
70
2.06k
   }
71
72
bool Protocol_Version::supports_ciphersuite_specific_prf() const
73
20.9k
   {
74
20.9k
   return (m_version != Protocol_Version::TLS_V10 &&
75
20.9k
           m_version != Protocol_Version::TLS_V11 &&
76
20.9k
           m_version != Protocol_Version::DTLS_V10);
77
20.9k
   }
78
79
bool Protocol_Version::supports_aead_modes() const
80
5.30M
   {
81
5.30M
   return (m_version != Protocol_Version::TLS_V10 &&
82
5.30M
           m_version != Protocol_Version::TLS_V11 &&
83
5.30M
           m_version != Protocol_Version::DTLS_V10);
84
5.30M
   }
85
86
}
87
88
}