diff options
author | Anatol Belski <ab@php.net> | 2018-07-03 14:04:22 +0200 |
---|---|---|
committer | Joe Watkins <krakjoe@php.net> | 2018-07-18 11:53:01 +0200 |
commit | 2fa74ad7c4f7f716183860e81489490b83277ccc (patch) | |
tree | b5812e57558bc5c948115a7a06e93288f2cc0f49 | |
parent | e29c24e381445159e7ccc90501bc67bac956348b (diff) | |
download | php-git-2fa74ad7c4f7f716183860e81489490b83277ccc.tar.gz |
Fixed bug #76459 windows linkinfo lacks openbasedir check
-rw-r--r-- | ext/standard/link_win32.c | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/ext/standard/link_win32.c b/ext/standard/link_win32.c index 898928b2af..b46dee6a26 100644 --- a/ext/standard/link_win32.c +++ b/ext/standard/link_win32.c @@ -87,6 +87,7 @@ PHP_FUNCTION(readlink) PHP_FUNCTION(linkinfo) { char *link; + char *dirname; size_t link_len; zend_stat_t sb; int ret; @@ -95,12 +96,22 @@ PHP_FUNCTION(linkinfo) return; } + dirname = estrndup(link, link_len); + php_dirname(dirname, link_len); + + if (php_check_open_basedir(dirname)) { + efree(dirname); + RETURN_FALSE; + } + ret = VCWD_STAT(link, &sb); if (ret == -1) { php_error_docref(NULL, E_WARNING, "%s", strerror(errno)); + efree(dirname); RETURN_LONG(Z_L(-1)); } + efree(dirname); RETURN_LONG((zend_long) sb.st_dev); } /* }}} */ |