Coverage Report

Created: 2026-05-24 07:14

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/openssl34/ssl/statem/extensions_srvr.c
Line
Count
Source
1
/*
2
 * Copyright 2016-2025 The OpenSSL Project Authors. All Rights Reserved.
3
 *
4
 * Licensed under the Apache License 2.0 (the "License").  You may not use
5
 * this file except in compliance with the License.  You can obtain a copy
6
 * in the file LICENSE in the source distribution or at
7
 * https://www.openssl.org/source/license.html
8
 */
9
10
#include <openssl/ocsp.h>
11
#include "../ssl_local.h"
12
#include "statem_local.h"
13
#include "internal/cryptlib.h"
14
15
0
#define COOKIE_STATE_FORMAT_VERSION 1
16
17
/*
18
 * 2 bytes for packet length, 2 bytes for format version, 2 bytes for
19
 * protocol version, 2 bytes for group id, 2 bytes for cipher id, 1 byte for
20
 * key_share present flag, 8 bytes for timestamp, 2 bytes for the hashlen,
21
 * EVP_MAX_MD_SIZE for transcript hash, 1 byte for app cookie length, app cookie
22
 * length bytes, SHA256_DIGEST_LENGTH bytes for the HMAC of the whole thing.
23
 */
24
0
#define MAX_COOKIE_SIZE (2 + 2 + 2 + 2 + 2 + 1 + 8 + 2 + EVP_MAX_MD_SIZE + 1 \
25
0
    + SSL_COOKIE_LENGTH + SHA256_DIGEST_LENGTH)
26
27
/*
28
 * Message header + 2 bytes for protocol version + number of random bytes +
29
 * + 1 byte for legacy session id length + number of bytes in legacy session id
30
 * + 2 bytes for ciphersuite + 1 byte for legacy compression
31
 * + 2 bytes for extension block length + 6 bytes for key_share extension
32
 * + 4 bytes for cookie extension header + the number of bytes in the cookie
33
 */
34
#define MAX_HRR_SIZE (SSL3_HM_HEADER_LENGTH + 2 + SSL3_RANDOM_SIZE + 1 \
35
    + SSL_MAX_SSL_SESSION_ID_LENGTH + 2 + 1 + 2 + 6 + 4                \
36
    + MAX_COOKIE_SIZE)
37
38
/*
39
 * Parse the client's renegotiation binding and abort if it's not right
40
 */
41
int tls_parse_ctos_renegotiate(SSL_CONNECTION *s, PACKET *pkt,
42
    unsigned int context,
43
    X509 *x, size_t chainidx)
44
5.50k
{
45
5.50k
    unsigned int ilen;
46
5.50k
    const unsigned char *data;
47
5.50k
    int ok;
48
49
    /* Parse the length byte */
50
5.50k
    if (!PACKET_get_1(pkt, &ilen)
51
5.48k
        || !PACKET_get_bytes(pkt, &data, ilen)) {
52
45
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_RENEGOTIATION_ENCODING_ERR);
53
45
        return 0;
54
45
    }
55
56
    /* Check that the extension matches */
57
5.45k
    if (ilen != s->s3.previous_client_finished_len) {
58
19
        SSLfatal(s, SSL_AD_HANDSHAKE_FAILURE, SSL_R_RENEGOTIATION_MISMATCH);
59
19
        return 0;
60
19
    }
61
62
5.43k
    ok = memcmp(data, s->s3.previous_client_finished,
63
5.43k
        s->s3.previous_client_finished_len);
64
5.43k
#ifdef FUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION
65
5.43k
    if (ok) {
66
0
        if ((data[0] ^ s->s3.previous_client_finished[0]) != 0xFF) {
67
0
            ok = 0;
68
0
        }
69
0
    }
70
5.43k
#endif
71
5.43k
    if (ok) {
72
0
        SSLfatal(s, SSL_AD_HANDSHAKE_FAILURE, SSL_R_RENEGOTIATION_MISMATCH);
73
0
        return 0;
74
0
    }
75
76
5.43k
    s->s3.send_connection_binding = 1;
77
78
5.43k
    return 1;
79
5.43k
}
80
81
/*-
82
 * The servername extension is treated as follows:
83
 *
84
 * - Only the hostname type is supported with a maximum length of 255.
85
 * - The servername is rejected if too long or if it contains zeros,
86
 *   in which case an fatal alert is generated.
87
 * - The servername field is maintained together with the session cache.
88
 * - When a session is resumed, the servername call back invoked in order
89
 *   to allow the application to position itself to the right context.
90
 * - The servername is acknowledged if it is new for a session or when
91
 *   it is identical to a previously used for the same session.
92
 *   Applications can control the behaviour.  They can at any time
93
 *   set a 'desirable' servername for a new SSL object. This can be the
94
 *   case for example with HTTPS when a Host: header field is received and
95
 *   a renegotiation is requested. In this case, a possible servername
96
 *   presented in the new client hello is only acknowledged if it matches
97
 *   the value of the Host: field.
98
 * - Applications must  use SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION
99
 *   if they provide for changing an explicit servername context for the
100
 *   session, i.e. when the session has been established with a servername
101
 *   extension.
102
 * - On session reconnect, the servername extension may be absent.
103
 */
104
int tls_parse_ctos_server_name(SSL_CONNECTION *s, PACKET *pkt,
105
    unsigned int context, X509 *x, size_t chainidx)
106
9.09k
{
107
9.09k
    unsigned int servname_type;
108
9.09k
    PACKET sni, hostname;
109
110
9.09k
    if (!PACKET_as_length_prefixed_2(pkt, &sni)
111
        /* ServerNameList must be at least 1 byte long. */
112
8.86k
        || PACKET_remaining(&sni) == 0) {
113
252
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
114
252
        return 0;
115
252
    }
116
117
    /*
118
     * Although the intent was for server_name to be extensible, RFC 4366
119
     * was not clear about it; and so OpenSSL among other implementations,
120
     * always and only allows a 'host_name' name types.
121
     * RFC 6066 corrected the mistake but adding new name types
122
     * is nevertheless no longer feasible, so act as if no other
123
     * SNI types can exist, to simplify parsing.
124
     *
125
     * Also note that the RFC permits only one SNI value per type,
126
     * i.e., we can only have a single hostname.
127
     */
128
8.84k
    if (!PACKET_get_1(&sni, &servname_type)
129
8.84k
        || servname_type != TLSEXT_NAMETYPE_host_name
130
8.80k
        || !PACKET_as_length_prefixed_2(&sni, &hostname)) {
131
177
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
132
177
        return 0;
133
177
    }
134
135
    /*
136
     * In TLSv1.2 and below the SNI is associated with the session. In TLSv1.3
137
     * we always use the SNI value from the handshake.
138
     */
139
8.66k
    if (!s->hit || SSL_CONNECTION_IS_TLS13(s)) {
140
8.65k
        if (PACKET_remaining(&hostname) > TLSEXT_MAXLEN_host_name) {
141
6
            SSLfatal(s, SSL_AD_UNRECOGNIZED_NAME, SSL_R_BAD_EXTENSION);
142
6
            return 0;
143
6
        }
144
145
8.64k
        if (PACKET_contains_zero_byte(&hostname)) {
146
18
            SSLfatal(s, SSL_AD_UNRECOGNIZED_NAME, SSL_R_BAD_EXTENSION);
147
18
            return 0;
148
18
        }
149
150
        /*
151
         * Store the requested SNI in the SSL as temporary storage.
152
         * If we accept it, it will get stored in the SSL_SESSION as well.
153
         */
154
8.62k
        OPENSSL_free(s->ext.hostname);
155
8.62k
        s->ext.hostname = NULL;
156
8.62k
        if (!PACKET_strndup(&hostname, &s->ext.hostname)) {
157
0
            SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
158
0
            return 0;
159
0
        }
160
161
8.62k
        s->servername_done = 1;
162
8.62k
    } else {
163
        /*
164
         * In TLSv1.2 and below we should check if the SNI is consistent between
165
         * the initial handshake and the resumption. In TLSv1.3 SNI is not
166
         * associated with the session.
167
         */
168
13
        s->servername_done = (s->session->ext.hostname != NULL)
169
6
            && PACKET_equal(&hostname, s->session->ext.hostname,
170
6
                strlen(s->session->ext.hostname));
171
13
    }
172
173
8.64k
    return 1;
174
8.66k
}
175
176
int tls_parse_ctos_maxfragmentlen(SSL_CONNECTION *s, PACKET *pkt,
177
    unsigned int context,
178
    X509 *x, size_t chainidx)
179
1.57k
{
180
1.57k
    unsigned int value;
181
182
1.57k
    if (PACKET_remaining(pkt) != 1 || !PACKET_get_1(pkt, &value)) {
183
141
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
184
141
        return 0;
185
141
    }
186
187
    /* Received |value| should be a valid max-fragment-length code. */
188
1.43k
    if (!IS_MAX_FRAGMENT_LENGTH_EXT_VALID(value)) {
189
60
        SSLfatal(s, SSL_AD_ILLEGAL_PARAMETER,
190
60
            SSL_R_SSL3_EXT_INVALID_MAX_FRAGMENT_LENGTH);
191
60
        return 0;
192
60
    }
193
194
    /*
195
     * When doing a full handshake or a renegotiation max_fragment_len_mode will
196
     * be TLSEXT_max_fragment_length_UNSPECIFIED
197
     *
198
     * In case of a resumption max_fragment_len_mode will be one of
199
     *      TLSEXT_max_fragment_length_DISABLED, TLSEXT_max_fragment_length_512,
200
     *      TLSEXT_max_fragment_length_1024, TLSEXT_max_fragment_length_2048.
201
     *      TLSEXT_max_fragment_length_4096
202
     *
203
     * RFC 6066: The negotiated length applies for the duration of the session
204
     * including session resumptions.
205
     *
206
     * So we only set the value in case it is unspecified.
207
     */
208
1.37k
    if (s->session->ext.max_fragment_len_mode == TLSEXT_max_fragment_length_UNSPECIFIED)
209
        /*
210
         * Store it in session, so it'll become binding for us
211
         * and we'll include it in a next Server Hello.
212
         */
213
1.36k
        s->session->ext.max_fragment_len_mode = value;
214
215
1.37k
    return 1;
216
1.43k
}
217
218
#ifndef OPENSSL_NO_SRP
219
int tls_parse_ctos_srp(SSL_CONNECTION *s, PACKET *pkt, unsigned int context,
220
    X509 *x, size_t chainidx)
221
149
{
222
149
    PACKET srp_I;
223
224
149
    if (!PACKET_as_length_prefixed_1(pkt, &srp_I)
225
88
        || PACKET_contains_zero_byte(&srp_I)) {
226
88
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
227
88
        return 0;
228
88
    }
229
230
61
    if (!PACKET_strndup(&srp_I, &s->srp_ctx.login)) {
231
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
232
0
        return 0;
233
0
    }
234
235
61
    return 1;
236
61
}
237
#endif
238
239
int tls_parse_ctos_ec_pt_formats(SSL_CONNECTION *s, PACKET *pkt,
240
    unsigned int context,
241
    X509 *x, size_t chainidx)
242
6.05k
{
243
6.05k
    PACKET ec_point_format_list;
244
245
6.05k
    if (!PACKET_as_length_prefixed_1(pkt, &ec_point_format_list)
246
5.92k
        || PACKET_remaining(&ec_point_format_list) == 0) {
247
147
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
248
147
        return 0;
249
147
    }
250
251
5.90k
    if (!s->hit) {
252
5.75k
        if (!PACKET_memdup(&ec_point_format_list,
253
5.75k
                &s->ext.peer_ecpointformats,
254
5.75k
                &s->ext.peer_ecpointformats_len)) {
255
0
            SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
256
0
            return 0;
257
0
        }
258
5.75k
    }
259
260
5.90k
    return 1;
261
5.90k
}
262
263
int tls_parse_ctos_session_ticket(SSL_CONNECTION *s, PACKET *pkt,
264
    unsigned int context,
265
    X509 *x, size_t chainidx)
266
5.73k
{
267
5.73k
    if (s->ext.session_ticket_cb && !s->ext.session_ticket_cb(SSL_CONNECTION_GET_USER_SSL(s), PACKET_data(pkt), PACKET_remaining(pkt), s->ext.session_ticket_cb_arg)) {
268
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
269
0
        return 0;
270
0
    }
271
272
5.73k
    return 1;
273
5.73k
}
274
275
int tls_parse_ctos_sig_algs_cert(SSL_CONNECTION *s, PACKET *pkt,
276
    ossl_unused unsigned int context,
277
    ossl_unused X509 *x,
278
    ossl_unused size_t chainidx)
