From 289cb0f77c28b80a779170711f5e4e92cdd4fbdb Mon Sep 17 00:00:00 2001 From: Anatol Belski Date: Tue, 3 Jul 2018 13:51:31 +0200 Subject: Fixed bug #76459 windows linkinfo lacks openbasedir check --- ext/standard/link_win32.c | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/ext/standard/link_win32.c b/ext/standard/link_win32.c index 6be7b5f63a..059201c6b2 100644 --- a/ext/standard/link_win32.c +++ b/ext/standard/link_win32.c @@ -87,7 +87,8 @@ PHP_FUNCTION(readlink) PHP_FUNCTION(linkinfo) { char *link; - int link_len; + char *dirname; + int link_len, dir_len; struct stat sb; int ret; @@ -95,12 +96,22 @@ PHP_FUNCTION(linkinfo) return; } + dirname = estrndup(link, link_len); + dir_len = php_dirname(dirname, link_len); + + if (php_check_open_basedir(dirname TSRMLS_CC)) { + efree(dirname); + RETURN_FALSE; + } + ret = VCWD_STAT(link, &sb); if (ret == -1) { php_error_docref(NULL TSRMLS_CC, E_WARNING, "%s", strerror(errno)); + efree(dirname); RETURN_LONG(-1L); } + efree(dirname); RETURN_LONG((long) sb.st_dev); } /* }}} */ -- cgit v1.2.1