Skip to content

Commit e07855f

Browse files
committed
Fix tests and logic for TLS 1.3
1 parent 8e583e2 commit e07855f

File tree

3 files changed

+39
-28
lines changed

3 files changed

+39
-28
lines changed

ext/openssl/tests/session_meta_capture_tlsv13.phpt

Lines changed: 14 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -8,30 +8,32 @@ if (OPENSSL_VERSION_NUMBER < 0x10101000) die("skip OpenSSL v1.1.1 required");
88
?>
99
--FILE--
1010
<?php
11+
$certFile = __DIR__ . DIRECTORY_SEPARATOR . 'session_meta_capture_tlsv13.pem.tmp';
12+
$cacertFile = __DIR__ . DIRECTORY_SEPARATOR . 'session_meta_capture_tlsv13-ca.pem.tmp';
13+
1114
$serverCode = <<<'CODE'
1215
$serverUri = "ssl://127.0.0.1:64321";
1316
$serverFlags = STREAM_SERVER_BIND | STREAM_SERVER_LISTEN;
1417
$serverCtx = stream_context_create(['ssl' => [
15-
'local_cert' => __DIR__ . '/bug54992.pem',
18+
'local_cert' => '%s',
1619
'crypto_method' => STREAM_CRYPTO_METHOD_TLSv1_3_SERVER,
1720
]]);
1821
1922
$server = stream_socket_server($serverUri, $errno, $errstr, $serverFlags, $serverCtx);
2023
phpt_notify();
2124
2225
@stream_socket_accept($server, 1);
23-
@stream_socket_accept($server, 1);
24-
@stream_socket_accept($server, 1);
25-
@stream_socket_accept($server, 1);
2626
CODE;
27+
$serverCode = sprintf($serverCode, $certFile);
2728

29+
$peerName = 'session_meta_capture_tlsv13';
2830
$clientCode = <<<'CODE'
2931
$serverUri = "ssl://127.0.0.1:64321";
3032
$clientFlags = STREAM_CLIENT_CONNECT;
3133
$clientCtx = stream_context_create(['ssl' => [
3234
'verify_peer' => true,
33-
'cafile' => __DIR__ . '/bug54992-ca.pem',
34-
'peer_name' => 'bug54992.local',
35+
'cafile' => '%s',
36+
'peer_name' => '%s',
3537
'capture_session_meta' => true,
3638
]]);
3739
@@ -42,6 +44,12 @@ $clientCode = <<<'CODE'
4244
$meta = stream_context_get_options($clientCtx)['ssl']['session_meta'];
4345
var_dump($meta['protocol']);
4446
CODE;
47+
$clientCode = sprintf($clientCode, $cacertFile, $peerName);
48+
49+
include 'CertificateGenerator.inc';
50+
$certificateGenerator = new CertificateGenerator();
51+
$certificateGenerator->saveCaCert($cacertFile);
52+
$certificateGenerator->saveNewCertAsFileWithKey($peerName, $certFile);
4553

4654
include 'ServerClientTestCase.inc';
4755
ServerClientTestCase::getInstance()->run($clientCode, $serverCode);

ext/openssl/tests/tlsv1.3_wrapper.phpt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -34,7 +34,7 @@ $clientCode = <<<'CODE'
3434
$client = stream_socket_client("tlsv1.3://127.0.0.1:64321", $errno, $errstr, 3, $flags, $ctx);
3535
var_dump($client);
3636
37-
$client = @stream_socket_client("sslv3://127.0.0.1:64321", $errno, $errstr, 3, $flags, $ctx);
37+
$client = @stream_socket_client("tlsv1.0://127.0.0.1:64321", $errno, $errstr, 3, $flags, $ctx);
3838
var_dump($client);
3939
4040
$client = @stream_socket_client("tlsv1.2://127.0.0.1:64321", $errno, $errstr, 3, $flags, $ctx);

ext/openssl/xp_ssl.c

Lines changed: 24 additions & 21 deletions
Original file line numberDiff line numberDiff line change
@@ -60,15 +60,6 @@
6060
#define STREAM_CRYPTO_METHOD_TLSv1_2 (1<<5)
6161
#define STREAM_CRYPTO_METHOD_TLSv1_3 (1<<6)
6262