279
1.36k
{
280
1.36k
    PACKET supported_sig_algs;
281
282
1.36k
    if (!PACKET_as_length_prefixed_2(pkt, &supported_sig_algs)
283
1.15k
        || PACKET_remaining(&supported_sig_algs) == 0) {
284
214
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
285
214
        return 0;
286
214
    }
287
288
    /*
289
     * We use this routine on both clients and servers, and when clients
290
     * get asked for PHA we need to always save the sigalgs regardless
291
     * of whether it was a resumption or not.
292
     */
293
1.14k
    if ((!s->server || (s->server && !s->hit))
294
1.13k
        && !tls1_save_sigalgs(s, &supported_sig_algs, 1)) {
295
17
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
296
17
        return 0;
297
17
    }
298
299
1.12k
    return 1;
300
1.14k
}
301
302
int tls_parse_ctos_sig_algs(SSL_CONNECTION *s, PACKET *pkt,
303
    unsigned int context, X509 *x, size_t chainidx)
304
10.4k
{
305
10.4k
    PACKET supported_sig_algs;
306
307
10.4k
    if (!PACKET_as_length_prefixed_2(pkt, &supported_sig_algs)
308
10.2k
        || PACKET_remaining(&supported_sig_algs) == 0) {
309
268
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
310
268
        return 0;
311
268
    }
312
313
    /*
314
     * We use this routine on both clients and servers, and when clients
315
     * get asked for PHA we need to always save the sigalgs regardless
316
     * of whether it was a resumption or not.
317
     */
318
10.1k
    if ((!s->server || (s->server && !s->hit))
319
10.0k
        && !tls1_save_sigalgs(s, &supported_sig_algs, 0)) {
320
18
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
321
18
        return 0;
322
18
    }
323
324
10.1k
    return 1;
325
10.1k
}
326
327
#ifndef OPENSSL_NO_OCSP
328
int tls_parse_ctos_status_request(SSL_CONNECTION *s, PACKET *pkt,
329
    unsigned int context,
330
    X509 *x, size_t chainidx)
331
5.92k
{
332
5.92k
    PACKET responder_id_list, exts;
333
334
    /* We ignore this in a resumption handshake */
335
5.92k
    if (s->hit)
336
28
        return 1;
337
338
    /* Not defined if we get one of these in a client Certificate */
339
5.89k
    if (x != NULL)
340
0
        return 1;
341
342
5.89k
    if (!PACKET_get_1(pkt, (unsigned int *)&s->ext.status_type)) {
343
18
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
344
18
        return 0;
345
18
    }
346
347
5.87k
    if (s->ext.status_type != TLSEXT_STATUSTYPE_ocsp) {
348
        /*
349
         * We don't know what to do with any other type so ignore it.
350
         */
351
347
        s->ext.status_type = TLSEXT_STATUSTYPE_nothing;
352
347
        return 1;
353
347
    }
354
355
5.53k
    if (!PACKET_get_length_prefixed_2(pkt, &responder_id_list)) {
356
92
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
357
92
        return 0;
358
92
    }
359
360
    /*
361
     * We remove any OCSP_RESPIDs from a previous handshake
362
     * to prevent unbounded memory growth - CVE-2016-6304
363
     */
364
5.44k
    sk_OCSP_RESPID_pop_free(s->ext.ocsp.ids, OCSP_RESPID_free);
365
5.44k
    if (PACKET_remaining(&responder_id_list) > 0) {
366
2.72k
        s->ext.ocsp.ids = sk_OCSP_RESPID_new_null();
367
2.72k
        if (s->ext.ocsp.ids == NULL) {
368
0
            SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_CRYPTO_LIB);
369
0
            return 0;
370
0
        }
371
2.72k
    } else {
372
2.71k
        s->ext.ocsp.ids = NULL;
373
2.71k
    }
374
375
5.55k
    while (PACKET_remaining(&responder_id_list) > 0) {
376
2.81k
        OCSP_RESPID *id;
377
2.81k
        PACKET responder_id;
378
2.81k
        const unsigned char *id_data;
379
380
2.81k
        if (!PACKET_get_length_prefixed_2(&responder_id_list, &responder_id)
381
2.73k
            || PACKET_remaining(&responder_id) == 0) {
382
88
            SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
383
88
            return 0;
384
88
        }
385
386
2.72k
        id_data = PACKET_data(&responder_id);
387
2.72k
        id = d2i_OCSP_RESPID(NULL, &id_data,
388
2.72k
            (int)PACKET_remaining(&responder_id));
389
2.72k
        if (id == NULL) {
390
2.56k
            SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
391
2.56k
            return 0;
392
2.56k
        }
393
394
166
        if (id_data != PACKET_end(&responder_id)) {
395
55
            OCSP_RESPID_free(id);
396
55
            SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
397
398
55
            return 0;
399
55
        }
400
401
111
        if (!sk_OCSP_RESPID_push(s->ext.ocsp.ids, id)) {
402
0
            OCSP_RESPID_free(id);
403
0
            SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
404
405
0
            return 0;
406
0
        }
407
111
    }
408
409
    /* Read in request_extensions */
410
2.73k
    if (!PACKET_as_length_prefixed_2(pkt, &exts)) {
411
77
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
412
77
        return 0;
413
77
    }
414
415
2.65k
    if (PACKET_remaining(&exts) > 0) {
416
1.06k
        const unsigned char *ext_data = PACKET_data(&exts);
417
418
1.06k
        sk_X509_EXTENSION_pop_free(s->ext.ocsp.exts,
419
1.06k
            X509_EXTENSION_free);
420
1.06k
        s->ext.ocsp.exts = d2i_X509_EXTENSIONS(NULL, &ext_data, (int)PACKET_remaining(&exts));
421
1.06k
        if (s->ext.ocsp.exts == NULL || ext_data != PACKET_end(&exts)) {
422
1.05k
            SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
423
1.05k
            return 0;
424
1.05k
        }
425
1.06k
    }
426
427
1.60k
    return 1;
428
2.65k
}
429
#endif
430
431
#ifndef OPENSSL_NO_NEXTPROTONEG
432
int tls_parse_ctos_npn(SSL_CONNECTION *s, PACKET *pkt, unsigned int context,
433
    X509 *x, size_t chainidx)
434
19
{
435
    /*
436
     * We shouldn't accept this extension on a
437
     * renegotiation.
438
     */
439
19
    if (SSL_IS_FIRST_HANDSHAKE(s))
440
19
        s->s3.npn_seen = 1;
441
442
19
    return 1;
443
19
}
444
#endif
445
446
/*
447
 * Save the ALPN extension in a ClientHello.|pkt| holds the contents of the ALPN
448
 * extension, not including type and length. Returns: 1 on success, 0 on error.
449
 */
450
int tls_parse_ctos_alpn(SSL_CONNECTION *s, PACKET *pkt, unsigned int context,
451
    X509 *x, size_t chainidx)
452
426
{
453
426
    PACKET protocol_list, save_protocol_list, protocol;
454
455
426
    if (!SSL_IS_FIRST_HANDSHAKE(s))
456
0
        return 1;
457
458
426
    if (!PACKET_as_length_prefixed_2(pkt, &protocol_list)
459
309
        || PACKET_remaining(&protocol_list) < 2) {
460
128
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
461
128
        return 0;
462
128
    }
463
464
298
    save_protocol_list = protocol_list;
465
2.59k
    do {
466
        /* Protocol names can't be empty. */
467
2.59k
        if (!PACKET_get_length_prefixed_1(&protocol_list, &protocol)
468
2.51k
            || PACKET_remaining(&protocol) == 0) {
469
119
            SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
470
119
            return 0;
471
119
        }
472
2.59k
    } while (PACKET_remaining(&protocol_list) != 0);
473
474
179
    OPENSSL_free(s->s3.alpn_proposed);
475
179
    s->s3.alpn_proposed = NULL;
476
179
    s->s3.alpn_proposed_len = 0;
477
179
    if (!PACKET_memdup(&save_protocol_list,
478
179
            &s->s3.alpn_proposed, &s->s3.alpn_proposed_len)) {
479
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
480
0
        return 0;
481
0
    }
482
483
179
    return 1;
484
179
}
485
486
#ifndef OPENSSL_NO_SRTP
487
int tls_parse_ctos_use_srtp(SSL_CONNECTION *s, PACKET *pkt,
488
    unsigned int context, X509 *x, size_t chainidx)
489
1.32k
{
490
1.32k
    STACK_OF(SRTP_PROTECTION_PROFILE) *srvr;
491
1.32k
    unsigned int ct, mki_len, id;
492
1.32k
    int i, srtp_pref;
493
1.32k
    PACKET subpkt;
494
1.32k
    SSL *ssl = SSL_CONNECTION_GET_SSL(s);
495
496
    /* Ignore this if we have no SRTP profiles */
497
1.32k
    if (SSL_get_srtp_profiles(ssl) == NULL)
498
1.32k
        return 1;
499
500
    /* Pull off the length of the cipher suite list  and check it is even */
501
0
    if (!PACKET_get_net_2(pkt, &ct) || (ct & 1) != 0
502
0
        || !PACKET_get_sub_packet(pkt, &subpkt, ct)) {
503
0
        SSLfatal(s, SSL_AD_DECODE_ERROR,
504
0
            SSL_R_BAD_SRTP_PROTECTION_PROFILE_LIST);
505
0
        return 0;
506
0
    }
507
508
0
    srvr = SSL_get_srtp_profiles(ssl);
509
0
    s->srtp_profile = NULL;
510
    /* Search all profiles for a match initially */
511
0
    srtp_pref = sk_SRTP_PROTECTION_PROFILE_num(srvr);
512
513
0
    while (PACKET_remaining(&subpkt)) {
514
0
        if (!PACKET_get_net_2(&subpkt, &id)) {
515
0
            SSLfatal(s, SSL_AD_DECODE_ERROR,
516
0
                SSL_R_BAD_SRTP_PROTECTION_PROFILE_LIST);
517
0
            return 0;
518
0
        }
519
520
        /*
521
         * Only look for match in profiles of higher preference than
522
         * current match.
523
         * If no profiles have been have been configured then this
524
         * does nothing.
525
         */
526
0
        for (i = 0; i < srtp_pref; i++) {
527
0
            SRTP_PROTECTION_PROFILE *sprof = sk_SRTP_PROTECTION_PROFILE_value(srvr, i);
528
529
0
            if (sprof->id == id) {
530
0
                s->srtp_profile = sprof;
531
0
                srtp_pref = i;
532
0
                break;
533
0
            }
534
0
        }
535
0
    }
536
537
    /* Now extract the MKI value as a sanity check, but discard it for now */
538
0
    if (!PACKET_get_1(pkt, &mki_len)) {
539
0
        SSLfatal(s, SSL_AD_DECODE_ERROR,
540
0
            SSL_R_BAD_SRTP_PROTECTION_PROFILE_LIST);
541
0
        return 0;
542
0
    }
543
544
0
    if (!PACKET_forward(pkt, mki_len)
545
0
        || PACKET_remaining(pkt)) {
546
0
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_SRTP_MKI_VALUE);
547
0
        return 0;
548
0
    }
549
550
0
    return 1;
551
0
}
552
#endif
553
554
int tls_parse_ctos_etm(SSL_CONNECTION *s, PACKET *pkt, unsigned int context,
555
    X509 *x, size_t chainidx)
556
1.84k
{
557
1.84k
    if (!(s->options & SSL_OP_NO_ENCRYPT_THEN_MAC))
558
1.84k
        s->ext.use_etm = 1;
559
560
1.84k
    return 1;
561
1.84k
}
562
563
/*
564
 * Process a psk_kex_modes extension received in the ClientHello. |pkt| contains
565
 * the raw PACKET data for the extension. Returns 1 on success or 0 on failure.
566
 */
567
int tls_parse_ctos_psk_kex_modes(SSL_CONNECTION *s, PACKET *pkt,
568
    unsigned int context,
569
    X509 *x, size_t chainidx)
