Skip to content

Commit c2e9c71

Browse files
committed
Fix tests and logic for TLS 1.3
1 parent 5c05f5e commit c2e9c71

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)
@@ -1021,7 +1024,7 @@ static inline int php_openssl_get_min_proto_version_flag(int flags) /* {{{ */
10211024
return ver;
10221025
}
10231026
}
1024-
return STREAM_CRYPTO_METHOD_TLSv1_3;
1027+
return PHP_OPENSSL_MAX_PROTO_VERSION;
10251028
}
10261029
/* }}} */
10271030

@@ -1041,22 +1044,22 @@ static inline int php_openssl_get_max_proto_version_flag(int flags) /* {{{ */
10411044
static inline int php_openssl_map_proto_version(int flag) /* {{{ */
10421045
{
10431046
switch (flag) {
1047+
#ifdef HAVE_TLS13
1048+
case STREAM_CRYPTO_METHOD_TLSv1_3:
1049+
return TLS1_3_VERSION;
1050+
#endif
1051+
case STREAM_CRYPTO_METHOD_TLSv1_2:
1052+
return TLS1_2_VERSION;
1053+
case STREAM_CRYPTO_METHOD_TLSv1_1:
1054+
return TLS1_1_VERSION;
1055+
case STREAM_CRYPTO_METHOD_TLSv1_0:
1056+
return TLS1_VERSION;
10441057
#ifdef HAVE_SSL3
10451058
case STREAM_CRYPTO_METHOD_SSLv3:
10461059
return SSL3_VERSION;
10471060
#endif
1048-
case STREAM_CRYPTO_METHOD_TLSv1_0:
1049-
return TLS1_VERSION;
1050-
case STREAM_CRYPTO_METHOD_TLSv1_1:
1051-
return TLS1_1_VERSION;
1052-
case STREAM_CRYPTO_METHOD_TLSv1_2:
1053-
return TLS1_2_VERSION;
1054-
/* case STREAM_CRYPTO_METHOD_TLSv1_3: */
1055-
#ifdef HAVE_TLS13
10561061
default:
1057-
return TLS1_3_VERSION;
1058-
#endif
1059-
1062+
return TLS1_2_VERSION;
10601063
}
10611064
}
10621065
/* }}} */

0 commit comments

Comments
 (0)