Skip to content

Commit 98736e8

Browse files
committed
Fix GH-13343: openssl_x509_parse should not allow omitted seconds in UTCTimes
Closes GH-14439 Signed-off-by: Jakub Zelenka <[email protected]>
1 parent 65ff511 commit 98736e8

File tree

5 files changed

+72
-14
lines changed

5 files changed

+72
-14
lines changed

NEWS

+2
Original file line numberDiff line numberDiff line change
@@ -143,6 +143,8 @@ PHP NEWS
143143
. Added compile-time option --with-openssl-legacy-provider to enable legacy
144144
provider. (Adam Saponara)
145145
. Added support for Curve25519 + Curve448 based keys. (Manuel Mausz)
146+
. Fixed bug GH-13343 (openssl_x509_parse should not allow omitted seconds in
147+
UTCTimes). (Jakub Zelenka)
146148

147149
- Output:
148150
. Clear output handler status flags during handler initialization. (haszi)

UPGRADING

+3
Original file line numberDiff line numberDiff line change
@@ -426,6 +426,9 @@ PHP 8.4 UPGRADE NOTES
426426
a single entry.
427427
. New serial_hex parameter added to openssl_csr_sign to allow setting serial
428428
number in the hexadecimal format.
429+
. Parsing ASN.1 UTCTime by openssl_x509_parse fails if seconds are omitted
430+
for OpenSSL version below 3.2 (-1 is returned for such fields). The
431+
OpenSSL version 3.3+ does not load such certificates already.
429432

430433
- ODBC:
431434
. Parameter $row of odbc_fetch_object(), odbc_fetch_array(), and

ext/openssl/openssl.c

+4-8
Original file line numberDiff line numberDiff line change
@@ -760,7 +760,7 @@ static time_t php_openssl_asn1_time_to_time_t(ASN1_UTCTIME * timestr) /* {{{ */
760760
return (time_t)-1;
761761
}
762762