570
1.64k
{
571
1.64k
#ifndef OPENSSL_NO_TLS1_3
572
1.64k
    PACKET psk_kex_modes;
573
1.64k
    unsigned int mode;
574
575
1.64k
    if (!PACKET_as_length_prefixed_1(pkt, &psk_kex_modes)
576
1.60k
        || PACKET_remaining(&psk_kex_modes) == 0) {
577
46
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
578
46
        return 0;
579
46
    }
580
581
10.0k
    while (PACKET_get_1(&psk_kex_modes, &mode)) {
582
8.48k
        if (mode == TLSEXT_KEX_MODE_KE_DHE)
583
2.74k
            s->ext.psk_kex_mode |= TLSEXT_KEX_MODE_FLAG_KE_DHE;
584
5.74k
        else if (mode == TLSEXT_KEX_MODE_KE
585
1.95k
            && (s->options & SSL_OP_ALLOW_NO_DHE_KEX) != 0)
586
0
            s->ext.psk_kex_mode |= TLSEXT_KEX_MODE_FLAG_KE;
587
8.48k
    }
588
589
1.59k
    if (((s->ext.psk_kex_mode & TLSEXT_KEX_MODE_FLAG_KE) != 0)
590
0
        && (s->options & SSL_OP_PREFER_NO_DHE_KEX) != 0) {
591
592
        /*
593
         * If NO_DHE is supported and preferred, then we only remember this
594
         * mode. DHE PSK will not be used for sure, because in any case where
595
         * it would be supported (i.e. if a key share is present), NO_DHE would
596
         * be supported as well. As the latter is preferred it would be
597
         * chosen. By removing DHE PSK here, we don't have to deal with the
598
         * SSL_OP_PREFER_NO_DHE_KEX option in any other place.
599
         */
600
0
        s->ext.psk_kex_mode = TLSEXT_KEX_MODE_FLAG_KE;
601
0
    }
602
603
1.59k
#endif
604
605
1.59k
    return 1;
606
1.64k
}
607
608
/*
609
 * Process a key_share extension received in the ClientHello. |pkt| contains
610
 * the raw PACKET data for the extension. Returns 1 on success or 0 on failure.
611
 */
612
int tls_parse_ctos_key_share(SSL_CONNECTION *s, PACKET *pkt,
613
    unsigned int context, X509 *x, size_t chainidx)
614
2.17k
{
615
2.17k
#ifndef OPENSSL_NO_TLS1_3
616
2.17k
    unsigned int group_id;
617
2.17k
    PACKET key_share_list, encoded_pt;
618
2.17k
    const uint16_t *clntgroups, *srvrgroups;
619
2.17k
    size_t clnt_num_groups, srvr_num_groups;
620
2.17k
    int found = 0;
621
622
2.17k
    if (s->hit && (s->ext.psk_kex_mode & TLSEXT_KEX_MODE_FLAG_KE_DHE) == 0)
623
0
        return 1;
624
625
    /* Sanity check */
626
2.17k
    if (s->s3.peer_tmp != NULL) {
627
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
628
0
        return 0;
629
0
    }
630
631
2.17k
    if (!PACKET_as_length_prefixed_2(pkt, &key_share_list)) {
632
59
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_LENGTH_MISMATCH);
633
59
        return 0;
634
59
    }
635
636
    /* Get our list of supported groups */
637
2.11k
    tls1_get_supported_groups(s, &srvrgroups, &srvr_num_groups);
638
    /* Get the clients list of supported groups. */
639
2.11k
    tls1_get_peer_groups(s, &clntgroups, &clnt_num_groups);
640
2.11k
    if (clnt_num_groups == 0) {
641
        /*
642
         * This can only happen if the supported_groups extension was not sent,
643
         * because we verify that the length is non-zero when we process that
644
         * extension.
645
         */
646
4
        SSLfatal(s, SSL_AD_MISSING_EXTENSION,
647
4
            SSL_R_MISSING_SUPPORTED_GROUPS_EXTENSION);
648
4
        return 0;
649
4
    }
650
651
2.11k
    if (s->s3.group_id != 0 && PACKET_remaining(&key_share_list) == 0) {
652
        /*
653
         * If we set a group_id already, then we must have sent an HRR
654
         * requesting a new key_share. If we haven't got one then that is an
655
         * error
656
         */
657
5
        SSLfatal(s, SSL_AD_ILLEGAL_PARAMETER, SSL_R_BAD_KEY_SHARE);
658
5
        return 0;
659
5
    }
660
661
4.37k
    while (PACKET_remaining(&key_share_list) > 0) {
662
2.45k
        if (!PACKET_get_net_2(&key_share_list, &group_id)
663
2.44k
            || !PACKET_get_length_prefixed_2(&key_share_list, &encoded_pt)
664
2.39k
            || PACKET_remaining(&encoded_pt) == 0) {
665
66
            SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_LENGTH_MISMATCH);
666
66
            return 0;
667
66
        }
668
669
        /*
670
         * If we already found a suitable key_share we loop through the
671
         * rest to verify the structure, but don't process them.
672
         */
673
2.38k
        if (found)
674
224
            continue;
675
676
        /*
677
         * If we sent an HRR then the key_share sent back MUST be for the group
678
         * we requested, and must be the only key_share sent.
679
         */
680
2.16k
        if (s->s3.group_id != 0
681
103
            && (group_id != s->s3.group_id
682
68
                || PACKET_remaining(&key_share_list) != 0)) {
683
39
            SSLfatal(s, SSL_AD_ILLEGAL_PARAMETER, SSL_R_BAD_KEY_SHARE);
684
39
            return 0;
685
39
        }
686
687
        /* Check if this share is in supported_groups sent from client */
688
2.12k
        if (!check_in_list(s, group_id, clntgroups, clnt_num_groups, 0)) {
689
33
            SSLfatal(s, SSL_AD_ILLEGAL_PARAMETER, SSL_R_BAD_KEY_SHARE);
690
33
            return 0;
691
33
        }
692
693
        /* Check if this share is for a group we can use */
694
2.09k
        if (!check_in_list(s, group_id, srvrgroups, srvr_num_groups, 1)
695
1.57k
            || !tls_group_allowed(s, group_id, SSL_SECOP_CURVE_SUPPORTED)
696
            /*
697
             * We tolerate but ignore a group id that we don't think is
698
             * suitable for TLSv1.3
699
             */
700
1.57k
            || !tls_valid_group(s, group_id, TLS1_3_VERSION, TLS1_3_VERSION,
701
1.57k
                0, NULL)) {
702
            /* Share not suitable */
703
515
            continue;
704
515
        }
705
706
1.57k
        s->s3.group_id = group_id;
707
        /* Cache the selected group ID in the SSL_SESSION */
708
1.57k
        s->session->kex_group = group_id;
709
710
1.57k
        if ((s->s3.peer_tmp = ssl_generate_param_group(s, group_id)) == NULL) {
711
0
            SSLfatal(s, SSL_AD_INTERNAL_ERROR,
712
0
                SSL_R_UNABLE_TO_FIND_ECDH_PARAMETERS);
713
0
            return 0;
714
0
        }
715
716
1.57k
        if (tls13_set_encoded_pub_key(s->s3.peer_tmp,
717
1.57k
                PACKET_data(&encoded_pt),
718
1.57k
                PACKET_remaining(&encoded_pt))
719
1.57k
            <= 0) {
720
42
            SSLfatal(s, SSL_AD_ILLEGAL_PARAMETER, SSL_R_BAD_ECPOINT);
721
42
            return 0;
722
42
        }
723
724
1.53k
        found = 1;
725
1.53k
    }
726
1.92k
#endif
727
728
1.92k
    return 1;
729
2.10k
}
730
731
int tls_parse_ctos_cookie(SSL_CONNECTION *s, PACKET *pkt, unsigned int context,
732
    X509 *x, size_t chainidx)
733
89
{
734
89
#ifndef OPENSSL_NO_TLS1_3
735
89
    unsigned int format, version, key_share, group_id;
736
89
    EVP_MD_CTX *hctx;
737
89
    EVP_PKEY *pkey;
738
89
    PACKET cookie, raw, chhash, appcookie;
739
89
    WPACKET hrrpkt;
740
89
    const unsigned char *data, *mdin, *ciphdata;
741
89
    unsigned char hmac[SHA256_DIGEST_LENGTH];
742
89
    unsigned char hrr[MAX_HRR_SIZE];
743
89
    size_t rawlen, hmaclen, hrrlen, ciphlen;
744
89
    uint64_t tm, now;
745
89
    SSL *ssl = SSL_CONNECTION_GET_SSL(s);
746
89
    SSL_CTX *sctx = SSL_CONNECTION_GET_CTX(s);
747
748
    /* Ignore any cookie if we're not set up to verify it */
749
89
    if (sctx->verify_stateless_cookie_cb == NULL
750
0
        || (s->s3.flags & TLS1_FLAGS_STATELESS) == 0)
751
89
        return 1;
752
753
0
    if (!PACKET_as_length_prefixed_2(pkt, &cookie)) {
754
0
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_LENGTH_MISMATCH);
755
0
        return 0;
756
0
    }
757
758
0
    raw = cookie;
759
0
    data = PACKET_data(&raw);
760
0
    rawlen = PACKET_remaining(&raw);
761
0
    if (rawlen < SHA256_DIGEST_LENGTH
762
0
        || !PACKET_forward(&raw, rawlen - SHA256_DIGEST_LENGTH)) {
763
0
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_LENGTH_MISMATCH);
764
0
        return 0;
765
0
    }
766
0
    mdin = PACKET_data(&raw);
767
768
    /* Verify the HMAC of the cookie */
769
0
    hctx = EVP_MD_CTX_create();
770
0
    pkey = EVP_PKEY_new_raw_private_key_ex(sctx->libctx, "HMAC",
771
0
        sctx->propq,
772
0
        s->session_ctx->ext.cookie_hmac_key,
773
0
        sizeof(s->session_ctx->ext.cookie_hmac_key));
774
0
    if (hctx == NULL || pkey == NULL) {
775
0
        EVP_MD_CTX_free(hctx);
776
0
        EVP_PKEY_free(pkey);
777
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_EVP_LIB);
778
0
        return 0;
779
0
    }
780
781
0
    hmaclen = SHA256_DIGEST_LENGTH;
782
0
    if (EVP_DigestSignInit_ex(hctx, NULL, "SHA2-256", sctx->libctx,
783
0
            sctx->propq, pkey, NULL)
784
0
            <= 0
785
0
        || EVP_DigestSign(hctx, hmac, &hmaclen, data,
786
0
               rawlen - SHA256_DIGEST_LENGTH)
787
0
            <= 0
788
0
        || hmaclen != SHA256_DIGEST_LENGTH) {
789
0
        EVP_MD_CTX_free(hctx);
790
0
        EVP_PKEY_free(pkey);
791
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
792
0
        return 0;
793
0
    }
794
795
0
    EVP_MD_CTX_free(hctx);
796
0
    EVP_PKEY_free(pkey);
797
798
0
    if (CRYPTO_memcmp(hmac, mdin, SHA256_DIGEST_LENGTH) != 0) {
799
0
        SSLfatal(s, SSL_AD_ILLEGAL_PARAMETER, SSL_R_COOKIE_MISMATCH);
800
0
        return 0;
801
0
    }
802
803
0
    if (!PACKET_get_net_2(&cookie, &format)) {
804
0
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_LENGTH_MISMATCH);
805
0
        return 0;
806
0
    }
807
    /* Check the cookie format is something we recognise. Ignore it if not */
808
0
    if (format != COOKIE_STATE_FORMAT_VERSION)
809
0
        return 1;
810
811
    /*
812
     * The rest of these checks really shouldn't fail since we have verified the
813
     * HMAC above.
814
     */
815
816
    /* Check the version number is sane */
817
0
    if (!PACKET_get_net_2(&cookie, &version)) {
818
0
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_LENGTH_MISMATCH);
819
0
        return 0;
820
0
    }
821
0
    if (version != TLS1_3_VERSION) {
822
0
        SSLfatal(s, SSL_AD_ILLEGAL_PARAMETER,
823
0
            SSL_R_BAD_PROTOCOL_VERSION_NUMBER);
824
0
        return 0;
825
0
    }
826
827
0
    if (!PACKET_get_net_2(&cookie, &group_id)) {
828
0
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_LENGTH_MISMATCH);
829
0
        return 0;
830
0
    }
831
832
0
    ciphdata = PACKET_data(&cookie);
833
0
    if (!PACKET_forward(&cookie, 2)) {
834
0
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_LENGTH_MISMATCH);
835
0
        return 0;
836
0
    }
837
0
    if (group_id != s->s3.group_id
838
0
        || s->s3.tmp.new_cipher
839
0
            != ssl_get_cipher_by_char(s, ciphdata, 0)) {
840
        /*
841
         * We chose a different cipher or group id this time around to what is
842
         * in the cookie. Something must have changed.
843
         */
844
0
        SSLfatal(s, SSL_AD_ILLEGAL_PARAMETER, SSL_R_BAD_CIPHER);
845
0
        return 0;
846
0
    }
