Skip to content

Commit 46d2865

Browse files
maurice2knikic
authored andcommitted
Fixed bug #74341
Added support for ASN.1 UTCTime without seconds part (being 11 characters long instead of 13). Additionally, fixed incorrect handling of DST on systems without gmtoff.
1 parent e0102f8 commit 46d2865

File tree

3 files changed

+71
-8
lines changed

3 files changed

+71
-8
lines changed

NEWS

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -6,6 +6,10 @@ PHP NEWS
66
. Fixed bug #74343 (compile fails on solaris 11 with system gd2 library).
77
(krakjoe)
88

9+
- OpenSSL:
10+
. Fixed bug #74341 (openssl_x509_parse fails to parse ASN.1 UTCTime without
11+
seconds). (Moritz Fain)
12+
913
13 Apr 2017 PHP 7.0.18
1014

1115
- Core:

ext/openssl/openssl.c

Lines changed: 15 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -739,23 +739,26 @@ static time_t asn1_time_to_time_t(ASN1_UTCTIME * timestr) /* {{{ */
739739
char * strbuf;
740740
char * thestr;
741741
long gmadjust = 0;
742+
size_t timestr_len;
742743

743744
if (ASN1_STRING_type(timestr) != V_ASN1_UTCTIME && ASN1_STRING_type(timestr) != V_ASN1_GENERALIZEDTIME) {
744745
php_error_docref(NULL, E_WARNING, "illegal ASN1 data type for timestamp");
745746
return (time_t)-1;
746747
}
747748

