Extensions.h 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. /*
  2. * Copyright (c) 2020, Ali Mohammad Pur <mpfard@serenityos.org>
  3. * Copyright (c) 2023, stelar7 <dudedbz@gmail.com>
  4. *
  5. * SPDX-License-Identifier: BSD-2-Clause
  6. */
  7. #pragma once
  8. #include <AK/Types.h>
  9. namespace TLS {
  10. #define _ENUM_KEY(name) name,
  11. #define _ENUM_KEY_VALUE(name, value) name = value,
  12. // https://www.iana.org/assignments/tls-parameters/tls-parameters.xhtml#tls-parameters-5
  13. #define __ENUM_CONTENT_TYPES \
  14. _ENUM_KEY_VALUE(CHANGE_CIPHER_SPEC, 20) \
  15. _ENUM_KEY_VALUE(ALERT, 21) \
  16. _ENUM_KEY_VALUE(HANDSHAKE, 22) \
  17. _ENUM_KEY_VALUE(APPLICATION_DATA, 23) \
  18. _ENUM_KEY_VALUE(HEARTBEAT, 24) \
  19. _ENUM_KEY_VALUE(TLS12_CID, 25) \
  20. _ENUM_KEY_VALUE(ACK, 26)
  21. enum class ContentType : u8 {
  22. __ENUM_CONTENT_TYPES
  23. };
  24. #define __ENUM_PROTOCOL_VERSIONS \
  25. _ENUM_KEY_VALUE(VERSION_1_3, 0x0304) \
  26. _ENUM_KEY_VALUE(VERSION_1_2, 0x0303) \
  27. _ENUM_KEY_VALUE(VERSION_1_1, 0x0302) \
  28. _ENUM_KEY_VALUE(VERSION_1_0, 0x0301) \
  29. _ENUM_KEY_VALUE(GREASE_0, 0x0A0A) \
  30. _ENUM_KEY_VALUE(GREASE_1, 0x1A1A) \
  31. _ENUM_KEY_VALUE(GREASE_2, 0x2A2A) \
  32. _ENUM_KEY_VALUE(GREASE_3, 0x3A3A) \
  33. _ENUM_KEY_VALUE(GREASE_4, 0x4A4A) \
  34. _ENUM_KEY_VALUE(GREASE_5, 0x5A5A) \
  35. _ENUM_KEY_VALUE(GREASE_6, 0x6A6A) \
  36. _ENUM_KEY_VALUE(GREASE_7, 0x7A7A) \
  37. _ENUM_KEY_VALUE(GREASE_8, 0x8A8A) \
  38. _ENUM_KEY_VALUE(GREASE_9, 0x9A9A) \
  39. _ENUM_KEY_VALUE(GREASE_A, 0xAAAA) \
  40. _ENUM_KEY_VALUE(GREASE_B, 0xBABA) \
  41. _ENUM_KEY_VALUE(GREASE_C, 0xCACA) \
  42. _ENUM_KEY_VALUE(GREASE_D, 0xDADA) \
  43. _ENUM_KEY_VALUE(GREASE_E, 0xEAEA) \
  44. _ENUM_KEY_VALUE(GREASE_F, 0xFAFA)
  45. enum class ProtocolVersion : u16 {
  46. __ENUM_PROTOCOL_VERSIONS
  47. };
  48. #define __ENUM_ALERT_LEVELS \
  49. _ENUM_KEY_VALUE(WARNING, 1) \
  50. _ENUM_KEY_VALUE(FATAL, 2)
  51. enum class AlertLevel : u8 {
  52. __ENUM_ALERT_LEVELS
  53. };
  54. // https://www.iana.org/assignments/tls-parameters/tls-parameters.xhtml#tls-parameters-7
  55. #define __ENUM_HANDSHAKE_TYPES \
  56. _ENUM_KEY_VALUE(HELLO_REQUEST_RESERVED, 0) \
  57. _ENUM_KEY_VALUE(CLIENT_HELLO, 1) \
  58. _ENUM_KEY_VALUE(SERVER_HELLO, 2) \
  59. _ENUM_KEY_VALUE(HELLO_VERIFY_REQUEST_RESERVED, 3) \
  60. _ENUM_KEY_VALUE(NEW_SESSION_TICKET, 4) \
  61. _ENUM_KEY_VALUE(END_OF_EARLY_DATA, 5) \
  62. _ENUM_KEY_VALUE(HELLO_RETRY_REQUEST_RESERVED, 6) \
  63. _ENUM_KEY_VALUE(ENCRYPTED_EXTENSIONS, 8) \
  64. _ENUM_KEY_VALUE(REQUEST_CONNECTION_ID, 9) \
  65. _ENUM_KEY_VALUE(NEW_CONNECTION_ID, 10) \
  66. _ENUM_KEY_VALUE(CERTIFICATE, 11) \
  67. _ENUM_KEY_VALUE(SERVER_KEY_EXCHANGE_RESERVED, 12) \
  68. _ENUM_KEY_VALUE(CERTIFICATE_REQUEST, 13) \
  69. _ENUM_KEY_VALUE(SERVER_HELLO_DONE_RESERVED, 14) \
  70. _ENUM_KEY_VALUE(CERTIFICATE_VERIFY, 15) \
  71. _ENUM_KEY_VALUE(CLIENT_KEY_EXCHANGE_RESERVED, 16) \
  72. _ENUM_KEY_VALUE(FINISHED, 20) \
  73. _ENUM_KEY_VALUE(CERTIFICATE_URL_RESERVED, 21) \
  74. _ENUM_KEY_VALUE(CERTIFICATE_STATUS_RESERVED, 22) \
  75. _ENUM_KEY_VALUE(SUPPLEMENTAL_DATA_RESERVED, 23) \
  76. _ENUM_KEY_VALUE(KEY_UPDATE, 24) \
  77. _ENUM_KEY_VALUE(COMPRESSED_CERTIFICATE, 25) \
  78. _ENUM_KEY_VALUE(EKT_KEY, 26) \
  79. _ENUM_KEY_VALUE(MESSAGE_HASH, 254)
  80. enum class HandshakeType : u8 {
  81. __ENUM_HANDSHAKE_TYPES
  82. };
  83. // https://www.iana.org/assignments/tls-extensiontype-values/tls-extensiontype-values.xhtml#tls-extensiontype-values-1
  84. #define __ENUM_EXTENSION_TYPES \
  85. _ENUM_KEY_VALUE(SERVER_NAME, 0) \
  86. _ENUM_KEY_VALUE(MAX_FRAGMENT_LENGTH, 1) \
  87. _ENUM_KEY_VALUE(CLIENT_CERTIFICATE_URL, 2) \
  88. _ENUM_KEY_VALUE(TRUSTED_CA_KEYS, 3) \
  89. _ENUM_KEY_VALUE(TRUNCATED_HMAC, 4) \
  90. _ENUM_KEY_VALUE(STATUS_REQUEST, 5) \
  91. _ENUM_KEY_VALUE(USER_MAPPING, 6) \
  92. _ENUM_KEY_VALUE(CLIENT_AUTHZ, 7) \
  93. _ENUM_KEY_VALUE(SERVER_AUTHZ, 8) \
  94. _ENUM_KEY_VALUE(CERT_TYPE, 9) \
  95. _ENUM_KEY_VALUE(SUPPORTED_GROUPS, 10) \
  96. _ENUM_KEY_VALUE(EC_POINT_FORMATS, 11) \
  97. _ENUM_KEY_VALUE(SRP, 12) \
  98. _ENUM_KEY_VALUE(SIGNATURE_ALGORITHMS, 13) \
  99. _ENUM_KEY_VALUE(USE_SRTP, 14) \
  100. _ENUM_KEY_VALUE(HEARTBEAT, 15) \
  101. _ENUM_KEY_VALUE(APPLICATION_LAYER_PROTOCOL_NEGOTIATION, 16) \
  102. _ENUM_KEY_VALUE(STATUS_REQUEST_V2, 17) \
  103. _ENUM_KEY_VALUE(SIGNED_CERTIFICATE_TIMESTAMP, 18) \
  104. _ENUM_KEY_VALUE(CLIENT_CERTIFICATE_TYPE, 19) \
  105. _ENUM_KEY_VALUE(SERVER_CERTIFICATE_TYPE, 20) \
  106. _ENUM_KEY_VALUE(PADDING, 21) \
  107. _ENUM_KEY_VALUE(ENCRYPT_THEN_MAC, 22) \
  108. _ENUM_KEY_VALUE(EXTENDED_MASTER_SECRET, 23) \
  109. _ENUM_KEY_VALUE(TOKEN_BINDING, 24) \
  110. _ENUM_KEY_VALUE(CACHED_INFO, 25) \
  111. _ENUM_KEY_VALUE(TLS_LTS, 26) \
  112. _ENUM_KEY_VALUE(COMPRESS_CERTIFICATE, 27) \
  113. _ENUM_KEY_VALUE(RECORD_SIZE_LIMIT, 28) \
  114. _ENUM_KEY_VALUE(PWD_PROTECT, 29) \
  115. _ENUM_KEY_VALUE(PWD_CLEAR, 30) \
  116. _ENUM_KEY_VALUE(PASSWORD_SALT, 31) \
  117. _ENUM_KEY_VALUE(TICKET_PINNING, 32) \
  118. _ENUM_KEY_VALUE(TLS_CERT_WITH_EXTERN_PSK, 33) \
  119. _ENUM_KEY_VALUE(DELEGATED_CREDENTIALS, 34) \
  120. _ENUM_KEY_VALUE(SESSION_TICKET, 35) \
  121. _ENUM_KEY_VALUE(TLMSP, 36) \
  122. _ENUM_KEY_VALUE(TLMSP_PROXYING, 37) \
  123. _ENUM_KEY_VALUE(TLMSP_DELEGATE, 38) \
  124. _ENUM_KEY_VALUE(SUPPORTED_EKT_CIPHERS, 39) \
  125. _ENUM_KEY_VALUE(PRE_SHARED_KEY, 41) \
  126. _ENUM_KEY_VALUE(EARLY_DATA, 42) \
  127. _ENUM_KEY_VALUE(SUPPORTED_VERSIONS, 43) \
  128. _ENUM_KEY_VALUE(COOKIE, 44) \
  129. _ENUM_KEY_VALUE(PSK_KEY_EXCHANGE_MODES, 45) \
  130. _ENUM_KEY_VALUE(CERTIFICATE_AUTHORITIES, 47) \
  131. _ENUM_KEY_VALUE(OID_FILTERS, 48) \
  132. _ENUM_KEY_VALUE(POST_HANDSHAKE_AUTH, 49) \
  133. _ENUM_KEY_VALUE(SIGNATURE_ALGORITHMS_CERT, 50) \
  134. _ENUM_KEY_VALUE(KEY_SHARE, 51) \
  135. _ENUM_KEY_VALUE(TRANSPARENCY_INFO, 52) \
  136. _ENUM_KEY_VALUE(CONNECTION_ID_DEPRECATED, 53) \
  137. _ENUM_KEY_VALUE(CONNECTION_ID, 54) \
  138. _ENUM_KEY_VALUE(EXTERNAL_ID_HASH, 55) \
  139. _ENUM_KEY_VALUE(EXTERNAL_SESSION_ID, 56) \
  140. _ENUM_KEY_VALUE(QUIC_TRANSPORT_PARAMETERS, 57) \
  141. _ENUM_KEY_VALUE(TICKET_REQUEST, 58) \
  142. _ENUM_KEY_VALUE(DNSSEC_CHAIN, 59) \
  143. _ENUM_KEY_VALUE(RENEGOTIATION_INFO, 65281)
  144. enum class ExtensionType : u16 {
  145. __ENUM_EXTENSION_TYPES
  146. };
  147. #undef _ENUM_KEY
  148. #undef _ENUM_KEY_VALUE
  149. }