847
848
0
    if (!PACKET_get_1(&cookie, &key_share)
849
0
        || !PACKET_get_net_8(&cookie, &tm)
850
0
        || !PACKET_get_length_prefixed_2(&cookie, &chhash)
851
0
        || !PACKET_get_length_prefixed_1(&cookie, &appcookie)
852
0
        || PACKET_remaining(&cookie) != SHA256_DIGEST_LENGTH) {
853
0
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_LENGTH_MISMATCH);
854
0
        return 0;
855
0
    }
856
857
    /* We tolerate a cookie age of up to 10 minutes (= 60 * 10 seconds) */
858
0
    now = time(NULL);
859
0
    if (tm > now || (now - tm) > 600) {
860
        /* Cookie is stale. Ignore it */
861
0
        return 1;
862
0
    }
863
864
    /* Verify the app cookie */
865
0
    if (sctx->verify_stateless_cookie_cb(SSL_CONNECTION_GET_USER_SSL(s),
866
0
            PACKET_data(&appcookie),
867
0
            PACKET_remaining(&appcookie))
868
0
        == 0) {
869
0
        SSLfatal(s, SSL_AD_ILLEGAL_PARAMETER, SSL_R_COOKIE_MISMATCH);
870
0
        return 0;
871
0
    }
872
873
    /*
874
     * Reconstruct the HRR that we would have sent in response to the original
875
     * ClientHello so we can add it to the transcript hash.
876
     * Note: This won't work with custom HRR extensions
877
     */
878
0
    if (!WPACKET_init_static_len(&hrrpkt, hrr, sizeof(hrr), 0)) {
879
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
880
0
        return 0;
881
0
    }
882
0
    if (!WPACKET_put_bytes_u8(&hrrpkt, SSL3_MT_SERVER_HELLO)
883
0
        || !WPACKET_start_sub_packet_u24(&hrrpkt)
884
0
        || !WPACKET_put_bytes_u16(&hrrpkt, TLS1_2_VERSION)
885
0
        || !WPACKET_memcpy(&hrrpkt, hrrrandom, SSL3_RANDOM_SIZE)
886
0
        || !WPACKET_sub_memcpy_u8(&hrrpkt, s->tmp_session_id,
887
0
            s->tmp_session_id_len)
888
0
        || !ssl->method->put_cipher_by_char(s->s3.tmp.new_cipher, &hrrpkt,
889
0
            &ciphlen)
890
0
        || !WPACKET_put_bytes_u8(&hrrpkt, 0)
891
0
        || !WPACKET_start_sub_packet_u16(&hrrpkt)) {
892
0
        WPACKET_cleanup(&hrrpkt);
893
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
894
0
        return 0;
895
0
    }
896
0
    if (!WPACKET_put_bytes_u16(&hrrpkt, TLSEXT_TYPE_supported_versions)
897
0
        || !WPACKET_start_sub_packet_u16(&hrrpkt)
898
0
        || !WPACKET_put_bytes_u16(&hrrpkt, s->version)
899
0
        || !WPACKET_close(&hrrpkt)) {
900
0
        WPACKET_cleanup(&hrrpkt);
901
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
902
0
        return 0;
903
0
    }
904
0
    if (key_share) {
905
0
        if (!WPACKET_put_bytes_u16(&hrrpkt, TLSEXT_TYPE_key_share)
906
0
            || !WPACKET_start_sub_packet_u16(&hrrpkt)
907
0
            || !WPACKET_put_bytes_u16(&hrrpkt, s->s3.group_id)
908
0
            || !WPACKET_close(&hrrpkt)) {
909
0
            WPACKET_cleanup(&hrrpkt);
910
0
            SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
911
0
            return 0;
912
0
        }
913
0
    }
914
0
    if (!WPACKET_put_bytes_u16(&hrrpkt, TLSEXT_TYPE_cookie)
915
0
        || !WPACKET_start_sub_packet_u16(&hrrpkt)
916
0
        || !WPACKET_sub_memcpy_u16(&hrrpkt, data, rawlen)
917
0
        || !WPACKET_close(&hrrpkt) /* cookie extension */
918
0
        || !WPACKET_close(&hrrpkt) /* extension block */
919
0
        || !WPACKET_close(&hrrpkt) /* message */
920
0
        || !WPACKET_get_total_written(&hrrpkt, &hrrlen)
921
0
        || !WPACKET_finish(&hrrpkt)) {
922
0
        WPACKET_cleanup(&hrrpkt);
923
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
924
0
        return 0;
925
0
    }
926
927
    /* Reconstruct the transcript hash */
928
0
    if (!create_synthetic_message_hash(s, PACKET_data(&chhash),
929
0
            PACKET_remaining(&chhash), hrr,
930
0
            hrrlen)) {
931
        /* SSLfatal() already called */
932
0
        return 0;
933
0
    }
934
935
    /* Act as if this ClientHello came after a HelloRetryRequest */
936
0
    s->hello_retry_request = SSL_HRR_PENDING;
937
938
0
    s->ext.cookieok = 1;
939
0
#endif
940
941
0
    return 1;
942
0
}
943
944
int tls_parse_ctos_supported_groups(SSL_CONNECTION *s, PACKET *pkt,
945
    unsigned int context,
946
    X509 *x, size_t chainidx)
947
20.4k
{
948
20.4k
    PACKET supported_groups_list;
949
950
    /* Each group is 2 bytes and we must have at least 1. */
951
20.4k
    if (!PACKET_as_length_prefixed_2(pkt, &supported_groups_list)
952
20.2k
        || PACKET_remaining(&supported_groups_list) == 0
953
20.2k
        || (PACKET_remaining(&supported_groups_list) % 2) != 0) {
954
263
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
955
263
        return 0;
956
263
    }
957
958
20.2k
    if (!s->hit || SSL_CONNECTION_IS_TLS13(s)) {
959
20.1k
        OPENSSL_free(s->ext.peer_supportedgroups);
960
20.1k
        s->ext.peer_supportedgroups = NULL;
961
20.1k
        s->ext.peer_supportedgroups_len = 0;
962
20.1k
        if (!tls1_save_u16(&supported_groups_list,
963
20.1k
                &s->ext.peer_supportedgroups,
964
20.1k
                &s->ext.peer_supportedgroups_len)) {
965
0
            SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
966
0
            return 0;
967
0
        }
968
20.1k
    }
969
970
20.2k
    return 1;
971
20.2k
}
972
973
int tls_parse_ctos_ems(SSL_CONNECTION *s, PACKET *pkt, unsigned int context,
974
    X509 *x, size_t chainidx)
975
4.92k
{
976
    /* The extension must always be empty */
977
4.92k
    if (PACKET_remaining(pkt) != 0) {
978
22
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
979
22
        return 0;
980
22
    }
981
982
4.90k
    if (s->options & SSL_OP_NO_EXTENDED_MASTER_SECRET)
983
0
        return 1;
984
985
4.90k
    s->s3.flags |= TLS1_FLAGS_RECEIVED_EXTMS;
986
987
4.90k
    return 1;
988
4.90k
}
989
990
int tls_parse_ctos_early_data(SSL_CONNECTION *s, PACKET *pkt, unsigned int context,
991
    X509 *x, size_t chainidx)
992
2.67k
{
993
2.67k
    if (PACKET_remaining(pkt) != 0) {
994
8
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
995
8
        return 0;
996
8
    }
997
998
2.67k
    if (s->hello_retry_request != SSL_HRR_NONE) {
999
8
        SSLfatal(s, SSL_AD_ILLEGAL_PARAMETER, SSL_R_BAD_EXTENSION);
1000
8
        return 0;
1001
8
    }
1002
1003
2.66k
    return 1;
1004
2.67k
}
1005
1006
static SSL_TICKET_STATUS tls_get_stateful_ticket(SSL_CONNECTION *s, PACKET *tick,
1007
    SSL_SESSION **sess)
1008
0
{
1009
0
    SSL_SESSION *tmpsess = NULL;
1010
1011
0
    s->ext.ticket_expected = 1;
1012
1013
0
    switch (PACKET_remaining(tick)) {
1014
0
    case 0:
1015
0
        return SSL_TICKET_EMPTY;
1016
1017
0
    case SSL_MAX_SSL_SESSION_ID_LENGTH:
1018
0
        break;
1019
1020
0
    default:
1021
0
        return SSL_TICKET_NO_DECRYPT;
1022
0
    }
1023
1024
0
    tmpsess = lookup_sess_in_cache(s, PACKET_data(tick),
1025
0
        SSL_MAX_SSL_SESSION_ID_LENGTH);
1026
1027
0
    if (tmpsess == NULL)
1028
0
        return SSL_TICKET_NO_DECRYPT;
1029
1030
0
    *sess = tmpsess;
1031
0
    return SSL_TICKET_SUCCESS;
1032
0
}
1033
1034
int tls_parse_ctos_psk(SSL_CONNECTION *s, PACKET *pkt, unsigned int context,
1035
    X509 *x, size_t chainidx)