63-
#ifndef OPENSSL_NO_SSL3
64-
#define HAVE_SSL3 1
65-
#define PHP_OPENSSL_MIN_PROTO_VERSION STREAM_CRYPTO_METHOD_SSLv3
66-
#else
67-
#define PHP_OPENSSL_MIN_PROTO_VERSION STREAM_CRYPTO_METHOD_TLSv1_0
68-
#endif
69-
#define PHP_OPENSSL_MAX_PROTO_VERSION STREAM_CRYPTO_METHOD_TLSv1_3
70-
71-
7263
#define HAVE_TLS11 1
7364
#define HAVE_TLS12 1
7465
#if OPENSSL_VERSION_NUMBER >= 0x10101000
@@ -90,6 +81,18 @@
9081
#define HAVE_SEC_LEVEL 1
9182
#endif
9283

84+
#ifndef OPENSSL_NO_SSL3
85+
#define HAVE_SSL3 1
86+
#define PHP_OPENSSL_MIN_PROTO_VERSION STREAM_CRYPTO_METHOD_SSLv3
87+
#else
88+
#define PHP_OPENSSL_MIN_PROTO_VERSION STREAM_CRYPTO_METHOD_TLSv1_0
89+
#endif
90+
#ifdef HAVE_TLS13
91+
#define PHP_OPENSSL_MAX_PROTO_VERSION STREAM_CRYPTO_METHOD_TLSv1_3
92+
#else
93+
#define PHP_OPENSSL_MAX_PROTO_VERSION STREAM_CRYPTO_METHOD_TLSv1_2
94+
#endif
95+
9396
/* Simplify ssl context option retrieval */
9497
#define GET_VER_OPT(name) \
9598
(PHP_STREAM_CONTEXT(stream) && (val = php_stream_context_get_option(PHP_STREAM_CONTEXT(stream), "ssl", name)) != NULL)
@@ -1015,7 +1018,7 @@ static inline int php_openssl_get_min_proto_version_flag(int flags) /* {{{ */
10151018
return ver;
10161019
}
10171020
}
1018-
return STREAM_CRYPTO_METHOD_TLSv1_3;
1021+
return PHP_OPENSSL_MAX_PROTO_VERSION;
10191022
}
10201023
/* }}} */
10211024

@@ -1035,22 +1038,22 @@ static inline int php_openssl_get_max_proto_version_flag(int flags) /* {{{ */
10351038
static inline int php_openssl_map_proto_version(int flag) /* {{{ */
10361039
{
10371040
switch (flag) {
1041+
#ifdef HAVE_TLS13
1042+
case STREAM_CRYPTO_METHOD_TLSv1_3:
1043+
return TLS1_3_VERSION;
1044+
#endif
1045+
case STREAM_CRYPTO_METHOD_TLSv1_2:
1046+
return TLS1_2_VERSION;
1047+
case STREAM_CRYPTO_METHOD_TLSv1_1:
1048+
return TLS1_1_VERSION;
1049+
case STREAM_CRYPTO_METHOD_TLSv1_0:
1050+
return TLS1_VERSION;
10381051
#ifdef HAVE_SSL3
10391052
case STREAM_CRYPTO_METHOD_SSLv3:
10401053
return SSL3_VERSION;
10411054
#endif
1042-
case STREAM_CRYPTO_METHOD_TLSv1_0:
1043-
return TLS1_VERSION;
1044-
case STREAM_CRYPTO_METHOD_TLSv1_1:
1045-
return TLS1_1_VERSION;
1046-
case STREAM_CRYPTO_METHOD_TLSv1_2:
1047-
return TLS1_2_VERSION;
1048-
/* case STREAM_CRYPTO_METHOD_TLSv1_3: */
1049-
#ifdef HAVE_TLS13
10501055
default:
1051-
return TLS1_3_VERSION;
1052-
#endif
1053-
1056+
return TLS1_2_VERSION;
10541057
}
10551058
}
10561059
/* }}} */

0 commit comments

Comments
 (0)