Coverage Report

Created: 2026-05-24 07:14

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