1036
432
{
1037
432
    PACKET identities, binders, binder;
1038
432
    size_t binderoffset;
1039
432
    int hashsize;
1040
432
    SSL_SESSION *sess = NULL;
1041
432
    unsigned int id, i, ext = 0;
1042
432
    const EVP_MD *md = NULL;
1043
432
    SSL_CTX *sctx = SSL_CONNECTION_GET_CTX(s);
1044
432
    SSL *ussl = SSL_CONNECTION_GET_USER_SSL(s);
1045
1046
    /*
1047
     * If we have no PSK kex mode that we recognise then we can't resume so
1048
     * ignore this extension
1049
     */
1050
432
    if ((s->ext.psk_kex_mode
1051
432
            & (TLSEXT_KEX_MODE_FLAG_KE | TLSEXT_KEX_MODE_FLAG_KE_DHE))
1052
432
        == 0)
1053
8
        return 1;
1054
1055
424
    if (!PACKET_get_length_prefixed_2(pkt, &identities)) {
1056
23
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
1057
23
        return 0;
1058
23
    }
1059
1060
401
    s->ext.ticket_expected = 0;
1061
784
    for (id = 0; PACKET_remaining(&identities) != 0; id++) {
1062
622
        PACKET identity;
1063
622
        unsigned long ticket_agel;
1064
622
        size_t idlen;
1065
1066
622
        if (!PACKET_get_length_prefixed_2(&identities, &identity)
1067
536
            || !PACKET_get_net_4(&identities, &ticket_agel)) {
1068
96
            SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
1069
96
            return 0;
1070
96
        }
1071
1072
526
        idlen = PACKET_remaining(&identity);
1073
526
        if (idlen == 0) {
1074
13
            SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
1075
13
            return 0;
1076
13
        }
1077
513
        if (s->psk_find_session_cb != NULL
1078
0
            && !s->psk_find_session_cb(ussl, PACKET_data(&identity), idlen,
1079
0
                &sess)) {
1080
0
            SSLfatal(s, SSL_AD_INTERNAL_ERROR, SSL_R_BAD_EXTENSION);
1081
0
            return 0;
1082
0
        }
1083
1084
513
#ifndef OPENSSL_NO_PSK
1085
513
        if (sess == NULL
1086
513
            && s->psk_server_callback != NULL
1087
0
            && idlen <= PSK_MAX_IDENTITY_LEN) {
1088
0
            char *pskid = NULL;
1089
0
            unsigned char pskdata[PSK_MAX_PSK_LEN];
1090
0
            unsigned int pskdatalen;
1091
1092
0
            if (!PACKET_strndup(&identity, &pskid)) {
1093
0
                SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1094
0
                return 0;
1095
0
            }
1096
0
            pskdatalen = s->psk_server_callback(ussl, pskid, pskdata,
1097
0
                sizeof(pskdata));
1098
0
            OPENSSL_free(pskid);
1099
0
            if (pskdatalen > PSK_MAX_PSK_LEN) {
1100
0
                SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1101
0
                return 0;
1102
0
            } else if (pskdatalen > 0) {
1103
0
                const SSL_CIPHER *cipher;
1104
0
                const unsigned char tls13_aes128gcmsha256_id[] = { 0x13, 0x01 };
1105
1106
                /*
1107
                 * We found a PSK using an old style callback. We don't know
1108
                 * the digest so we default to SHA256 as per the TLSv1.3 spec
1109
                 */
1110
0
                cipher = SSL_CIPHER_find(SSL_CONNECTION_GET_SSL(s),
1111
0
                    tls13_aes128gcmsha256_id);
1112
0
                if (cipher == NULL) {
1113
0
                    OPENSSL_cleanse(pskdata, pskdatalen);
1114
0
                    SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1115
0
                    return 0;
1116
0
                }
1117
1118
0
                sess = SSL_SESSION_new();
1119
0
                if (sess == NULL
1120
0
                    || !SSL_SESSION_set1_master_key(sess, pskdata,
1121
0
                        pskdatalen)
1122
0
                    || !SSL_SESSION_set_cipher(sess, cipher)
1123
0
                    || !SSL_SESSION_set_protocol_version(sess,
1124
0
                        TLS1_3_VERSION)) {
1125
0
                    OPENSSL_cleanse(pskdata, pskdatalen);
1126
0
                    SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1127
0
                    goto err;
1128
0
                }
1129
0
                OPENSSL_cleanse(pskdata, pskdatalen);
1130
0
            }
1131
0
        }
1132
513
#endif /* OPENSSL_NO_PSK */
1133
1134
513
        if (sess != NULL) {
1135
            /* We found a PSK */
1136
0
            SSL_SESSION *sesstmp = ssl_session_dup(sess, 0);
1137
1138
0
            if (sesstmp == NULL) {
1139
0
                SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1140
0
                goto err;
1141
0
            }
1142
0
            SSL_SESSION_free(sess);
1143
0
            sess = sesstmp;
1144
1145
            /*
1146
             * We've just been told to use this session for this context so
1147
             * make sure the sid_ctx matches up.
1148
             */
1149
0
            memcpy(sess->sid_ctx, s->sid_ctx, s->sid_ctx_length);
1150
0
            sess->sid_ctx_length = s->sid_ctx_length;
1151
0
            ext = 1;
1152
0
            if (id == 0)
1153
0
                s->ext.early_data_ok = 1;
1154
0
            s->ext.ticket_expected = 1;
1155
513
        } else {
1156
513
            OSSL_TIME t, age, expire;
1157
513
            int ret;
1158
1159
            /*
1160
             * If we are using anti-replay protection then we behave as if
1161
             * SSL_OP_NO_TICKET is set - we are caching tickets anyway so there
1162
             * is no point in using full stateless tickets.
1163
             */
1164
513
            if ((s->options & SSL_OP_NO_TICKET) != 0
1165
513
                || (s->max_early_data > 0
1166
0
                    && (s->options & SSL_OP_NO_ANTI_REPLAY) == 0))
1167
0
                ret = tls_get_stateful_ticket(s, &identity, &sess);
1168
513
            else
1169
513
                ret = tls_decrypt_ticket(s, PACKET_data(&identity),
1170
513
                    PACKET_remaining(&identity), NULL, 0,
1171
513
                    &sess);
1172
1173
513
            if (ret == SSL_TICKET_EMPTY) {
1174
0
                SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
1175
0
                goto err;
1176
0
            }
1177
1178
513
            if (ret == SSL_TICKET_FATAL_ERR_MALLOC
1179
513
                || ret == SSL_TICKET_FATAL_ERR_OTHER) {
1180
0
                SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1181
0
                goto err;
1182
0
            }
1183
513
            if (ret == SSL_TICKET_NONE || ret == SSL_TICKET_NO_DECRYPT)
1184
254
                continue;
1185
1186
            /* Check for replay */
1187
259
            if (s->max_early_data > 0
1188
0
                && (s->options & SSL_OP_NO_ANTI_REPLAY) == 0
1189
0
                && !SSL_CTX_remove_session(s->session_ctx, sess)) {
1190
0
                SSL_SESSION_free(sess);
1191
0
                sess = NULL;
1192
0
                continue;
1193
0
            }
1194
1195
259
            age = ossl_time_subtract(ossl_ms2time(ticket_agel),
1196
259
                ossl_ms2time(sess->ext.tick_age_add));
1197
259
            t = ossl_time_subtract(ossl_time_now(), sess->time);
1198
1199
            /*
1200
             * Although internally we use OSS_TIME which has ns granularity,
1201
             * when SSL_SESSION structures are serialised/deserialised we use
1202
             * second granularity for the sess->time field. Therefore it could
1203
             * appear that the client's ticket age is longer than ours (our
1204
             * ticket age calculation should always be slightly longer than the
1205
             * client's due to the network latency). Therefore we add 1000ms to
1206
             * our age calculation to adjust for rounding errors.
1207
             */
1208
259
            expire = ossl_time_add(t, ossl_ms2time(1000));
1209
1210
259
            if (id == 0
1211
258
                && ossl_time_compare(sess->timeout, t) >= 0
1212
150
                && ossl_time_compare(age, expire) <= 0
1213
57
                && ossl_time_compare(ossl_time_add(age, TICKET_AGE_ALLOWANCE),
1214
57
                       expire)
1215
57
                    >= 0) {
1216
                /*
1217
                 * Ticket age is within tolerance and not expired. We allow it
1218
                 * for early data
1219
                 */
1220
57
                s->ext.early_data_ok = 1;
1221
57
            }
1222
259
        }
1223
1224
259
        md = ssl_md(sctx, sess->cipher->algorithm2);
1225
259
        if (md == NULL) {
1226
0
            SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1227
0
            goto err;
1228
0
        }
1229
259
        if (!EVP_MD_is_a(md,
1230
259
                EVP_MD_get0_name(ssl_md(sctx,
1231
259
                    s->s3.tmp.new_cipher->algorithm2)))) {
1232
            /* The ciphersuite is not compatible with this session. */
1233
129
            SSL_SESSION_free(sess);
1234
129
            sess = NULL;
1235
129
            s->ext.early_data_ok = 0;
1236
            /*
1237
             * We fall back to a full handshake. The new session ticket will be
1238
             * issued to the client with the newly negotiated ciphersuite,
1239
             * allowing successful resumption on future connections.
1240
             */
1241
129
            s->ext.ticket_expected = 1;
1242
129
            continue;
1243
129
        }
1244
130
        break;
1245
259
    }
1246
1247
292
    if (sess == NULL)
1248
162
        return 1;
1249
1250
130
    binderoffset = PACKET_data(pkt) - (const unsigned char *)s->init_buf->data;
1251
130
    hashsize = EVP_MD_get_size(md);
1252
130
    if (hashsize <= 0)
1253
0
        goto err;
1254
1255
130
    if (!PACKET_get_length_prefixed_2(pkt, &binders)) {
1256
66
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
1257
66
        goto err;
1258
66
    }
1259
1260
109
    for (i = 0; i <= id; i++) {
1261
64
        if (!PACKET_get_length_prefixed_1(&binders, &binder)) {
1262
19
            SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
1263
19
            goto err;
1264
19
        }
1265
64
    }
1266
1267
45
    if (PACKET_remaining(&binder) != (size_t)hashsize) {
1268
11
        SSLfatal(s, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
1269
11
        goto err;
1270
11
    }
1271
34
    if (tls_psk_do_binder(s, md, (const unsigned char *)s->init_buf->data,
1272
34
            binderoffset, PACKET_data(&binder), NULL, sess, 0,
1273
34
            ext)
1274
34
        != 1) {
1275
        /* SSLfatal() already called */
1276
31
        goto err;
1277
31
    }
1278
1279
3
    s->ext.tick_identity = id;
1280
1281
3
    SSL_SESSION_free(s->session);
1282
3
    s->session = sess;
1283
3
    return 1;
1284
127
err:
1285
127
    SSL_SESSION_free(sess);
1286
127
    return 0;
1287
34
}
1288
1289
int tls_parse_ctos_post_handshake_auth(SSL_CONNECTION *s, PACKET *pkt,
1290
    ossl_unused unsigned int context,
1291
    ossl_unused X509 *x,
1292
    ossl_unused size_t chainidx)
1293
143
{
1294
143
    if (PACKET_remaining(pkt) != 0) {
1295
8
        SSLfatal(s, SSL_AD_DECODE_ERROR,
1296
8
            SSL_R_POST_HANDSHAKE_AUTH_ENCODING_ERR);
1297
8
        return 0;
1298
8
    }
1299
1300
135
    s->post_handshake_auth = SSL_PHA_EXT_RECEIVED;
1301
1302
135
    return 1;
1303
143
}
1304
1305
/*
1306
 * Add the server's renegotiation binding
1307
 */
1308
EXT_RETURN tls_construct_stoc_renegotiate(SSL_CONNECTION *s, WPACKET *pkt,
1309
    unsigned int context, X509 *x,
1310
    size_t chainidx)
1311
26.7k
{
1312
26.7k
    if (!s->s3.send_connection_binding)
1313
18.6k
        return EXT_RETURN_NOT_SENT;
1314
1315
    /* Still add this even if SSL_OP_NO_RENEGOTIATION is set */
1316
8.09k
    if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_renegotiate)
1317
8.09k
        || !WPACKET_start_sub_packet_u16(pkt)
1318
8.09k
        || !WPACKET_start_sub_packet_u8(pkt)
1319
8.09k
        || !WPACKET_memcpy(pkt, s->s3.previous_client_finished,
1320
8.09k
            s->s3.previous_client_finished_len)
1321
8.09k
        || !WPACKET_memcpy(pkt, s->s3.previous_server_finished,
1322
8.09k
            s->s3.previous_server_finished_len)
1323
8.09k
        || !WPACKET_close(pkt)
1324
8.09k
        || !WPACKET_close(pkt)) {
1325
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1326
0
        return EXT_RETURN_FAIL;
1327
0
    }
1328
1329
8.09k
    return EXT_RETURN_SENT;
1330
8.09k
}
1331
1332
EXT_RETURN tls_construct_stoc_server_name(SSL_CONNECTION *s, WPACKET *pkt,
1333
    unsigned int context, X509 *x,
1334
    size_t chainidx)
1335
29.7k
{
1336
29.7k
    if (s->servername_done != 1)
1337
29.7k
        return EXT_RETURN_NOT_SENT;
1338
1339
    /*
1340
     * Prior to TLSv1.3 we ignore any SNI in the current handshake if resuming.
1341
     * We just use the servername from the initial handshake.
1342
     */
1343
0
    if (s->hit && !SSL_CONNECTION_IS_TLS13(s))
1344
0
        return EXT_RETURN_NOT_SENT;
1345
1346
0
    if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_server_name)
1347
0
        || !WPACKET_put_bytes_u16(pkt, 0)) {
1348
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1349
0
        return EXT_RETURN_FAIL;
1350
0
    }
1351
1352
0
    return EXT_RETURN_SENT;
1353
0
}
1354
1355
/* Add/include the server's max fragment len extension into ServerHello */
1356
EXT_RETURN tls_construct_stoc_maxfragmentlen(SSL_CONNECTION *s, WPACKET *pkt,
1357
    unsigned int context, X509 *x,
1358
    size_t chainidx)
1359
29.7k
{
1360
29.7k
    if (!USE_MAX_FRAGMENT_LENGTH_EXT(s->session))
1361
28.4k
        return EXT_RETURN_NOT_SENT;
1362
1363
    /*-
1364
     * 4 bytes for this extension type and extension length
1365
     * 1 byte for the Max Fragment Length code value.
1366
     */
1367
1.29k
    if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_max_fragment_length)
1368
1.29k
        || !WPACKET_start_sub_packet_u16(pkt)
1369
1.29k
        || !WPACKET_put_bytes_u8(pkt, s->session->ext.max_fragment_len_mode)
1370
1.29k
        || !WPACKET_close(pkt)) {
1371
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1372
0
        return EXT_RETURN_FAIL;
1373
0
    }
1374
1375
1.29k
    return EXT_RETURN_SENT;
1376
1.29k
}
1377
1378
EXT_RETURN tls_construct_stoc_ec_pt_formats(SSL_CONNECTION *s, WPACKET *pkt,
1379
    unsigned int context, X509 *x,
1380
    size_t chainidx)
1381
26.7k
{
1382
26.7k
    unsigned long alg_k = s->s3.tmp.new_cipher->algorithm_mkey;
1383
26.7k
    unsigned long alg_a = s->s3.tmp.new_cipher->algorithm_auth;
1384
26.7k
    int using_ecc = ((alg_k & SSL_kECDHE) || (alg_a & SSL_aECDSA))
1385
12.7k
        && (s->ext.peer_ecpointformats != NULL);
1386
26.7k
    const unsigned char *plist;
1387
26.7k
    size_t plistlen;
1388
1389
26.7k
    if (!using_ecc)
1390
23.4k
        return EXT_RETURN_NOT_SENT;
1391
1392
3.36k
    tls1_get_formatlist(s, &plist, &plistlen);
1393
3.36k
    if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_ec_point_formats)
1394
3.36k
        || !WPACKET_start_sub_packet_u16(pkt)
1395
3.36k
        || !WPACKET_sub_memcpy_u8(pkt, plist, plistlen)
1396
3.36k
        || !WPACKET_close(pkt)) {
1397
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1398
0
        return EXT_RETURN_FAIL;
1399
0
    }
1400
1401
3.36k
    return EXT_RETURN_SENT;
