Branch data Line data Source code
1 : : /* 2 : : * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. 3 : : * 4 : : * Licensed under the Apache License, Version 2.0 (the "License"). 5 : : * You may not use this file except in compliance with the License. 6 : : * A copy of the License is located at 7 : : * 8 : : * http://aws.amazon.com/apache2.0 9 : : * 10 : : * or in the "license" file accompanying this file. This file is distributed 11 : : * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either 12 : : * express or implied. See the License for the specific language governing 13 : : * permissions and limitations under the License. 14 : : */ 15 : : 16 : : #include <stdint.h> 17 : : #include <sys/param.h> 18 : : 19 : : #include "tls/extensions/s2n_ems.h" 20 : : #include "tls/s2n_tls.h" 21 : : #include "utils/s2n_safety.h" 22 : : 23 : : static int s2n_client_ems_recv(struct s2n_connection *conn, struct s2n_stuffer *extension); 24 : : static bool s2n_client_ems_should_send(struct s2n_connection *conn); 25 : : 26 : : /** 27 : : *= https://www.rfc-editor.org/rfc/rfc7627#section-5.1 28 : : *# 29 : : *# This document defines a new TLS extension, "extended_master_secret" 30 : : *# (with extension type 0x0017), which is used to signal both client and 31 : : *# server to use the extended master secret computation. The 32 : : *# "extension_data" field of this extension is empty. Thus, the entire 33 : : *# encoding of the extension is 00 17 00 00 (in hexadecimal.) 34 : : **/ 35 : : const s2n_extension_type s2n_client_ems_extension = { 36 : : .iana_value = TLS_EXTENSION_EMS, 37 : : .is_response = false, 38 : : .send = s2n_extension_send_noop, 39 : : .recv = s2n_client_ems_recv, 40 : : .should_send = s2n_client_ems_should_send, 41 : : .if_missing = s2n_extension_noop_if_missing, 42 : : }; 43 : : 44 : : static int s2n_client_ems_recv(struct s2n_connection *conn, struct s2n_stuffer *extension) 45 : 7220 : { 46 [ - + ][ # # ]: 7220 : POSIX_ENSURE_REF(conn); 47 : : 48 : : /* Read nothing. The extension just needs to exist without data. */ 49 [ - + ][ # # ]: 7220 : POSIX_ENSURE(s2n_stuffer_data_available(extension) == 0, S2N_ERR_UNSUPPORTED_EXTENSION); 50 : 7220 : conn->ems_negotiated = true; 51 : : 52 : 7220 : return S2N_SUCCESS; 53 : 7220 : } 54 : : 55 : : /** 56 : : *= https://www.rfc-editor.org/rfc/rfc7627#section-5.3 57 : : *= type=exception 58 : : *# When offering an abbreviated handshake, the client MUST send the 59 : : *# "extended_master_secret" extension in its ClientHello. 60 : : * 61 : : * We added an exception here in order to prevent a drop in 62 : : * session resumption rates during deployment. Eventually clients 63 : : * will be forced to do a full handshake as sessions expire and pick up EMS at that point. 64 : : **/ 65 : : static bool s2n_client_ems_should_send(struct s2n_connection *conn) 66 : 7355 : { 67 : : /* Don't send this extension if the previous session did not negotiate EMS */ 68 [ + - ][ + + ]: 7355 : if (conn && conn->set_session && !conn->ems_negotiated) { [ + + ] 69 : 129 : return false; 70 : 7226 : } else { 71 : 7226 : return true; 72 : 7226 : } 73 : 7355 : }