748-
if (ASN1_STRING_length(timestr) != strlen((const char*)ASN1_STRING_data(timestr))) {
749+
timestr_len = (size_t)ASN1_STRING_length(timestr);
750+
751+
if (timestr_len != strlen((const char*)ASN1_STRING_data(timestr))) {
749752
php_error_docref(NULL, E_WARNING, "illegal length in timestamp");
750753
return (time_t)-1;
751754
}
752755

753-
if (ASN1_STRING_length(timestr) < 13) {
756+
if (timestr_len < 13 && timestr_len != 11) {
754757
php_error_docref(NULL, E_WARNING, "unable to parse time string %s correctly", timestr->data);
755758
return (time_t)-1;
756759
}
757760

758-
if (ASN1_STRING_type(timestr) == V_ASN1_GENERALIZEDTIME && ASN1_STRING_length(timestr) < 15) {
761+
if (ASN1_STRING_type(timestr) == V_ASN1_GENERALIZEDTIME && timestr_len < 15) {
759762
php_error_docref(NULL, E_WARNING, "unable to parse time string %s correctly", timestr->data);
760763
return (time_t)-1;
761764
}
@@ -766,11 +769,15 @@ static time_t asn1_time_to_time_t(ASN1_UTCTIME * timestr) /* {{{ */
766769

767770
/* we work backwards so that we can use atoi more easily */
768771

769-
thestr = strbuf + ASN1_STRING_length(timestr) - 3;
772+
thestr = strbuf + timestr_len - 3;
770773

771-
thetime.tm_sec = atoi(thestr);
772-
*thestr = '\0';
773-
thestr -= 2;
774+
if (timestr_len == 11) {
775+
thetime.tm_sec = 0;
776+
} else {
777+
thetime.tm_sec = atoi(thestr);
778+
*thestr = '\0';
779+
thestr -= 2;
780+
}
774781
thetime.tm_min = atoi(thestr);
775782
*thestr = '\0';
776783
thestr -= 2;
@@ -807,7 +814,7 @@ static time_t asn1_time_to_time_t(ASN1_UTCTIME * timestr) /* {{{ */
807814
** the value of timezone - 3600 seconds. Otherwise, we need to overcorrect and
808815
** set the adjustment to the main timezone + 3600 seconds.
809816
*/
810-
gmadjust = -(thetime.tm_isdst ? (long)timezone - 3600 : (long)timezone + 3600);
817+
gmadjust = -(thetime.tm_isdst ? (long)timezone - 3600 : (long)timezone);
811818
#endif
812819
ret += gmadjust;
813820

ext/openssl/tests/bug74341.phpt

Lines changed: 52 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,52 @@
1+
--TEST--
2+
Bug #74341 (openssl_x509_parse fails to parse ASN.1 UTCTime without seconds)
3+
--SKIPIF--
4+
<?php if (!extension_loaded("openssl")) print "skip"; ?>
5+
--FILE--
6+
<?php
7+
8+
$pem_cert = '
9+
-----BEGIN CERTIFICATE-----
10+
MIIGFDCCBPygAwIBAgIDKCHVMA0GCSqGSIb3DQEBBQUAMIHcMQswCQYDVQQGEwJV
11+
UzEQMA4GA1UECBMHQXJpem9uYTETMBEGA1UEBxMKU2NvdHRzZGFsZTElMCMGA1UE
12+
ChMcU3RhcmZpZWxkIFRlY2hub2xvZ2llcywgSW5jLjE5MDcGA1UECxMwaHR0cDov
13+
L2NlcnRpZmljYXRlcy5zdGFyZmllbGR0ZWNoLmNvbS9yZXBvc2l0b3J5MTEwLwYD
14+
VQQDEyhTdGFyZmllbGQgU2VjdXJlIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MREw
15+
DwYDVQQFEwgxMDY4ODQzNTAcFwsxNDAxMDcwMDAwWhcNMTYwNDAxMDcwMDAwWjCB
16+
6zETMBEGCysGAQQBgjc8AgEDEwJVUzEYMBYGCysGAQQBgjc8AgECEwdBcml6b25h
17+
MR0wGwYDVQQPExRQcml2YXRlIE9yZ2FuaXphdGlvbjEUMBIGA1UEBRMLUi0xNzI0
18+
NzQxLTYxCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6b25hMRMwEQYDVQQHEwpT
19+
Y290dHNkYWxlMSQwIgYDVQQKExtTdGFyZmllbGQgVGVjaG5vbG9naWVzLCBMTEMx
20+
KzApBgNVBAMTInZhbGlkLnNmaS5jYXRlc3Quc3RhcmZpZWxkdGVjaC5jb20wggEi
21+
MA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCt1LHQOza9tkKxwGL+/yKi/Fe5
22+
HM0sjvcM4ic1XVrvpewa4P/04IzGSjIGO3CXaSArxQMSzsTt2dcO9tSJ1Zk8c9NZ
23+
XM8eVqx92iTMEf9OQcubWpzWmrPc3TAFhbVnfEmCptsXEgtxbAIbntrNeDk/hBPd
24+
l4DYFYRdm3ZTk4JMIf/quDZe5Oti53J0UsxWXSSoqKyPNdb671Q+OTQfSDj7kVF4
25+
+Ri3FIeAV16d2UnpBW1bgNqA5yITRskHE4bX98HDNHUTHioHpgA+fXfejWkGB/0F
26+
QN4HbZcysYHhf1L5cWBtz9w5J00YmjM5fzWvTc3UUF9ou7m7JE4aqEbNOWb9AgMB
27+
AAGjggHOMIIByjAMBgNVHRMBAf8EAjAAMA4GA1UdDwEB/wQEAwIFoDAdBgNVHSUE
28+
FjAUBggrBgEFBQcDAQYIKwYBBQUHAwIwLQYDVR0RBCYwJIIidmFsaWQuc2ZpLmNh
29+
dGVzdC5zdGFyZmllbGR0ZWNoLmNvbTAdBgNVHQ4EFgQUcO+QEqZcHphPW9szww9t
30+
y+1AGmQwHwYDVR0jBBgwFoAUSUtSJ9EbvPKhIWpie1FCeorX1VYwOAYDVR0fBDEw
31+
LzAtoCugKYYnaHR0cDovL2NybC5zdGFyZmllbGR0ZWNoLmNvbS9zZnMzLTAuY3Js
32+
MIGNBggrBgEFBQcBAQSBgDB+MCoGCCsGAQUFBzABhh5odHRwOi8vb2NzcC5zdGFy
33+
ZmllbGR0ZWNoLmNvbS8wUAYIKwYBBQUHMAKGRGh0dHA6Ly9jZXJ0aWZpY2F0ZXMu
34+
c3RhcmZpZWxkdGVjaC5jb20vcmVwb3NpdG9yeS9zZl9pbnRlcm1lZGlhdGUuY3J0
35+
MFIGA1UdIARLMEkwRwYLYIZIAYb9bgEHFwMwODA2BggrBgEFBQcCARYqaHR0cDov
36+
L2NlcnRzLnN0YXJmaWVsZHRlY2guY29tL3JlcG9zaXRvcnkvMA0GCSqGSIb3DQEB
37+
BQUAA4IBAQAViYkLUjQkxWRmZl4DutL0/9/wJSURcJ1qunLP+TImJFp0A9RE/MNK
38+
ZOmQoAEoH6hMg7FL4etkvTcnruTdcx+3mvqYiECUiUEx6pkx3dmkYgZACEuk2nfy
39+
J0MkV/zwzqmI8aV+kunpOQv93aePZbrBgaAzkE8jDlExtd7c4pE7JF40jxmvDwjZ
40+
HwpyNDULreGtFBij7JcWJCfihM3uetqrao0kOoeih1PQyJXtz2RldhFYs6Jdk3IL
41+
Yv+84t5UMO+aS9nVBXIcbgaGjIMZjHDgR/tE9FKFB66k8UTDzAwwEs38VV24zx6h
42+
lOzTF7xAUxmPUnNb2teatMf2Rmj0fs+d
43+
-----END CERTIFICATE-----
44+
';
45+
46+
$parsed_cert = openssl_x509_parse($pem_cert);
47+
var_dump($parsed_cert['validFrom_time_t']);
48+
var_dump($parsed_cert['validTo_time_t']);
49+
?>
50+
--EXPECTF--
51+
int(1389052800)
52+
int(1459494000)

0 commit comments

Comments
 (0)