1402
3.36k
}
1403
1404
EXT_RETURN tls_construct_stoc_supported_groups(SSL_CONNECTION *s, WPACKET *pkt,
1405
    unsigned int context, X509 *x,
1406
    size_t chainidx)
1407
29.7k
{
1408
29.7k
    const uint16_t *groups;
1409
29.7k
    size_t numgroups, i, first = 1;
1410
29.7k
    int version;
1411
1412
    /* s->s3.group_id is non zero if we accepted a key_share */
1413
29.7k
    if (s->s3.group_id == 0)
1414
26.7k
        return EXT_RETURN_NOT_SENT;
1415
1416
    /* Get our list of supported groups */
1417
2.95k
    tls1_get_supported_groups(s, &groups, &numgroups);
1418
2.95k
    if (numgroups == 0) {
1419
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1420
0
        return EXT_RETURN_FAIL;
1421
0
    }
1422
1423
    /* Copy group ID if supported */
1424
2.95k
    version = SSL_version(SSL_CONNECTION_GET_SSL(s));
1425
17.0k
    for (i = 0; i < numgroups; i++) {
1426
15.5k
        uint16_t group = groups[i];
1427
1428
15.5k
        if (tls_valid_group(s, group, version, version, 0, NULL)
1429
15.5k
            && tls_group_allowed(s, group, SSL_SECOP_CURVE_SUPPORTED)) {
1430
15.5k
            if (first) {
1431
                /*
1432
                 * Check if the client is already using our preferred group. If
1433
                 * so we don't need to add this extension
1434
                 */
1435
2.95k
                if (s->s3.group_id == group)
1436
1.42k
                    return EXT_RETURN_NOT_SENT;
1437
1438
                /* Add extension header */
1439
1.53k
                if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_supported_groups)
1440
                    /* Sub-packet for supported_groups extension */
1441
1.53k
                    || !WPACKET_start_sub_packet_u16(pkt)
1442
1.53k
                    || !WPACKET_start_sub_packet_u16(pkt)) {
1443
0
                    SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1444
0
                    return EXT_RETURN_FAIL;
1445
0
                }
1446
1447
1.53k
                first = 0;
1448
1.53k
            }
1449
14.0k
            if (!WPACKET_put_bytes_u16(pkt, group)) {
1450
0
                SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1451
0
                return EXT_RETURN_FAIL;
1452
0
            }
1453
14.0k
        }
1454
15.5k
    }
1455
1456
1.53k
    if (!WPACKET_close(pkt) || !WPACKET_close(pkt)) {
1457
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1458
0
        return EXT_RETURN_FAIL;
1459
0
    }
1460
1461
1.53k
    return EXT_RETURN_SENT;
1462
1.53k
}
1463
1464
EXT_RETURN tls_construct_stoc_session_ticket(SSL_CONNECTION *s, WPACKET *pkt,
1465
    unsigned int context, X509 *x,
1466
    size_t chainidx)
1467
26.7k
{
1468
26.7k
    if (!s->ext.ticket_expected || !tls_use_ticket(s)) {
1469
21.8k
        s->ext.ticket_expected = 0;
1470
21.8k
        return EXT_RETURN_NOT_SENT;
1471
21.8k
    }
1472
1473
4.89k
    if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_session_ticket)
1474
4.89k
        || !WPACKET_put_bytes_u16(pkt, 0)) {
1475
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1476
0
        return EXT_RETURN_FAIL;
1477
0
    }
1478
1479
4.89k
    return EXT_RETURN_SENT;
1480
4.89k
}
1481
1482
#ifndef OPENSSL_NO_OCSP
1483
EXT_RETURN tls_construct_stoc_status_request(SSL_CONNECTION *s, WPACKET *pkt,
1484
    unsigned int context, X509 *x,
1485
    size_t chainidx)
1486
18.7k
{
1487
    /* We don't currently support this extension inside a CertificateRequest */
1488
18.7k
    if (context == SSL_EXT_TLS1_3_CERTIFICATE_REQUEST)
1489
0
        return EXT_RETURN_NOT_SENT;
1490
1491
18.7k
    if (!s->ext.status_expected)
1492
18.7k
        return EXT_RETURN_NOT_SENT;
1493
1494
0
    if (SSL_CONNECTION_IS_TLS13(s) && chainidx != 0)
1495
0
        return EXT_RETURN_NOT_SENT;
1496
1497
0
    if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_status_request)
1498
0
        || !WPACKET_start_sub_packet_u16(pkt)) {
1499
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1500
0
        return EXT_RETURN_FAIL;
1501
0
    }
1502
1503
    /*
1504
     * In TLSv1.3 we include the certificate status itself. In <= TLSv1.2 we
1505
     * send back an empty extension, with the certificate status appearing as a
1506
     * separate message
1507
     */
1508
0
    if (SSL_CONNECTION_IS_TLS13(s) && !tls_construct_cert_status_body(s, pkt)) {
1509
        /* SSLfatal() already called */
1510
0
        return EXT_RETURN_FAIL;
1511
0
    }
1512
0
    if (!WPACKET_close(pkt)) {
1513
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1514
0
        return EXT_RETURN_FAIL;
1515
0
    }
1516
1517
0
    return EXT_RETURN_SENT;
1518
0
}
1519
#endif
1520
1521
#ifndef OPENSSL_NO_NEXTPROTONEG
1522
EXT_RETURN tls_construct_stoc_next_proto_neg(SSL_CONNECTION *s, WPACKET *pkt,
1523
    unsigned int context, X509 *x,
1524
    size_t chainidx)
1525
26.7k
{
1526
26.7k
    const unsigned char *npa;
1527
26.7k
    unsigned int npalen;
1528
26.7k
    int ret;
1529
26.7k
    int npn_seen = s->s3.npn_seen;
1530
26.7k
    SSL_CTX *sctx = SSL_CONNECTION_GET_CTX(s);
1531
1532
26.7k
    s->s3.npn_seen = 0;
1533
26.7k
    if (!npn_seen || sctx->ext.npn_advertised_cb == NULL)
1534
26.7k
        return EXT_RETURN_NOT_SENT;
1535
1536
0
    ret = sctx->ext.npn_advertised_cb(SSL_CONNECTION_GET_USER_SSL(s), &npa,
1537
0
        &npalen, sctx->ext.npn_advertised_cb_arg);
1538
0
    if (ret == SSL_TLSEXT_ERR_OK) {
1539
0
        if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_next_proto_neg)
1540
0
            || !WPACKET_sub_memcpy_u16(pkt, npa, npalen)) {
1541
0
            SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1542
0
            return EXT_RETURN_FAIL;
1543
0
        }
1544
0
        s->s3.npn_seen = 1;
1545
0
        return EXT_RETURN_SENT;
1546
0
    }
1547
1548
0
    return EXT_RETURN_NOT_SENT;
1549
0
}
1550
#endif
1551
1552
EXT_RETURN tls_construct_stoc_alpn(SSL_CONNECTION *s, WPACKET *pkt, unsigned int context,
1553
    X509 *x, size_t chainidx)
1554
29.7k
{
1555
29.7k
    if (s->s3.alpn_selected == NULL)
1556
29.7k
        return EXT_RETURN_NOT_SENT;
1557
1558
0
    if (!WPACKET_put_bytes_u16(pkt,
1559
0
            TLSEXT_TYPE_application_layer_protocol_negotiation)
1560
0
        || !WPACKET_start_sub_packet_u16(pkt)
1561
0
        || !WPACKET_start_sub_packet_u16(pkt)
1562
0
        || !WPACKET_sub_memcpy_u8(pkt, s->s3.alpn_selected,
1563
0
            s->s3.alpn_selected_len)
1564
0
        || !WPACKET_close(pkt)
1565
0
        || !WPACKET_close(pkt)) {
1566
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1567
0
        return EXT_RETURN_FAIL;
1568
0
    }
1569
1570
0
    return EXT_RETURN_SENT;
1571
0
}
1572
1573
#ifndef OPENSSL_NO_SRTP
1574
EXT_RETURN tls_construct_stoc_use_srtp(SSL_CONNECTION *s, WPACKET *pkt,
1575
    unsigned int context, X509 *x,
1576
    size_t chainidx)
1577
29.7k
{
1578
29.7k
    if (s->srtp_profile == NULL)
1579
29.7k
        return EXT_RETURN_NOT_SENT;
1580
1581
0
    if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_use_srtp)
1582
0
        || !WPACKET_start_sub_packet_u16(pkt)
1583
0
        || !WPACKET_put_bytes_u16(pkt, 2)
1584
0
        || !WPACKET_put_bytes_u16(pkt, s->srtp_profile->id)
1585
0
        || !WPACKET_put_bytes_u8(pkt, 0)
1586
0
        || !WPACKET_close(pkt)) {
1587
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1588
0
        return EXT_RETURN_FAIL;
1589
0
    }
1590
1591
0
    return EXT_RETURN_SENT;
1592
0
}
1593
#endif
1594
1595
EXT_RETURN tls_construct_stoc_etm(SSL_CONNECTION *s, WPACKET *pkt,
1596
    unsigned int context,
1597
    X509 *x, size_t chainidx)
1598
26.7k
{
1599
26.7k
    if (!s->ext.use_etm)
1600
25.3k
        return EXT_RETURN_NOT_SENT;
1601
1602
    /*
1603
     * Don't use encrypt_then_mac if AEAD or RC4 might want to disable
1604
     * for other cases too.
1605
     */
1606
1.45k
    if (s->s3.tmp.new_cipher->algorithm_mac == SSL_AEAD
1607
1.16k
        || s->s3.tmp.new_cipher->algorithm_enc == SSL_RC4
1608
1.16k
        || s->s3.tmp.new_cipher->algorithm_enc == SSL_eGOST2814789CNT
1609
1.16k
        || s->s3.tmp.new_cipher->algorithm_enc == SSL_eGOST2814789CNT12
1610
1.16k
        || s->s3.tmp.new_cipher->algorithm_enc == SSL_MAGMA
1611
1.16k
        || s->s3.tmp.new_cipher->algorithm_enc == SSL_KUZNYECHIK) {
1612
285
        s->ext.use_etm = 0;
1613
285
        return EXT_RETURN_NOT_SENT;
1614
285
    }
1615
1616
1.16k
    if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_encrypt_then_mac)
1617
1.16k
        || !WPACKET_put_bytes_u16(pkt, 0)) {
1618
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1619
0
        return EXT_RETURN_FAIL;
1620
0
    }
1621
1622
1.16k
    return EXT_RETURN_SENT;
1623
1.16k
}
1624
1625
EXT_RETURN tls_construct_stoc_ems(SSL_CONNECTION *s, WPACKET *pkt,
1626
    unsigned int context,
1627
    X509 *x, size_t chainidx)
1628
26.7k
{
1629
26.7k
    if ((s->s3.flags & TLS1_FLAGS_RECEIVED_EXTMS) == 0)
1630
22.6k
        return EXT_RETURN_NOT_SENT;
1631
1632
4.09k
    if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_extended_master_secret)
1633
4.09k
        || !WPACKET_put_bytes_u16(pkt, 0)) {
1634
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1635
0
        return EXT_RETURN_FAIL;
1636
0
    }
1637
1638
4.09k
    return EXT_RETURN_SENT;
1639
4.09k
}
1640
1641
EXT_RETURN tls_construct_stoc_supported_versions(SSL_CONNECTION *s, WPACKET *pkt,
1642
    unsigned int context, X509 *x,
1643
    size_t chainidx)
1644
3.71k
{
1645
3.71k
    if (!ossl_assert(SSL_CONNECTION_IS_TLS13(s))) {
1646
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1647
0
        return EXT_RETURN_FAIL;
1648
0
    }
1649
1650
3.71k
    if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_supported_versions)
1651
3.71k
        || !WPACKET_start_sub_packet_u16(pkt)
1652
3.71k
        || !WPACKET_put_bytes_u16(pkt, s->version)
1653
3.71k
        || !WPACKET_close(pkt)) {
1654
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1655
0
        return EXT_RETURN_FAIL;
1656
0
    }
1657
1658
3.71k
    return EXT_RETURN_SENT;
1659
3.71k
}
1660
1661
EXT_RETURN tls_construct_stoc_key_share(SSL_CONNECTION *s, WPACKET *pkt,
1662
    unsigned int context, X509 *x,
1663
    size_t chainidx)
