File indexing completed on 2025-01-18 10:05:50
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011 #ifndef OPENSSL_SSL3_H
0012 # define OPENSSL_SSL3_H
0013 # pragma once
0014
0015 # include <openssl/macros.h>
0016 # ifndef OPENSSL_NO_DEPRECATED_3_0
0017 # define HEADER_SSL3_H
0018 # endif
0019
0020 # include <openssl/comp.h>
0021 # include <openssl/buffer.h>
0022 # include <openssl/evp.h>
0023 # include <openssl/ssl.h>
0024
0025 #ifdef __cplusplus
0026 extern "C" {
0027 #endif
0028
0029
0030
0031
0032
0033 # define SSL3_CK_SCSV 0x030000FF
0034
0035
0036
0037
0038
0039 # define SSL3_CK_FALLBACK_SCSV 0x03005600
0040
0041 # define SSL3_CK_RSA_NULL_MD5 0x03000001
0042 # define SSL3_CK_RSA_NULL_SHA 0x03000002
0043 # define SSL3_CK_RSA_RC4_40_MD5 0x03000003
0044 # define SSL3_CK_RSA_RC4_128_MD5 0x03000004
0045 # define SSL3_CK_RSA_RC4_128_SHA 0x03000005
0046 # define SSL3_CK_RSA_RC2_40_MD5 0x03000006
0047 # define SSL3_CK_RSA_IDEA_128_SHA 0x03000007
0048 # define SSL3_CK_RSA_DES_40_CBC_SHA 0x03000008
0049 # define SSL3_CK_RSA_DES_64_CBC_SHA 0x03000009
0050 # define SSL3_CK_RSA_DES_192_CBC3_SHA 0x0300000A
0051
0052 # define SSL3_CK_DH_DSS_DES_40_CBC_SHA 0x0300000B
0053 # define SSL3_CK_DH_DSS_DES_64_CBC_SHA 0x0300000C
0054 # define SSL3_CK_DH_DSS_DES_192_CBC3_SHA 0x0300000D
0055 # define SSL3_CK_DH_RSA_DES_40_CBC_SHA 0x0300000E
0056 # define SSL3_CK_DH_RSA_DES_64_CBC_SHA 0x0300000F
0057 # define SSL3_CK_DH_RSA_DES_192_CBC3_SHA 0x03000010
0058
0059 # define SSL3_CK_DHE_DSS_DES_40_CBC_SHA 0x03000011
0060 # define SSL3_CK_EDH_DSS_DES_40_CBC_SHA SSL3_CK_DHE_DSS_DES_40_CBC_SHA
0061 # define SSL3_CK_DHE_DSS_DES_64_CBC_SHA 0x03000012
0062 # define SSL3_CK_EDH_DSS_DES_64_CBC_SHA SSL3_CK_DHE_DSS_DES_64_CBC_SHA
0063 # define SSL3_CK_DHE_DSS_DES_192_CBC3_SHA 0x03000013
0064 # define SSL3_CK_EDH_DSS_DES_192_CBC3_SHA SSL3_CK_DHE_DSS_DES_192_CBC3_SHA
0065 # define SSL3_CK_DHE_RSA_DES_40_CBC_SHA 0x03000014
0066 # define SSL3_CK_EDH_RSA_DES_40_CBC_SHA SSL3_CK_DHE_RSA_DES_40_CBC_SHA
0067 # define SSL3_CK_DHE_RSA_DES_64_CBC_SHA 0x03000015
0068 # define SSL3_CK_EDH_RSA_DES_64_CBC_SHA SSL3_CK_DHE_RSA_DES_64_CBC_SHA
0069 # define SSL3_CK_DHE_RSA_DES_192_CBC3_SHA 0x03000016
0070 # define SSL3_CK_EDH_RSA_DES_192_CBC3_SHA SSL3_CK_DHE_RSA_DES_192_CBC3_SHA
0071
0072 # define SSL3_CK_ADH_RC4_40_MD5 0x03000017
0073 # define SSL3_CK_ADH_RC4_128_MD5 0x03000018
0074 # define SSL3_CK_ADH_DES_40_CBC_SHA 0x03000019
0075 # define SSL3_CK_ADH_DES_64_CBC_SHA 0x0300001A
0076 # define SSL3_CK_ADH_DES_192_CBC_SHA 0x0300001B
0077
0078
0079 # define SSL3_RFC_RSA_NULL_MD5 "TLS_RSA_WITH_NULL_MD5"
0080 # define SSL3_RFC_RSA_NULL_SHA "TLS_RSA_WITH_NULL_SHA"
0081 # define SSL3_RFC_RSA_DES_192_CBC3_SHA "TLS_RSA_WITH_3DES_EDE_CBC_SHA"
0082 # define SSL3_RFC_DHE_DSS_DES_192_CBC3_SHA "TLS_DHE_DSS_WITH_3DES_EDE_CBC_SHA"
0083 # define SSL3_RFC_DHE_RSA_DES_192_CBC3_SHA "TLS_DHE_RSA_WITH_3DES_EDE_CBC_SHA"
0084 # define SSL3_RFC_ADH_DES_192_CBC_SHA "TLS_DH_anon_WITH_3DES_EDE_CBC_SHA"
0085 # define SSL3_RFC_RSA_IDEA_128_SHA "TLS_RSA_WITH_IDEA_CBC_SHA"
0086 # define SSL3_RFC_RSA_RC4_128_MD5 "TLS_RSA_WITH_RC4_128_MD5"
0087 # define SSL3_RFC_RSA_RC4_128_SHA "TLS_RSA_WITH_RC4_128_SHA"
0088 # define SSL3_RFC_ADH_RC4_128_MD5 "TLS_DH_anon_WITH_RC4_128_MD5"
0089
0090 # define SSL3_TXT_RSA_NULL_MD5 "NULL-MD5"
0091 # define SSL3_TXT_RSA_NULL_SHA "NULL-SHA"
0092 # define SSL3_TXT_RSA_RC4_40_MD5 "EXP-RC4-MD5"
0093 # define SSL3_TXT_RSA_RC4_128_MD5 "RC4-MD5"
0094 # define SSL3_TXT_RSA_RC4_128_SHA "RC4-SHA"
0095 # define SSL3_TXT_RSA_RC2_40_MD5 "EXP-RC2-CBC-MD5"
0096 # define SSL3_TXT_RSA_IDEA_128_SHA "IDEA-CBC-SHA"
0097 # define SSL3_TXT_RSA_DES_40_CBC_SHA "EXP-DES-CBC-SHA"
0098 # define SSL3_TXT_RSA_DES_64_CBC_SHA "DES-CBC-SHA"
0099 # define SSL3_TXT_RSA_DES_192_CBC3_SHA "DES-CBC3-SHA"
0100
0101 # define SSL3_TXT_DH_DSS_DES_40_CBC_SHA "EXP-DH-DSS-DES-CBC-SHA"
0102 # define SSL3_TXT_DH_DSS_DES_64_CBC_SHA "DH-DSS-DES-CBC-SHA"
0103 # define SSL3_TXT_DH_DSS_DES_192_CBC3_SHA "DH-DSS-DES-CBC3-SHA"
0104 # define SSL3_TXT_DH_RSA_DES_40_CBC_SHA "EXP-DH-RSA-DES-CBC-SHA"
0105 # define SSL3_TXT_DH_RSA_DES_64_CBC_SHA "DH-RSA-DES-CBC-SHA"
0106 # define SSL3_TXT_DH_RSA_DES_192_CBC3_SHA "DH-RSA-DES-CBC3-SHA"
0107
0108 # define SSL3_TXT_DHE_DSS_DES_40_CBC_SHA "EXP-DHE-DSS-DES-CBC-SHA"
0109 # define SSL3_TXT_DHE_DSS_DES_64_CBC_SHA "DHE-DSS-DES-CBC-SHA"
0110 # define SSL3_TXT_DHE_DSS_DES_192_CBC3_SHA "DHE-DSS-DES-CBC3-SHA"
0111 # define SSL3_TXT_DHE_RSA_DES_40_CBC_SHA "EXP-DHE-RSA-DES-CBC-SHA"
0112 # define SSL3_TXT_DHE_RSA_DES_64_CBC_SHA "DHE-RSA-DES-CBC-SHA"
0113 # define SSL3_TXT_DHE_RSA_DES_192_CBC3_SHA "DHE-RSA-DES-CBC3-SHA"
0114
0115
0116
0117
0118
0119
0120 # define SSL3_TXT_EDH_DSS_DES_40_CBC_SHA "EXP-EDH-DSS-DES-CBC-SHA"
0121 # define SSL3_TXT_EDH_DSS_DES_64_CBC_SHA "EDH-DSS-DES-CBC-SHA"
0122 # define SSL3_TXT_EDH_DSS_DES_192_CBC3_SHA "EDH-DSS-DES-CBC3-SHA"
0123 # define SSL3_TXT_EDH_RSA_DES_40_CBC_SHA "EXP-EDH-RSA-DES-CBC-SHA"
0124 # define SSL3_TXT_EDH_RSA_DES_64_CBC_SHA "EDH-RSA-DES-CBC-SHA"
0125 # define SSL3_TXT_EDH_RSA_DES_192_CBC3_SHA "EDH-RSA-DES-CBC3-SHA"
0126
0127 # define SSL3_TXT_ADH_RC4_40_MD5 "EXP-ADH-RC4-MD5"
0128 # define SSL3_TXT_ADH_RC4_128_MD5 "ADH-RC4-MD5"
0129 # define SSL3_TXT_ADH_DES_40_CBC_SHA "EXP-ADH-DES-CBC-SHA"
0130 # define SSL3_TXT_ADH_DES_64_CBC_SHA "ADH-DES-CBC-SHA"
0131 # define SSL3_TXT_ADH_DES_192_CBC_SHA "ADH-DES-CBC3-SHA"
0132
0133 # define SSL3_SSL_SESSION_ID_LENGTH 32
0134 # define SSL3_MAX_SSL_SESSION_ID_LENGTH 32
0135
0136 # define SSL3_MASTER_SECRET_SIZE 48
0137 # define SSL3_RANDOM_SIZE 32
0138 # define SSL3_SESSION_ID_SIZE 32
0139 # define SSL3_RT_HEADER_LENGTH 5
0140
0141 # define SSL3_HM_HEADER_LENGTH 4
0142
0143 # ifndef SSL3_ALIGN_PAYLOAD
0144
0145
0146
0147
0148
0149
0150
0151
0152 # define SSL3_ALIGN_PAYLOAD 8
0153 # else
0154 # if (SSL3_ALIGN_PAYLOAD&(SSL3_ALIGN_PAYLOAD-1))!=0
0155 # error "insane SSL3_ALIGN_PAYLOAD"
0156 # undef SSL3_ALIGN_PAYLOAD
0157 # endif
0158 # endif
0159
0160
0161
0162
0163
0164
0165
0166 # define SSL3_RT_MAX_MD_SIZE 64
0167
0168
0169
0170
0171
0172 # define SSL_RT_MAX_CIPHER_BLOCK_SIZE 16
0173
0174 # define SSL3_RT_MAX_EXTRA (16384)
0175
0176
0177 # define SSL3_RT_MAX_PLAIN_LENGTH 16384
0178
0179 # define SSL3_RT_MAX_COMPRESSED_OVERHEAD 1024
0180
0181
0182
0183
0184
0185
0186 # define SSL3_RT_MAX_ENCRYPTED_OVERHEAD (256 + SSL3_RT_MAX_MD_SIZE)
0187 # define SSL3_RT_MAX_TLS13_ENCRYPTED_OVERHEAD 256
0188
0189
0190
0191
0192
0193
0194 # define SSL3_RT_SEND_MAX_ENCRYPTED_OVERHEAD \
0195 (SSL_RT_MAX_CIPHER_BLOCK_SIZE + SSL3_RT_MAX_MD_SIZE)
0196
0197
0198
0199 # ifdef OPENSSL_NO_COMP
0200 # define SSL3_RT_MAX_COMPRESSED_LENGTH SSL3_RT_MAX_PLAIN_LENGTH
0201 # else
0202 # define SSL3_RT_MAX_COMPRESSED_LENGTH \
0203 (SSL3_RT_MAX_PLAIN_LENGTH+SSL3_RT_MAX_COMPRESSED_OVERHEAD)
0204 # endif
0205 # define SSL3_RT_MAX_ENCRYPTED_LENGTH \
0206 (SSL3_RT_MAX_ENCRYPTED_OVERHEAD+SSL3_RT_MAX_COMPRESSED_LENGTH)
0207 # define SSL3_RT_MAX_TLS13_ENCRYPTED_LENGTH \
0208 (SSL3_RT_MAX_PLAIN_LENGTH + SSL3_RT_MAX_TLS13_ENCRYPTED_OVERHEAD)
0209 # define SSL3_RT_MAX_PACKET_SIZE \
0210 (SSL3_RT_MAX_ENCRYPTED_LENGTH+SSL3_RT_HEADER_LENGTH)
0211
0212 # define SSL3_MD_CLIENT_FINISHED_CONST "\x43\x4C\x4E\x54"
0213 # define SSL3_MD_SERVER_FINISHED_CONST "\x53\x52\x56\x52"
0214
0215
0216 # define SSL3_VERSION_MAJOR 0x03
0217 # define SSL3_VERSION_MINOR 0x00
0218
0219 # define SSL3_RT_CHANGE_CIPHER_SPEC 20
0220 # define SSL3_RT_ALERT 21
0221 # define SSL3_RT_HANDSHAKE 22
0222 # define SSL3_RT_APPLICATION_DATA 23
0223
0224
0225 # define TLS1_RT_CRYPTO 0x1000
0226 # define TLS1_RT_CRYPTO_PREMASTER (TLS1_RT_CRYPTO | 0x1)
0227 # define TLS1_RT_CRYPTO_CLIENT_RANDOM (TLS1_RT_CRYPTO | 0x2)
0228 # define TLS1_RT_CRYPTO_SERVER_RANDOM (TLS1_RT_CRYPTO | 0x3)
0229 # define TLS1_RT_CRYPTO_MASTER (TLS1_RT_CRYPTO | 0x4)
0230
0231 # define TLS1_RT_CRYPTO_READ 0x0000
0232 # define TLS1_RT_CRYPTO_WRITE 0x0100
0233 # define TLS1_RT_CRYPTO_MAC (TLS1_RT_CRYPTO | 0x5)
0234 # define TLS1_RT_CRYPTO_KEY (TLS1_RT_CRYPTO | 0x6)
0235 # define TLS1_RT_CRYPTO_IV (TLS1_RT_CRYPTO | 0x7)
0236 # define TLS1_RT_CRYPTO_FIXED_IV (TLS1_RT_CRYPTO | 0x8)
0237
0238
0239 # define SSL3_RT_HEADER 0x100
0240 # define SSL3_RT_INNER_CONTENT_TYPE 0x101
0241
0242
0243 # define SSL3_RT_QUIC_DATAGRAM 0x200
0244 # define SSL3_RT_QUIC_PACKET 0x201
0245 # define SSL3_RT_QUIC_FRAME_FULL 0x202
0246 # define SSL3_RT_QUIC_FRAME_HEADER 0x203
0247 # define SSL3_RT_QUIC_FRAME_PADDING 0x204
0248
0249 # define SSL3_AL_WARNING 1
0250 # define SSL3_AL_FATAL 2
0251
0252 # define SSL3_AD_CLOSE_NOTIFY 0
0253 # define SSL3_AD_UNEXPECTED_MESSAGE 10
0254 # define SSL3_AD_BAD_RECORD_MAC 20
0255 # define SSL3_AD_DECOMPRESSION_FAILURE 30
0256 # define SSL3_AD_HANDSHAKE_FAILURE 40
0257 # define SSL3_AD_NO_CERTIFICATE 41
0258 # define SSL3_AD_BAD_CERTIFICATE 42
0259 # define SSL3_AD_UNSUPPORTED_CERTIFICATE 43
0260 # define SSL3_AD_CERTIFICATE_REVOKED 44
0261 # define SSL3_AD_CERTIFICATE_EXPIRED 45
0262 # define SSL3_AD_CERTIFICATE_UNKNOWN 46
0263 # define SSL3_AD_ILLEGAL_PARAMETER 47
0264
0265 # define TLS1_HB_REQUEST 1
0266 # define TLS1_HB_RESPONSE 2
0267
0268
0269 # define SSL3_CT_RSA_SIGN 1
0270 # define SSL3_CT_DSS_SIGN 2
0271 # define SSL3_CT_RSA_FIXED_DH 3
0272 # define SSL3_CT_DSS_FIXED_DH 4
0273 # define SSL3_CT_RSA_EPHEMERAL_DH 5
0274 # define SSL3_CT_DSS_EPHEMERAL_DH 6
0275 # define SSL3_CT_FORTEZZA_DMS 20
0276
0277
0278
0279
0280 # define SSL3_CT_NUMBER 12
0281
0282 # if defined(TLS_CT_NUMBER)
0283 # if TLS_CT_NUMBER != SSL3_CT_NUMBER
0284 # error "SSL/TLS CT_NUMBER values do not match"
0285 # endif
0286 # endif
0287
0288
0289 # define SSL3_FLAGS_NO_RENEGOTIATE_CIPHERS 0x0001
0290
0291
0292 # define TLS1_FLAGS_TLS_PADDING_BUG 0x0
0293
0294 # define TLS1_FLAGS_SKIP_CERT_VERIFY 0x0010
0295
0296
0297 # define TLS1_FLAGS_ENCRYPT_THEN_MAC_READ 0x0100
0298 # define TLS1_FLAGS_ENCRYPT_THEN_MAC TLS1_FLAGS_ENCRYPT_THEN_MAC_READ
0299
0300
0301 # define TLS1_FLAGS_RECEIVED_EXTMS 0x0200
0302
0303 # define TLS1_FLAGS_ENCRYPT_THEN_MAC_WRITE 0x0400
0304
0305 # define TLS1_FLAGS_STATELESS 0x0800
0306
0307
0308 # define TLS1_FLAGS_REQUIRED_EXTMS 0x1000
0309
0310
0311
0312 # define SSL3_MT_HELLO_REQUEST 0
0313 # define SSL3_MT_CLIENT_HELLO 1
0314 # define SSL3_MT_SERVER_HELLO 2
0315 # define SSL3_MT_NEWSESSION_TICKET 4
0316 # define SSL3_MT_END_OF_EARLY_DATA 5
0317 # define SSL3_MT_ENCRYPTED_EXTENSIONS 8
0318 # define SSL3_MT_CERTIFICATE 11
0319 # define SSL3_MT_SERVER_KEY_EXCHANGE 12
0320 # define SSL3_MT_CERTIFICATE_REQUEST 13
0321 # define SSL3_MT_SERVER_DONE 14
0322 # define SSL3_MT_CERTIFICATE_VERIFY 15
0323 # define SSL3_MT_CLIENT_KEY_EXCHANGE 16
0324 # define SSL3_MT_FINISHED 20
0325 # define SSL3_MT_CERTIFICATE_URL 21
0326 # define SSL3_MT_CERTIFICATE_STATUS 22
0327 # define SSL3_MT_SUPPLEMENTAL_DATA 23
0328 # define SSL3_MT_KEY_UPDATE 24
0329 # define SSL3_MT_COMPRESSED_CERTIFICATE 25
0330 # ifndef OPENSSL_NO_NEXTPROTONEG
0331 # define SSL3_MT_NEXT_PROTO 67
0332 # endif
0333 # define SSL3_MT_MESSAGE_HASH 254
0334 # define DTLS1_MT_HELLO_VERIFY_REQUEST 3
0335
0336
0337 # define SSL3_MT_CHANGE_CIPHER_SPEC 0x0101
0338
0339 # define SSL3_MT_CCS 1
0340
0341
0342 # define SSL3_CC_READ 0x001
0343 # define SSL3_CC_WRITE 0x002
0344 # define SSL3_CC_CLIENT 0x010
0345 # define SSL3_CC_SERVER 0x020
0346 # define SSL3_CC_EARLY 0x040
0347 # define SSL3_CC_HANDSHAKE 0x080
0348 # define SSL3_CC_APPLICATION 0x100
0349 # define SSL3_CHANGE_CIPHER_CLIENT_WRITE (SSL3_CC_CLIENT|SSL3_CC_WRITE)
0350 # define SSL3_CHANGE_CIPHER_SERVER_READ (SSL3_CC_SERVER|SSL3_CC_READ)
0351 # define SSL3_CHANGE_CIPHER_CLIENT_READ (SSL3_CC_CLIENT|SSL3_CC_READ)
0352 # define SSL3_CHANGE_CIPHER_SERVER_WRITE (SSL3_CC_SERVER|SSL3_CC_WRITE)
0353
0354 #ifdef __cplusplus
0355 }
0356 #endif
0357 #endif