From f151e048ed27f6f4eef729f3310d053ab5da71d4 Mon Sep 17 00:00:00 2001 From: Anatol Belski Date: Tue, 3 Jul 2018 14:04:22 +0200 Subject: Fixed bug #76459 windows linkinfo lacks openbasedir check --- ext/standard/link_win32.c | 11 +++++++++++ 1 file changed, 11 insertions(+) (limited to 'ext') diff --git a/ext/standard/link_win32.c b/ext/standard/link_win32.c index 13ee88dfad..0068a3edb1 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); } /* }}} */ -- cgit v1.2.1