Blame SOURCES/php-5.5.6-CVE-2013-6420.patch

37fd76
diff -up php-5.5.6/ext/openssl/openssl.c.cve6420 php-5.5.6/ext/openssl/openssl.c
37fd76
--- php-5.5.6/ext/openssl/openssl.c.cve6420	2013-11-12 15:17:27.000000000 +0100
37fd76
+++ php-5.5.6/ext/openssl/openssl.c	2013-12-06 09:45:33.910545670 +0100
37fd76
@@ -657,18 +657,28 @@ static time_t asn1_time_to_time_t(ASN1_U
37fd76
 	char * thestr;
37fd76
 	long gmadjust = 0;
37fd76
 
37fd76
-	if (timestr->length < 13) {
37fd76
+	if (ASN1_STRING_type(timestr) != V_ASN1_UTCTIME) {
37fd76
+		php_error_docref(NULL TSRMLS_CC, E_WARNING, "illegal ASN1 data type for timestamp");
37fd76
+		return (time_t)-1;
37fd76
+	}
37fd76
+
37fd76
+	if (ASN1_STRING_length(timestr) != strlen(ASN1_STRING_data(timestr))) {
37fd76
+		php_error_docref(NULL TSRMLS_CC, E_WARNING, "illegal length in timestamp");
37fd76
+		return (time_t)-1;
37fd76
+	}
37fd76
+
37fd76
+	if (ASN1_STRING_length(timestr) < 13) {
37fd76
 		php_error_docref(NULL TSRMLS_CC, E_WARNING, "extension author too lazy to parse %s correctly", timestr->data);
37fd76
 		return (time_t)-1;
37fd76
 	}
37fd76
 
37fd76
-	strbuf = estrdup((char *)timestr->data);
37fd76
+	strbuf = estrdup((char *)ASN1_STRING_data(timestr));
37fd76
 
37fd76
 	memset(&thetime, 0, sizeof(thetime));
37fd76
 
37fd76
 	/* we work backwards so that we can use atoi more easily */
37fd76
 
37fd76
-	thestr = strbuf + timestr->length - 3;
37fd76
+	thestr = strbuf + ASN1_STRING_length(timestr) - 3;
37fd76
 
37fd76
 	thetime.tm_sec = atoi(thestr);
37fd76
 	*thestr = '\0';
37fd76
diff -up php-5.5.6/ext/openssl/tests/cve-2013-6420.crt.cve6420 php-5.5.6/ext/openssl/tests/cve-2013-6420.crt
37fd76
--- php-5.5.6/ext/openssl/tests/cve-2013-6420.crt.cve6420	2013-12-06 09:45:33.910545670 +0100
37fd76
+++ php-5.5.6/ext/openssl/tests/cve-2013-6420.crt	2013-12-06 09:45:33.910545670 +0100
37fd76
@@ -0,0 +1,29 @@
37fd76
+-----BEGIN CERTIFICATE-----
37fd76
+MIIEpDCCA4ygAwIBAgIJAJzu8r6u6eBcMA0GCSqGSIb3DQEBBQUAMIHDMQswCQYD
37fd76
+VQQGEwJERTEcMBoGA1UECAwTTm9yZHJoZWluLVdlc3RmYWxlbjEQMA4GA1UEBwwH
37fd76
+S8ODwrZsbjEUMBIGA1UECgwLU2VrdGlvbkVpbnMxHzAdBgNVBAsMFk1hbGljaW91
37fd76
+cyBDZXJ0IFNlY3Rpb24xITAfBgNVBAMMGG1hbGljaW91cy5zZWt0aW9uZWlucy5k
37fd76
+ZTEqMCgGCSqGSIb3DQEJARYbc3RlZmFuLmVzc2VyQHNla3Rpb25laW5zLmRlMHUY
37fd76
+ZDE5NzAwMTAxMDAwMDAwWgAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
37fd76
+AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
37fd76
+AAAAAAAXDTE0MTEyODExMzkzNVowgcMxCzAJBgNVBAYTAkRFMRwwGgYDVQQIDBNO
37fd76
+b3JkcmhlaW4tV2VzdGZhbGVuMRAwDgYDVQQHDAdLw4PCtmxuMRQwEgYDVQQKDAtT
37fd76
+ZWt0aW9uRWluczEfMB0GA1UECwwWTWFsaWNpb3VzIENlcnQgU2VjdGlvbjEhMB8G
37fd76
+A1UEAwwYbWFsaWNpb3VzLnNla3Rpb25laW5zLmRlMSowKAYJKoZIhvcNAQkBFhtz
37fd76
+dGVmYW4uZXNzZXJAc2VrdGlvbmVpbnMuZGUwggEiMA0GCSqGSIb3DQEBAQUAA4IB
37fd76
+DwAwggEKAoIBAQDDAf3hl7JY0XcFniyEJpSSDqn0OqBr6QP65usJPRt/8PaDoqBu
37fd76
+wEYT/Na+6fsgPjC0uK9DZgWg2tHWWoanSblAMoz5PH6Z+S4SHRZ7e2dDIjPjdhjh
37fd76
+0mLg2UMO5yp0V797Ggs9lNt6JRfH81MN2obXWs4NtztLMuD6egqpr8dDbr34aOs8
37fd76
+pkdui5UawTZksy5pLPHq5cMhFGm06v65CLo0V2Pd9+KAokPrPcN5KLKebz7mLpk6
37fd76
+SMeEXOKP4idEqxyQ7O7fBuHMedsQhu+prY3si3BUyKfQtP5CZnX2bp0wKHxX12DX
37fd76
+1nfFIt9DbGvHTcyOuN+nZLPBm3vWxntyIIvVAgMBAAGjQjBAMAkGA1UdEwQCMAAw
37fd76
+EQYJYIZIAYb4QgEBBAQDAgeAMAsGA1UdDwQEAwIFoDATBgNVHSUEDDAKBggrBgEF
37fd76
+BQcDAjANBgkqhkiG9w0BAQUFAAOCAQEAG0fZYYCTbdj1XYc+1SnoaPR+vI8C8CaD
37fd76
+8+0UYhdnyU4gga0BAcDrY9e94eEAu6ZqycF6FjLqXXdAboppWocr6T6GD1x33Ckl
37fd76
+VArzG/KxQohGD2JeqkhIMlDomxHO7ka39+Oa8i2vWLVyjU8AZvWMAruHa4EENyG7
37fd76
+lW2AagaFKFCr9TnXTfrdxGVEbv7KVQ6bdhg5p5SjpWH1+Mq03uR3ZXPBYdyV8319
37fd76
+o0lVj1KFI2DCL/liWisJRoof+1cR35Ctd0wYBcpB6TZslMcOPl76dwKwJgeJo2Qg
37fd76
+Zsfmc2vC1/qOlNuNq/0TzzkVGv8ETT3CgaU+UXe4XOVvkccebJn2dg==
37fd76
+-----END CERTIFICATE-----
37fd76
+
37fd76
+
37fd76
diff -up php-5.5.6/ext/openssl/tests/cve-2013-6420.phpt.cve6420 php-5.5.6/ext/openssl/tests/cve-2013-6420.phpt
37fd76
--- php-5.5.6/ext/openssl/tests/cve-2013-6420.phpt.cve6420	2013-12-06 09:45:33.910545670 +0100
37fd76
+++ php-5.5.6/ext/openssl/tests/cve-2013-6420.phpt	2013-12-06 09:45:33.910545670 +0100
37fd76
@@ -0,0 +1,18 @@
37fd76
+--TEST--
37fd76
+CVE-2013-6420
37fd76
+--SKIPIF--
37fd76
+
37fd76
+if (!extension_loaded("openssl")) die("skip"); 
37fd76
+?>
37fd76
+--FILE--
37fd76
+
37fd76
+$crt = substr(__FILE__, 0, -4).'.crt';
37fd76
+$info = openssl_x509_parse("file://$crt");
37fd76
+var_dump($info['issuer']['emailAddress'], $info["validFrom_time_t"]);
37fd76
+?>
37fd76
+Done
37fd76
+--EXPECTF--
37fd76
+%s openssl_x509_parse(): illegal ASN1 data type for timestamp in %s/cve-2013-6420.php on line 3
37fd76
+string(27) "stefan.esser@sektioneins.de"
37fd76
+int(-1)
37fd76
+Done