summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSara Golemon <pollita@php.net>2017-01-09 16:08:08 -0800
committerSara Golemon <pollita@php.net>2017-01-09 16:08:08 -0800
commit005ba2001ddc0e84ae62e00aa4956899f85c50f8 (patch)
tree083899e234b55e02779fdb55ae3aa697245e5ae8
parent9cc34c4e3ef82d92afdf9864b085ecfb8994927e (diff)
parent69fbe3a9add21dfd2341472e2e702af5c150e98c (diff)
downloadphp-git-005ba2001ddc0e84ae62e00aa4956899f85c50f8.tar.gz
Merge branch 'PHP-7.0' into PHP-7.1
* PHP-7.0: Fix open_basedir check for glob:// opendir wrapper
-rw-r--r--ext/standard/tests/streams/glob-wrapper.phpt35
-rw-r--r--main/streams/glob_wrapper.c8
2 files changed, 39 insertions, 4 deletions
diff --git a/ext/standard/tests/streams/glob-wrapper.phpt b/ext/standard/tests/streams/glob-wrapper.phpt
new file mode 100644
index 0000000000..fc47d83a02
--- /dev/null
+++ b/ext/standard/tests/streams/glob-wrapper.phpt
@@ -0,0 +1,35 @@
+--TEST--
+Glob wrapper bypasses open_basedir
+--INI--
+open_basedir=/does_not_exist
+--SKIPIF--
+<?php
+if (!in_array("glob", stream_get_wrappers())) echo "skip";
+--FILE--
+<?php
+
+foreach ( [ __DIR__, "glob://".__DIR__ ] as $spec) {
+ echo "** Opening $spec\n";
+ $dir = opendir($spec);
+ if (!$dir) {
+ echo "Failed to open $spec\n";
+ continue;
+ }
+ if (false === readdir($dir)) {
+ echo "No files in $spec\n";
+ continue;
+ }
+}
+--EXPECTF--
+** Opening %s
+
+Warning: opendir(): open_basedir restriction in effect. File(/%s) is not within the allowed path(s): (/does_not_exist) in %s/glob-wrapper.php on line 5
+
+Warning: opendir(/%s): failed to open dir: Operation not permitted in %s/glob-wrapper.php on line 5
+Failed to open /%s
+** Opening glob://%s
+
+Warning: opendir(): open_basedir restriction in effect. File(/%s) is not within the allowed path(s): (/does_not_exist) in %s/glob-wrapper.php on line 5
+
+Warning: opendir(glob://%s): failed to open dir: operation failed in %s/glob-wrapper.php on line 5
+Failed to open glob://%s
diff --git a/main/streams/glob_wrapper.c b/main/streams/glob_wrapper.c
index ac7b2d2b1d..1288fa6bad 100644
--- a/main/streams/glob_wrapper.c
+++ b/main/streams/glob_wrapper.c
@@ -213,10 +213,6 @@ static php_stream *php_glob_stream_opener(php_stream_wrapper *wrapper, const cha
int ret;
const char *tmp, *pos;
- if (((options & STREAM_DISABLE_OPEN_BASEDIR) == 0) && php_check_open_basedir(path)) {
- return NULL;
- }
-
if (!strncmp(path, "glob://", sizeof("glob://")-1)) {
path += sizeof("glob://")-1;
if (opened_path) {
@@ -224,6 +220,10 @@ static php_stream *php_glob_stream_opener(php_stream_wrapper *wrapper, const cha
}
}
+ if (((options & STREAM_DISABLE_OPEN_BASEDIR) == 0) && php_check_open_basedir(path)) {
+ return NULL;
+ }
+
pglob = ecalloc(sizeof(*pglob), 1);
if (0 != (ret = glob(path, pglob->flags & GLOB_FLAGMASK, NULL, &pglob->glob))) {