PATH:
var
/
www
/
clients
/
client1
/
web1
/
web
/
wp-content
/
plugins
/
wordfence
/
lib
<?php require_once __DIR__ . "/wfInvalidPathException.php"; require_once __DIR__ . "/wfInaccessibleDirectoryException.php"; class wfFileUtils { const CURRENT_DIRECTORY = '.'; const PARENT_DIRECTORY = '..'; const DIRECTORY_SEPARATOR = '/'; public static function isCurrentOrParentDirectory($file) { return $file === self::CURRENT_DIRECTORY || $file === self::PARENT_DIRECTORY; } public static function getContents($directory) { $contents = @scandir($directory); if ($contents === false) throw new wfInaccessibleDirectoryException("Unable to read contents", $directory); return array_filter($contents, function ($file) { return !wfFileUtils::isCurrentOrParentDirectory($file); }); } public static function trimSeparators($path, $trimLeft = true, $trimRight = true) { if ($trimLeft) $path = ltrim($path, self::DIRECTORY_SEPARATOR); if ($trimRight) $path = rtrim($path, self::DIRECTORY_SEPARATOR); return $path; } public static function joinPaths() { $paths = func_get_args(); $count = count($paths); $filtered = array(); $trailingSeparator = false; for ($i = 0; $i < $count; $i++) { $path = self::trimSeparators($paths[$i], !empty($filtered)); if (!empty($path)) { $filtered[] = $path; $trailingSeparator = substr($paths[$i], -1) === self::DIRECTORY_SEPARATOR; } } return implode(self::DIRECTORY_SEPARATOR, $filtered) . ($trailingSeparator ? self::DIRECTORY_SEPARATOR : ''); } public static function splitPath($path, &$count = null) { $components = array_values(array_filter(explode(self::DIRECTORY_SEPARATOR, $path))); $count = count($components); return $components; } public static function isReadableFile($file) { return @is_file($file) && @is_readable($file); } public static function belongsTo($child, $parent) { $childComponents = self::splitPath($child, $childCount); $parentComponents = self::splitPath($parent, $parentCount); if ($childCount < $parentCount) return false; for ($i = 0; $i < $parentCount; $i++) { if ($childComponents[$i] !== $parentComponents[$i]) return false; } return true; } public static function matchPaths($a, $b, $allowChild = false) { $aComponents = self::splitPath($a, $aCount); $bComponents = self::splitPath($b, $bCount); if ($allowChild ? ($bCount < $aCount) : ($aCount !== $bCount)) return false; for ($i = 0; $i < $aCount; $i++) { if ($aComponents[$i] !== $bComponents[$i]) return false; } return true; } public static function realPath($path) { $realPath = realpath($path); if ($realPath === false) throw new wfInvalidPathException("Realpath resolution failed", $path); return $realPath; } public static function isChild($parent, $child) { return self::matchPaths($parent, $child, true); } }
[-] menu_support.php
[edit]
[-] wfBinaryList.php
[edit]
[-] sysinfo.php
[edit]
[-] menu_scanner.php
[edit]
[-] wfViewResult.php
[edit]
[-] wfScanMonitor.php
[edit]
[-] wfScanEngine.php
[edit]
[-] WFLSPHP52Compatability.php
[edit]
[-] .htaccess
[edit]
[-] wfSupportController.php
[edit]
[-] wfConfig.php
[edit]
[-] menu_firewall_waf.php
[edit]
[-] menu_dashboard_options.php
[edit]
[-] wfScan.php
[edit]
[-] wfUtils.php
[edit]
[-] wfDashboard.php
[edit]
[-] wordfenceScanner.php
[edit]
[+]
Diff
[-] menu_tools_whois.php
[edit]
[-] wfIpLocator.php
[edit]
[-] wfUnlockMsg.php
[edit]
[-] menu_wordfence_central.php
[edit]
[-] wfDirectoryIterator.php
[edit]
[-] wfHelperString.php
[edit]
[-] wfDB.php
[edit]
[-] live_activity.php
[edit]
[-] wfCrawl.php
[edit]
[-] email_genericAlert.php
[edit]
[-] IPTrafList.php
[edit]
[-] wfBrowscap.php
[edit]
[-] geoip.mmdb
[edit]
[-] wfAlerts.php
[edit]
[-] wfWebsite.php
[edit]
[-] noc1.key
[edit]
[-] wfCurlInterceptor.php
[edit]
[-] wordfenceHash.php
[edit]
[-] wfDateLocalization.php
[edit]
[-] menu_tools_importExport.php
[edit]
[-] wfScanEntrypoint.php
[edit]
[-] wfView.php
[edit]
[-] menu_tools.php
[edit]
[-] wfJWT.php
[edit]
[-] wfCache.php
[edit]
[-] menu_tools_livetraffic.php
[edit]
[-] wfCrypt.php
[edit]
[-] wfScanFile.php
[edit]
[-] wfAdminNoticeQueue.php
[edit]
[-] wfInaccessibleDirectoryException.php
[edit]
[-] wfVersionCheckController.php
[edit]
[-] wfRESTAPI.php
[edit]
[-] wfDeactivationOption.php
[edit]
[-] menu_tools_diagnostic.php
[edit]
[-] flags.php
[edit]
[-] email_newIssues.php
[edit]
[-] wfBrowscapCache.php
[edit]
[-] wfModuleController.php
[edit]
[-] wfLicense.php
[edit]
[-] wfIpLocation.php
[edit]
[-] wfCredentialsController.php
[edit]
[+]
rest-api
[-] wordfenceClass.php
[edit]
[-] wf503.php
[edit]
[+]
audit-log
[-] wfNotification.php
[edit]
[-] wfLog.php
[edit]
[-] wfActivityReport.php
[edit]
[-] wfScanFileProperties.php
[edit]
[-] wfHelperBin.php
[edit]
[-] wfAPI.php
[edit]
[-] viewFullActivityLog.php
[edit]
[-] wfLockedOut.php
[edit]
[-] wfScanPath.php
[edit]
[-] sodium_compat_fast.php
[edit]
[-] wfIssues.php
[edit]
[-] wordfenceConstants.php
[edit]
[-] menu_firewall_waf_options.php
[edit]
[-] wfI18n.php
[edit]
[-] menu_scanner_options.php
[edit]
[-] IPTraf.php
[edit]
[-] wfAuditLog.php
[edit]
[-] wfCommonPasswords.php
[edit]
[-] wfOnboardingController.php
[edit]
[-] wfInvalidPathException.php
[edit]
[-] email_unsubscribeRequest.php
[edit]
[-] wordfenceURLHoover.php
[edit]
[-] diffResult.php
[edit]
[-] menu_firewall_blocking_options.php
[edit]
[-] menu_scanner_credentials.php
[edit]
[-] wfFileUtils.php
[edit]
[-] wfPersistenceController.php
[edit]
[-] wfVersionSupport.php
[edit]
[-] Diff.php
[edit]
[+]
..
[-] wfMD5BloomFilter.php
[edit]
[-] wfUpdateCheck.php
[edit]
[-] wfDiagnostic.php
[edit]
[-] menu_install.php
[edit]
[-] wfCentralAPI.php
[edit]
[-] menu_options.php
[edit]
[-] wfSchema.php
[edit]
[-] menu_dashboard.php
[edit]
[-] compat.php
[edit]
[-] menu_firewall_blocking.php
[edit]
[-] wfIPWhitelist.php
[edit]
[-] wfBulkCountries.php
[edit]
[-] menu_tools_auditlog.php
[edit]
[-] email_unlockRequest.php
[edit]
[-] menu_firewall.php
[edit]
[-] wfScanFileListItem.php
[edit]
[-] wfImportExportController.php
[edit]
[-] menu_tools_twoFactor.php
[edit]
[+]
dashboard
[-] wfScanFileLink.php
[edit]
[-] wfStyle.php
[edit]