1664
3.71k
{
1665
3.71k
#ifndef OPENSSL_NO_TLS1_3
1666
3.71k
    unsigned char *encodedPoint;
1667
3.71k
    size_t encoded_pt_len = 0;
1668
3.71k
    EVP_PKEY *ckey = s->s3.peer_tmp, *skey = NULL;
1669
3.71k
    const TLS_GROUP_INFO *ginf = NULL;
1670
1671
3.71k
    if (s->hello_retry_request == SSL_HRR_PENDING) {
1672
730
        if (ckey != NULL) {
1673
            /* Original key_share was acceptable so don't ask for another one */
1674
0
            return EXT_RETURN_NOT_SENT;
1675
0
        }
1676
730
        if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_key_share)
1677
730
            || !WPACKET_start_sub_packet_u16(pkt)
1678
730
            || !WPACKET_put_bytes_u16(pkt, s->s3.group_id)
1679
730
            || !WPACKET_close(pkt)) {
1680
0
            SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1681
0
            return EXT_RETURN_FAIL;
1682
0
        }
1683
1684
730
        return EXT_RETURN_SENT;
1685
730
    }
1686
1687
2.98k
    if (ckey == NULL) {
1688
        /* No key_share received from client - must be resuming */
1689
0
        if (!s->hit || !tls13_generate_handshake_secret(s, NULL, 0)) {
1690
0
            SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1691
0
            return EXT_RETURN_FAIL;
1692
0
        }
1693
0
        return EXT_RETURN_NOT_SENT;
1694
0
    }
1695
1696
2.98k
    if (s->hit && (s->ext.psk_kex_mode & TLSEXT_KEX_MODE_FLAG_KE_DHE) == 0) {
1697
        /*
1698
         * PSK ('hit') and explicitly not doing DHE. If the client sent the
1699
         * DHE option, we take it by default, except if non-DHE would be
1700
         * preferred by config, but this case would have been handled in
1701
         * tls_parse_ctos_psk_kex_modes().
1702
         */
1703
0
        return EXT_RETURN_NOT_SENT;
1704
0
    }
1705
1706
2.98k
    if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_key_share)
1707
2.98k
        || !WPACKET_start_sub_packet_u16(pkt)
1708
2.98k
        || !WPACKET_put_bytes_u16(pkt, s->s3.group_id)) {
1709
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1710
0
        return EXT_RETURN_FAIL;
1711
0
    }
1712
1713
2.98k
    if ((ginf = tls1_group_id_lookup(SSL_CONNECTION_GET_CTX(s),
1714
2.98k
             s->s3.group_id))
1715
2.98k
        == NULL) {
1716
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1717
0
        return EXT_RETURN_FAIL;
1718
0
    }
1719
1720
2.98k
    if (!ginf->is_kem) {
1721
        /* Regular KEX */
1722
2.96k
        skey = ssl_generate_pkey(s, ckey);
1723
2.96k
        if (skey == NULL) {
1724
0
            SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_SSL_LIB);
1725
0
            return EXT_RETURN_FAIL;
1726
0
        }
1727
1728
        /* Generate encoding of server key */
1729
2.96k
        encoded_pt_len = EVP_PKEY_get1_encoded_public_key(skey, &encodedPoint);
1730
2.96k
        if (encoded_pt_len == 0) {
1731
0
            SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_EC_LIB);
1732
0
            EVP_PKEY_free(skey);
1733
0
            return EXT_RETURN_FAIL;
1734
0
        }
1735
1736
2.96k
        if (!WPACKET_sub_memcpy_u16(pkt, encodedPoint, encoded_pt_len)
1737
2.96k
            || !WPACKET_close(pkt)) {
1738
0
            SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1739
0
            EVP_PKEY_free(skey);
1740
0
            OPENSSL_free(encodedPoint);
1741
0
            return EXT_RETURN_FAIL;
1742
0
        }
1743
2.96k
        OPENSSL_free(encodedPoint);
1744
1745
        /*
1746
         * This causes the crypto state to be updated based on the derived keys
1747
         */
1748
2.96k
        s->s3.tmp.pkey = skey;
1749
2.96k
        if (ssl_derive(s, skey, ckey, 1) == 0) {
1750
            /* SSLfatal() already called */
1751
22
            return EXT_RETURN_FAIL;
1752
22
        }
1753
2.96k
    } else {
1754
        /* KEM mode */
1755
24
        unsigned char *ct = NULL;
1756
24
        size_t ctlen = 0;
1757
1758
        /*
1759
         * This does not update the crypto state.
1760
         *
1761
         * The generated pms is stored in `s->s3.tmp.pms` to be later used via
1762
         * ssl_gensecret().
1763
         */
1764
24
        if (ssl_encapsulate(s, ckey, &ct, &ctlen, 0) == 0) {
1765
            /* SSLfatal() already called */
1766
4
            return EXT_RETURN_FAIL;
1767
4
        }
1768
1769
20
        if (ctlen == 0) {
1770
0
            SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1771
0
            OPENSSL_free(ct);
1772
0
            return EXT_RETURN_FAIL;
1773
0
        }
1774
1775
20
        if (!WPACKET_sub_memcpy_u16(pkt, ct, ctlen)
1776
20
            || !WPACKET_close(pkt)) {
1777
0
            SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1778
0
            OPENSSL_free(ct);
1779
0
            return EXT_RETURN_FAIL;
1780
0
        }
1781
20
        OPENSSL_free(ct);
1782
1783
        /*
1784
         * This causes the crypto state to be updated based on the generated pms
1785
         */
1786
20
        if (ssl_gensecret(s, s->s3.tmp.pms, s->s3.tmp.pmslen) == 0) {
1787
            /* SSLfatal() already called */
1788
0
            return EXT_RETURN_FAIL;
1789
0
        }
1790
20
    }
1791
2.95k
    s->s3.did_kex = 1;
1792
2.95k
    return EXT_RETURN_SENT;
1793
#else
1794
    return EXT_RETURN_FAIL;
1795
#endif
1796
2.98k
}
1797
1798
EXT_RETURN tls_construct_stoc_cookie(SSL_CONNECTION *s, WPACKET *pkt,
1799
    unsigned int context,
1800
    X509 *x, size_t chainidx)
1801
730
{
1802
730
#ifndef OPENSSL_NO_TLS1_3
1803
730
    unsigned char *hashval1, *hashval2, *appcookie1, *appcookie2, *cookie;
1804
730
    unsigned char *hmac, *hmac2;
1805
730
    size_t startlen, ciphlen, totcookielen, hashlen, hmaclen, appcookielen;
1806
730
    EVP_MD_CTX *hctx;
1807
730
    EVP_PKEY *pkey;
1808
730
    int ret = EXT_RETURN_FAIL;
1809
730
    SSL_CTX *sctx = SSL_CONNECTION_GET_CTX(s);
1810
730
    SSL *ssl = SSL_CONNECTION_GET_SSL(s);
1811
730
    SSL *ussl = SSL_CONNECTION_GET_USER_SSL(s);
1812
1813
730
    if ((s->s3.flags & TLS1_FLAGS_STATELESS) == 0)
1814
730
        return EXT_RETURN_NOT_SENT;
1815
1816
0
    if (sctx->gen_stateless_cookie_cb == NULL) {
1817
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, SSL_R_NO_COOKIE_CALLBACK_SET);
1818
0
        return EXT_RETURN_FAIL;
1819
0
    }
1820
1821
0
    if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_cookie)
1822
0
        || !WPACKET_start_sub_packet_u16(pkt)
1823
0
        || !WPACKET_start_sub_packet_u16(pkt)
1824
0
        || !WPACKET_get_total_written(pkt, &startlen)
1825
0
        || !WPACKET_reserve_bytes(pkt, MAX_COOKIE_SIZE, &cookie)
1826
0
        || !WPACKET_put_bytes_u16(pkt, COOKIE_STATE_FORMAT_VERSION)
1827
0
        || !WPACKET_put_bytes_u16(pkt, TLS1_3_VERSION)
1828
0
        || !WPACKET_put_bytes_u16(pkt, s->s3.group_id)
1829
0
        || !ssl->method->put_cipher_by_char(s->s3.tmp.new_cipher, pkt,
1830
0
            &ciphlen)
1831
        /* Is there a key_share extension present in this HRR? */
1832
0
        || !WPACKET_put_bytes_u8(pkt, s->s3.peer_tmp == NULL)
1833
0
        || !WPACKET_put_bytes_u64(pkt, time(NULL))
1834
0
        || !WPACKET_start_sub_packet_u16(pkt)
1835
0
        || !WPACKET_reserve_bytes(pkt, EVP_MAX_MD_SIZE, &hashval1)) {
1836
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1837
0
        return EXT_RETURN_FAIL;
1838
0
    }
1839
1840
    /*
1841
     * Get the hash of the initial ClientHello. ssl_handshake_hash() operates
1842
     * on raw buffers, so we first reserve sufficient bytes (above) and then
1843
     * subsequently allocate them (below)
1844
     */
1845
0
    if (!ssl3_digest_cached_records(s, 0)
1846
0
        || !ssl_handshake_hash(s, hashval1, EVP_MAX_MD_SIZE, &hashlen)) {
1847
        /* SSLfatal() already called */
1848
0
        return EXT_RETURN_FAIL;
1849
0
    }
1850
1851
0
    if (!WPACKET_allocate_bytes(pkt, hashlen, &hashval2)
1852
0
        || !ossl_assert(hashval1 == hashval2)
1853
0
        || !WPACKET_close(pkt)
1854
0
        || !WPACKET_start_sub_packet_u8(pkt)
1855
0
        || !WPACKET_reserve_bytes(pkt, SSL_COOKIE_LENGTH, &appcookie1)) {
1856
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1857
0
        return EXT_RETURN_FAIL;
1858
0
    }
1859
1860
    /* Generate the application cookie */
1861
0
    if (sctx->gen_stateless_cookie_cb(ussl, appcookie1,
1862
0
            &appcookielen)
1863
0
        == 0) {
1864
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, SSL_R_COOKIE_GEN_CALLBACK_FAILURE);
1865
0
        return EXT_RETURN_FAIL;
1866
0
    }
1867
1868
0
    if (!WPACKET_allocate_bytes(pkt, appcookielen, &appcookie2)
1869
0
        || !ossl_assert(appcookie1 == appcookie2)
1870
0
        || !WPACKET_close(pkt)
1871
0
        || !WPACKET_get_total_written(pkt, &totcookielen)
1872
0
        || !WPACKET_reserve_bytes(pkt, SHA256_DIGEST_LENGTH, &hmac)) {
1873
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1874
0
        return EXT_RETURN_FAIL;
1875
0
    }
1876
0
    hmaclen = SHA256_DIGEST_LENGTH;
1877
1878
0
    totcookielen -= startlen;
1879
0
    if (!ossl_assert(totcookielen <= MAX_COOKIE_SIZE - SHA256_DIGEST_LENGTH)) {
1880
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1881
0
        return EXT_RETURN_FAIL;
1882
0
    }
1883
1884
    /* HMAC the cookie */
1885
0
    hctx = EVP_MD_CTX_create();
1886
0
    pkey = EVP_PKEY_new_raw_private_key_ex(sctx->libctx, "HMAC",
1887
0
        sctx->propq,
1888
0
        s->session_ctx->ext.cookie_hmac_key,
1889
0
        sizeof(s->session_ctx->ext.cookie_hmac_key));
1890
0
    if (hctx == NULL || pkey == NULL) {
1891
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_EVP_LIB);
1892
0
        goto err;
1893
0
    }
1894
1895
0
    if (EVP_DigestSignInit_ex(hctx, NULL, "SHA2-256", sctx->libctx,
1896
0
            sctx->propq, pkey, NULL)
1897
0
            <= 0
1898
0
        || EVP_DigestSign(hctx, hmac, &hmaclen, cookie,
1899
0
               totcookielen)
1900
0
            <= 0) {
1901
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1902
0
        goto err;
1903
0
    }
1904
1905
0
    if (!ossl_assert(totcookielen + hmaclen <= MAX_COOKIE_SIZE)) {
1906
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1907
0
        goto err;
1908
0
    }
1909
1910
0
    if (!WPACKET_allocate_bytes(pkt, hmaclen, &hmac2)
1911
0
        || !ossl_assert(hmac == hmac2)
1912
0
        || !ossl_assert(cookie == hmac - totcookielen)
1913
0
        || !WPACKET_close(pkt)
1914
0
        || !WPACKET_close(pkt)) {
1915
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1916
0
        goto err;
1917
0
    }
1918
1919
0
    ret = EXT_RETURN_SENT;
1920
1921
0
err:
1922
0
    EVP_MD_CTX_free(hctx);
1923
0
    EVP_PKEY_free(pkey);
1924
0
    return ret;
1925
#else
1926
    return EXT_RETURN_FAIL;
1927
#endif
1928
0
}
1929
1930
EXT_RETURN tls_construct_stoc_cryptopro_bug(SSL_CONNECTION *s, WPACKET *pkt,
1931
    unsigned int context, X509 *x,
1932
    size_t chainidx)
