]> granicus.if.org Git - php/commitdiff
Fixed string format validation inside phar extension. Reported by Stefan Esser
authorIlia Alshanetsky <iliaa@php.net>
Tue, 27 Apr 2010 17:13:24 +0000 (17:13 +0000)
committerIlia Alshanetsky <iliaa@php.net>
Tue, 27 Apr 2010 17:13:24 +0000 (17:13 +0000)
NEWS
ext/phar/dirstream.c
ext/phar/stream.c

diff --git a/NEWS b/NEWS
index 0e6b61433d24cc6fa7d66223d998481c54f0069a..b7ba3822448aa3ca1478c94139be48f0511fce61 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -21,6 +21,8 @@ PHP                                                                        NEWS
 - Fixed very rare memory leak in mysqlnd, when binding thousands of columns.
   (Andrey)
 
+- Fixed string format validation inside phar extension. Reported by Stefan
+  Esser (Ilia)
 - Fixed handling of session variable serialization on certain prefix
   characters. Reported by Stefan Esser (Ilia)
 - Fixed a NULL pointer dereference when processing invalid XML-RPC
index c1758d42059de7d784bafcbb115d281e7a78db17..0e5c09b8bca45cd85eb8d7de8e90417d9791cc11 100644 (file)
@@ -360,7 +360,7 @@ php_stream *phar_wrapper_open_dir(php_stream_wrapper *wrapper, char *path, char
 
        if (FAILURE == phar_get_archive(&phar, resource->host, host_len, NULL, 0, &error TSRMLS_CC)) {
                if (error) {
-                       php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, error);
+                       php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, "%s", error);
                        efree(error);
                } else {
                        php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, "phar file \"%s\" is unknown", resource->host);
index 94c81d116474d56fd18c07b8d6902e412967735e..2b91e8df245ed5fca3eccb398fdc00c9eb89eab1 100644 (file)
@@ -117,7 +117,7 @@ php_url* phar_parse_url(php_stream_wrapper *wrapper, char *filename, char *mode,
                {
                        if (error) {
                                if (!(options & PHP_STREAM_URL_STAT_QUIET)) {
-                                       php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, error);
+                                       php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, "%s", error);
                                }
                                efree(error);
                        }
@@ -128,7 +128,7 @@ php_url* phar_parse_url(php_stream_wrapper *wrapper, char *filename, char *mode,
                        if (error) {
                                spprintf(&error, 0, "Cannot open cached phar '%s' as writeable, copy on write failed", resource->host);
                                if (!(options & PHP_STREAM_URL_STAT_QUIET)) {
-                                       php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, error);
+                                       php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, "%s", error);
                                }
                                efree(error);
                        }
@@ -140,7 +140,7 @@ php_url* phar_parse_url(php_stream_wrapper *wrapper, char *filename, char *mode,
                {
                        if (error) {
                                if (!(options & PHP_STREAM_URL_STAT_QUIET)) {
-                                       php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, error);
+                                       php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, "%s", error);
                                }
                                efree(error);
                        }
@@ -192,7 +192,7 @@ static php_stream * phar_wrapper_open_url(php_stream_wrapper *wrapper, char *pat
        if (mode[0] == 'w' || (mode[0] == 'r' && mode[1] == '+')) {
                if (NULL == (idata = phar_get_or_create_entry_data(resource->host, host_len, internal_file, strlen(internal_file), mode, 0, &error, 1 TSRMLS_CC))) {
                        if (error) {
-                               php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, error);
+                               php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, "%s", error);
                                efree(error);
                        } else {
                                php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, "phar error: file \"%s\" could not be created in phar \"%s\"", internal_file, resource->host);
@@ -297,7 +297,7 @@ static php_stream * phar_wrapper_open_url(php_stream_wrapper *wrapper, char *pat
                if ((FAILURE == phar_get_entry_data(&idata, resource->host, host_len, internal_file, strlen(internal_file), "r", 0, &error, 0 TSRMLS_CC)) || !idata) {
 idata_error:
                        if (error) {
-                               php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, error);
+                               php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, "%s", error);
                                efree(error);
                        } else {
                                php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, "phar error: \"%s\" is not a file in phar \"%s\"", internal_file, resource->host);
@@ -320,7 +320,7 @@ idata_error:
 
        /* check length, crc32 */
        if (!idata->internal_file->is_crc_checked && phar_postprocess_file(idata, idata->internal_file->crc32, &error, 2 TSRMLS_CC) != SUCCESS) {
-               php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, error);
+               php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, "%s", error);
                efree(error);
                phar_entry_delref(idata TSRMLS_CC);
                efree(internal_file);
@@ -761,7 +761,7 @@ static int phar_wrapper_unlink(php_stream_wrapper *wrapper, char *url, int optio
        efree(internal_file);
        phar_entry_remove(idata, &error TSRMLS_CC);
        if (error) {
-               php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, error);
+               php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, "%s", error);
                efree(error);
        }
        return 1;