763-
if (timestr_len < 13 && timestr_len != 11) {
763+
if (timestr_len < 13) {
764764
php_error_docref(NULL, E_WARNING, "Unable to parse time string %s correctly", timestr->data);
765765
return (time_t)-1;
766766
}
@@ -778,13 +778,9 @@ static time_t php_openssl_asn1_time_to_time_t(ASN1_UTCTIME * timestr) /* {{{ */
778778

779779
thestr = strbuf + timestr_len - 3;
780780

781-
if (timestr_len == 11) {
782-
thetime.tm_sec = 0;
783-
} else {
784-
thetime.tm_sec = atoi(thestr);
785-
*thestr = '\0';
786-
thestr -= 2;
787-
}
781+
thetime.tm_sec = atoi(thestr);
782+
*thestr = '\0';
783+
thestr -= 2;
788784
thetime.tm_min = atoi(thestr);
789785
*thestr = '\0';
790786
thestr -= 2;

ext/openssl/tests/gh13343.phpt

+56
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,56 @@
1+
--TEST--
2+
GH-13343: openssl_x509_parse should not allow omitted seconds in UTCTimes
3+
--EXTENSIONS--
4+
openssl
5+
--SKIPIF--
6+
<?php
7+
if (OPENSSL_VERSION_NUMBER >= 0x30300000) die('skip For OpenSSL < 3.3');
8+
?>
9+
--FILE--
10+
<?php
11+
12+
$pem_cert = '
13+
-----BEGIN CERTIFICATE-----
14+
MIIGFDCCBPygAwIBAgIDKCHVMA0GCSqGSIb3DQEBBQUAMIHcMQswCQYDVQQGEwJV
15+
UzEQMA4GA1UECBMHQXJpem9uYTETMBEGA1UEBxMKU2NvdHRzZGFsZTElMCMGA1UE
16+
ChMcU3RhcmZpZWxkIFRlY2hub2xvZ2llcywgSW5jLjE5MDcGA1UECxMwaHR0cDov
17+
L2NlcnRpZmljYXRlcy5zdGFyZmllbGR0ZWNoLmNvbS9yZXBvc2l0b3J5MTEwLwYD
18+
VQQDEyhTdGFyZmllbGQgU2VjdXJlIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MREw
19+
DwYDVQQFEwgxMDY4ODQzNTAcFwsxNDAxMDcwMDAwWhcNMTYwNDAxMDcwMDAwWjCB
20+
6zETMBEGCysGAQQBgjc8AgEDEwJVUzEYMBYGCysGAQQBgjc8AgECEwdBcml6b25h
21+
MR0wGwYDVQQPExRQcml2YXRlIE9yZ2FuaXphdGlvbjEUMBIGA1UEBRMLUi0xNzI0
22+
NzQxLTYxCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6b25hMRMwEQYDVQQHEwpT
23+
Y290dHNkYWxlMSQwIgYDVQQKExtTdGFyZmllbGQgVGVjaG5vbG9naWVzLCBMTEMx
24+
KzApBgNVBAMTInZhbGlkLnNmaS5jYXRlc3Quc3RhcmZpZWxkdGVjaC5jb20wggEi
25+
MA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCt1LHQOza9tkKxwGL+/yKi/Fe5
26+
HM0sjvcM4ic1XVrvpewa4P/04IzGSjIGO3CXaSArxQMSzsTt2dcO9tSJ1Zk8c9NZ
27+
XM8eVqx92iTMEf9OQcubWpzWmrPc3TAFhbVnfEmCptsXEgtxbAIbntrNeDk/hBPd
28+
l4DYFYRdm3ZTk4JMIf/quDZe5Oti53J0UsxWXSSoqKyPNdb671Q+OTQfSDj7kVF4
29+
+Ri3FIeAV16d2UnpBW1bgNqA5yITRskHE4bX98HDNHUTHioHpgA+fXfejWkGB/0F
30+
QN4HbZcysYHhf1L5cWBtz9w5J00YmjM5fzWvTc3UUF9ou7m7JE4aqEbNOWb9AgMB
31+
AAGjggHOMIIByjAMBgNVHRMBAf8EAjAAMA4GA1UdDwEB/wQEAwIFoDAdBgNVHSUE
32+
FjAUBggrBgEFBQcDAQYIKwYBBQUHAwIwLQYDVR0RBCYwJIIidmFsaWQuc2ZpLmNh
33+
dGVzdC5zdGFyZmllbGR0ZWNoLmNvbTAdBgNVHQ4EFgQUcO+QEqZcHphPW9szww9t
34+
y+1AGmQwHwYDVR0jBBgwFoAUSUtSJ9EbvPKhIWpie1FCeorX1VYwOAYDVR0fBDEw
35+
LzAtoCugKYYnaHR0cDovL2NybC5zdGFyZmllbGR0ZWNoLmNvbS9zZnMzLTAuY3Js
36+
MIGNBggrBgEFBQcBAQSBgDB+MCoGCCsGAQUFBzABhh5odHRwOi8vb2NzcC5zdGFy
37+
ZmllbGR0ZWNoLmNvbS8wUAYIKwYBBQUHMAKGRGh0dHA6Ly9jZXJ0aWZpY2F0ZXMu
38+
c3RhcmZpZWxkdGVjaC5jb20vcmVwb3NpdG9yeS9zZl9pbnRlcm1lZGlhdGUuY3J0
39+
MFIGA1UdIARLMEkwRwYLYIZIAYb9bgEHFwMwODA2BggrBgEFBQcCARYqaHR0cDov
40+
L2NlcnRzLnN0YXJmaWVsZHRlY2guY29tL3JlcG9zaXRvcnkvMA0GCSqGSIb3DQEB
41+
BQUAA4IBAQAViYkLUjQkxWRmZl4DutL0/9/wJSURcJ1qunLP+TImJFp0A9RE/MNK
42+
ZOmQoAEoH6hMg7FL4etkvTcnruTdcx+3mvqYiECUiUEx6pkx3dmkYgZACEuk2nfy
43+
J0MkV/zwzqmI8aV+kunpOQv93aePZbrBgaAzkE8jDlExtd7c4pE7JF40jxmvDwjZ
44+
HwpyNDULreGtFBij7JcWJCfihM3uetqrao0kOoeih1PQyJXtz2RldhFYs6Jdk3IL
45+
Yv+84t5UMO+aS9nVBXIcbgaGjIMZjHDgR/tE9FKFB66k8UTDzAwwEs38VV24zx6h
46+
lOzTF7xAUxmPUnNb2teatMf2Rmj0fs+d
47+
-----END CERTIFICATE-----
48+
';
49+
50+
$parsed_cert = openssl_x509_parse($pem_cert);
51+
var_dump($parsed_cert['validFrom_time_t']);
52+
?>
53+
--EXPECTF--
54+
55+
Warning: openssl_x509_parse(): Unable to parse time string 1401070000Z correctly in %s on line %d
56+
int(-1)

ext/openssl/tests/bug74341.phpt renamed to ext/openssl/tests/gh13343_openssl33.phpt

+7-6
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,11 @@
11
--TEST--
2-
Bug #74341 (openssl_x509_parse fails to parse ASN.1 UTCTime without seconds)
2+
GH-13343: openssl_x509_parse should not allow omitted seconds in UTCTimes for OpenSSL 3.3+
33
--EXTENSIONS--
44
openssl
5+
--SKIPIF--
6+
<?php
7+
if (OPENSSL_VERSION_NUMBER < 0x30300000) die('skip For OpenSSL >= 3.3');
8+
?>
59
--FILE--
610
<?php
711

@@ -43,10 +47,7 @@ lOzTF7xAUxmPUnNb2teatMf2Rmj0fs+d
4347
-----END CERTIFICATE-----
4448
';
4549

46-
$parsed_cert = openssl_x509_parse($pem_cert);
47-
var_dump($parsed_cert['validFrom_time_t']);
48-
var_dump($parsed_cert['validTo_time_t']);
50+
var_dump(openssl_x509_parse($pem_cert));
4951
?>
5052
--EXPECT--
51-
int(1389052800)
52-
int(1459494000)
53+
bool(false)

0 commit comments

Comments
 (0)