1933
26.7k
{
1934
26.7k
    const unsigned char cryptopro_ext[36] = {
1935
26.7k
        0xfd, 0xe8, /* 65000 */
1936
26.7k
        0x00, 0x20, /* 32 bytes length */
1937
26.7k
        0x30, 0x1e, 0x30, 0x08, 0x06, 0x06, 0x2a, 0x85,
1938
26.7k
        0x03, 0x02, 0x02, 0x09, 0x30, 0x08, 0x06, 0x06,
1939
26.7k
        0x2a, 0x85, 0x03, 0x02, 0x02, 0x16, 0x30, 0x08,
1940
26.7k
        0x06, 0x06, 0x2a, 0x85, 0x03, 0x02, 0x02, 0x17
1941
26.7k
    };
1942
1943
26.7k
    if (((s->s3.tmp.new_cipher->id & 0xFFFF) != 0x80
1944
26.7k
            && (s->s3.tmp.new_cipher->id & 0xFFFF) != 0x81)
1945
0
        || (SSL_get_options(SSL_CONNECTION_GET_SSL(s))
1946
0
               & SSL_OP_CRYPTOPRO_TLSEXT_BUG)
1947
0
            == 0)
1948
26.7k
        return EXT_RETURN_NOT_SENT;
1949
1950
0
    if (!WPACKET_memcpy(pkt, cryptopro_ext, sizeof(cryptopro_ext))) {
1951
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1952
0
        return EXT_RETURN_FAIL;
1953
0
    }
1954
1955
0
    return EXT_RETURN_SENT;
1956
0
}
1957
1958
EXT_RETURN tls_construct_stoc_early_data(SSL_CONNECTION *s, WPACKET *pkt,
1959
    unsigned int context, X509 *x,
1960
    size_t chainidx)
1961
2.95k
{
1962
2.95k
    if (context == SSL_EXT_TLS1_3_NEW_SESSION_TICKET) {
1963
0
        if (s->max_early_data == 0)
1964
0
            return EXT_RETURN_NOT_SENT;
1965
1966
0
        if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_early_data)
1967
0
            || !WPACKET_start_sub_packet_u16(pkt)
1968
0
            || !WPACKET_put_bytes_u32(pkt, s->max_early_data)
1969
0
            || !WPACKET_close(pkt)) {
1970
0
            SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1971
0
            return EXT_RETURN_FAIL;
1972
0
        }
1973
1974
0
        return EXT_RETURN_SENT;
1975
0
    }
1976
1977
2.95k
    if (s->ext.early_data != SSL_EARLY_DATA_ACCEPTED)
1978
2.95k
        return EXT_RETURN_NOT_SENT;
1979
1980
0
    if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_early_data)
1981
0
        || !WPACKET_start_sub_packet_u16(pkt)
1982
0
        || !WPACKET_close(pkt)) {
1983
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
1984
0
        return EXT_RETURN_FAIL;
1985
0
    }
1986
1987
0
    return EXT_RETURN_SENT;
1988
0
}
1989
1990
EXT_RETURN tls_construct_stoc_psk(SSL_CONNECTION *s, WPACKET *pkt,
1991
    unsigned int context,
1992
    X509 *x, size_t chainidx)
1993
2.95k
{
1994
2.95k
    if (!s->hit)
1995
2.95k
        return EXT_RETURN_NOT_SENT;
1996
1997
0
    if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_psk)
1998
0
        || !WPACKET_start_sub_packet_u16(pkt)
1999
0
        || !WPACKET_put_bytes_u16(pkt, s->ext.tick_identity)
2000
0
        || !WPACKET_close(pkt)) {
2001
0
        SSLfatal(s, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
2002
0
        return EXT_RETURN_FAIL;
2003
0
    }
2004
2005
0
    return EXT_RETURN_SENT;
2006
0
}
2007
2008
EXT_RETURN tls_construct_stoc_client_cert_type(SSL_CONNECTION *sc, WPACKET *pkt,
2009
    unsigned int context,
2010
    X509 *x, size_t chainidx)
2011
27.1k
{
2012
27.1k
    if (sc->ext.client_cert_type_ctos == OSSL_CERT_TYPE_CTOS_ERROR
2013
0
        && (send_certificate_request(sc)
2014
0
            || sc->post_handshake_auth == SSL_PHA_EXT_RECEIVED)) {
2015
        /* Did not receive an acceptable cert type - and doing client auth */
2016
0
        SSLfatal(sc, SSL_AD_UNSUPPORTED_CERTIFICATE, SSL_R_BAD_EXTENSION);
2017
0
        return EXT_RETURN_FAIL;
2018
0
    }
2019
2020
27.1k
    if (sc->ext.client_cert_type == TLSEXT_cert_type_x509) {
2021
27.1k
        sc->ext.client_cert_type_ctos = OSSL_CERT_TYPE_CTOS_NONE;
2022
27.1k
        return EXT_RETURN_NOT_SENT;
2023
27.1k
    }
2024
2025
    /*
2026
     * Note: only supposed to send this if we are going to do a cert request,
2027
     * but TLSv1.3 could do a PHA request if the client supports it
2028
     */
2029
0
    if ((!send_certificate_request(sc) && sc->post_handshake_auth != SSL_PHA_EXT_RECEIVED)
2030
0
        || sc->ext.client_cert_type_ctos != OSSL_CERT_TYPE_CTOS_GOOD
2031
0
        || sc->client_cert_type == NULL) {
2032
        /* if we don't send it, reset to TLSEXT_cert_type_x509 */
2033
0
        sc->ext.client_cert_type_ctos = OSSL_CERT_TYPE_CTOS_NONE;
2034
0
        sc->ext.client_cert_type = TLSEXT_cert_type_x509;
2035
0
        return EXT_RETURN_NOT_SENT;
2036
0
    }
2037
2038
0
    if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_client_cert_type)
2039
0
        || !WPACKET_start_sub_packet_u16(pkt)
2040
0
        || !WPACKET_put_bytes_u8(pkt, sc->ext.client_cert_type)
2041
0
        || !WPACKET_close(pkt)) {
2042
0
        SSLfatal(sc, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
2043
0
        return EXT_RETURN_FAIL;
2044
0
    }
2045
0
    return EXT_RETURN_SENT;
2046
0
}
2047
2048
/* One of |pref|, |other| is configured and the values are sanitized */
2049
static int reconcile_cert_type(const unsigned char *pref, size_t pref_len,
2050
    const unsigned char *other, size_t other_len,
2051
    uint8_t *chosen_cert_type)
2052
0
{
2053
0
    size_t i;
2054
2055
0
    for (i = 0; i < pref_len; i++) {
2056
0
        if (memchr(other, pref[i], other_len) != NULL) {
2057
0
            *chosen_cert_type = pref[i];
2058
0
            return OSSL_CERT_TYPE_CTOS_GOOD;
2059
0
        }
2060
0
    }
2061
0
    return OSSL_CERT_TYPE_CTOS_ERROR;
2062
0
}
2063
2064
int tls_parse_ctos_client_cert_type(SSL_CONNECTION *sc, PACKET *pkt,
2065
    unsigned int context,
2066
    X509 *x, size_t chainidx)
2067
289
{
2068
289
    PACKET supported_cert_types;
2069
289
    const unsigned char *data;
2070
289
    size_t len;
2071
2072
    /* Ignore the extension */
2073
289
    if (sc->client_cert_type == NULL) {
2074
289
        sc->ext.client_cert_type_ctos = OSSL_CERT_TYPE_CTOS_NONE;
2075
289
        sc->ext.client_cert_type = TLSEXT_cert_type_x509;
2076
289
        return 1;
2077
289
    }
2078
2079
0
    if (!PACKET_as_length_prefixed_1(pkt, &supported_cert_types)) {
2080
0
        sc->ext.client_cert_type_ctos = OSSL_CERT_TYPE_CTOS_ERROR;
2081
0
        SSLfatal(sc, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
2082
0
        return 0;
2083
0
    }
2084
0
    if ((len = PACKET_remaining(&supported_cert_types)) == 0) {
2085
0
        sc->ext.client_cert_type_ctos = OSSL_CERT_TYPE_CTOS_ERROR;
2086
0
        SSLfatal(sc, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
2087
0
        return 0;
2088
0
    }
2089
0
    if (!PACKET_get_bytes(&supported_cert_types, &data, len)) {
2090
0
        sc->ext.client_cert_type_ctos = OSSL_CERT_TYPE_CTOS_ERROR;
2091
0
        SSLfatal(sc, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
2092
0
        return 0;
2093
0
    }
2094
    /* client_cert_type: client (peer) has priority */
2095
0
    sc->ext.client_cert_type_ctos = reconcile_cert_type(data, len,
2096
0
        sc->client_cert_type, sc->client_cert_type_len,
2097
0
        &sc->ext.client_cert_type);
2098
2099
    /* Ignore the error until sending - so we can check cert auth*/
2100
0
    return 1;
2101
0
}
2102
2103
EXT_RETURN tls_construct_stoc_server_cert_type(SSL_CONNECTION *sc, WPACKET *pkt,
2104
    unsigned int context,
2105
    X509 *x, size_t chainidx)
2106
27.1k
{
2107
27.1k
    if (sc->ext.server_cert_type == TLSEXT_cert_type_x509) {
2108
27.1k
        sc->ext.server_cert_type_ctos = OSSL_CERT_TYPE_CTOS_NONE;
2109
27.1k
        return EXT_RETURN_NOT_SENT;
2110
27.1k
    }
2111
0
    if (sc->ext.server_cert_type_ctos != OSSL_CERT_TYPE_CTOS_GOOD
2112
0
        || sc->server_cert_type == NULL) {
2113
        /* if we don't send it, reset to TLSEXT_cert_type_x509 */
2114
0
        sc->ext.server_cert_type_ctos = OSSL_CERT_TYPE_CTOS_NONE;
2115
0
        sc->ext.server_cert_type = TLSEXT_cert_type_x509;
2116
0
        return EXT_RETURN_NOT_SENT;
2117
0
    }
2118
2119
0
    if (!WPACKET_put_bytes_u16(pkt, TLSEXT_TYPE_server_cert_type)
2120
0
        || !WPACKET_start_sub_packet_u16(pkt)
2121
0
        || !WPACKET_put_bytes_u8(pkt, sc->ext.server_cert_type)
2122
0
        || !WPACKET_close(pkt)) {
2123
0
        SSLfatal(sc, SSL_AD_INTERNAL_ERROR, ERR_R_INTERNAL_ERROR);
2124
0
        return EXT_RETURN_FAIL;
2125
0
    }
2126
0
    return EXT_RETURN_SENT;
2127
0
}
2128
2129
int tls_parse_ctos_server_cert_type(SSL_CONNECTION *sc, PACKET *pkt,
2130
    unsigned int context,
2131
    X509 *x, size_t chainidx)
2132
301
{
2133
301
    PACKET supported_cert_types;
2134
301
    const unsigned char *data;
2135
301
    size_t len;
2136
2137
    /* Ignore the extension */
2138
301
    if (sc->server_cert_type == NULL) {
2139
301
        sc->ext.server_cert_type_ctos = OSSL_CERT_TYPE_CTOS_NONE;
2140
301
        sc->ext.server_cert_type = TLSEXT_cert_type_x509;
2141
301
        return 1;
2142
301
    }
2143
2144
0
    if (!PACKET_as_length_prefixed_1(pkt, &supported_cert_types)) {
2145
0
        SSLfatal(sc, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
2146
0
        return 0;
2147
0
    }
2148
2149
0
    if ((len = PACKET_remaining(&supported_cert_types)) == 0) {
2150
0
        SSLfatal(sc, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
2151
0
        return 0;
2152
0
    }
2153
0
    if (!PACKET_get_bytes(&supported_cert_types, &data, len)) {
2154
0
        SSLfatal(sc, SSL_AD_DECODE_ERROR, SSL_R_BAD_EXTENSION);
2155
0
        return 0;
2156
0
    }
2157
    /* server_cert_type: server (this) has priority */
2158
0
    sc->ext.server_cert_type_ctos = reconcile_cert_type(sc->server_cert_type, sc->server_cert_type_len,
2159
0
        data, len,
2160
0
        &sc->ext.server_cert_type);
2161
0
    if (sc->ext.server_cert_type_ctos == OSSL_CERT_TYPE_CTOS_GOOD)
2162
0
        return 1;
2163
2164
    /* Did not receive an acceptable cert type */
2165
0
    SSLfatal(sc, SSL_AD_UNSUPPORTED_CERTIFICATE, SSL_R_BAD_EXTENSION);
2166
0
    return 0;
2167
0
}