PluginProbe ʕ •ᴥ•ʔ
Wordfence Security – Firewall, Malware Scan, and Login Security / 7.4.4
Wordfence Security – Firewall, Malware Scan, and Login Security v7.4.4
8.2.2 8.2.1 8.2.0 3.7.1 3.7.2 3.8.1 3.8.2 3.8.3 3.8.4 3.8.5 3.8.6 3.8.7 3.8.8 3.8.9 3.9.1 4.0.1 4.0.2 4.0.3 5.0.1 5.0.2 5.0.3 5.0.4 5.0.5 5.0.6 5.0.7 5.0.8 5.0.9 5.1.1 5.1.2 5.1.4 5.1.5 5.1.6 5.1.7 5.1.8 5.1.9 5.2.1 5.2.2 5.2.3 5.2.4 5.2.5 5.2.6 5.2.7 5.2.8 5.2.9 5.3.1 5.3.10 5.3.11 5.3.12 5.3.2 5.3.3 5.3.4 5.3.5 5.3.6 5.3.7 5.3.8 5.3.9 6.0.1 6.0.10 6.0.11 6.0.12 6.0.14 6.0.15 6.0.16 6.0.17 6.0.18 6.0.19 6.0.2 6.0.20 6.0.21 6.0.22 6.0.23 6.0.24 6.0.25 6.0.3 6.0.4 6.0.5 6.0.6 6.0.7 6.0.8 6.0.9 6.1.1 6.1.10 6.1.11 6.1.12 6.1.14 6.1.15 6.1.16 6.1.17 6.1.2 6.1.3 6.1.4 6.1.5 6.1.6 6.1.7 6.1.8 6.1.9 6.2.0 6.2.1 6.2.10 6.2.2 6.2.3 6.2.4 6.2.5 6.2.6 6.2.7 6.2.8 6.2.9 6.3.0 6.3.1 6.3.10 6.3.11 6.3.12 6.3.14 6.3.15 6.3.16 6.3.17 6.3.18 6.3.19 6.3.2 6.3.20 6.3.21 6.3.22 6.3.3 6.3.4 6.3.5 6.3.6 6.3.7 6.3.8 6.3.9 7.0.1 7.0.2 7.0.3 7.0.4 7.0.5 7.1.0 7.1.1 7.1.10 7.1.11 7.1.12 7.1.14 7.1.15 7.1.16 7.1.17 7.1.18 7.1.19 7.1.2 7.1.20 7.1.3 7.1.4 7.1.5 7.1.6 7.1.7 7.1.8 7.1.9 7.10.0 7.10.1 7.10.2 7.10.3 7.10.4 7.10.5 7.10.6 7.10.7 7.11.0 7.11.1 7.11.2 7.11.3 7.11.4 7.11.5 7.11.6 7.11.7 7.2.1 7.2.2 7.2.3 7.2.4 7.2.5 7.3.1 7.3.2 7.3.3 7.3.4 7.3.5 7.3.6 7.4.0 7.4.1 7.4.10 7.4.11 7.4.12 7.4.14 7.4.2 7.4.3 trunk 7.4.4 1.1 7.4.5 1.2 7.4.6 1.3 7.4.7 1.3.1 7.4.8 1.3.2 7.4.9 1.3.3 7.5.0 1.4.2 7.5.1 1.4.3 7.5.10 1.4.4 7.5.11 1.4.5 7.5.2 1.4.6 7.5.3 1.4.7 7.5.4 1.4.8 7.5.5 1.5.1 7.5.6 1.5.2 7.5.7 1.5.3 7.5.8 1.5.4 7.5.9 1.5.5 7.6.0 1.5.6 7.6.1 2.0.1 7.6.2 2.0.2 7.7.0 2.0.3 7.7.1 2.0.5 7.8.0 2.0.6 7.8.1 2.0.7 7.8.2 2.1.0 7.9.0 2.1.1 7.9.1 2.1.2 7.9.2 2.1.3 7.9.3 2.1.4 8.0.0 2.1.5 8.0.1 3.0.2 8.0.2 3.0.3 8.0.3 3.0.4 8.0.4 3.0.5 8.0.5 3.0.6 8.1.0 3.0.7 8.1.1 3.0.8 8.1.2 3.0.9 8.1.3 3.1.0 8.1.4 3.1.1 v1.4.1 3.1.2 3.1.4 3.1.6 3.2.1 3.2.3 3.2.4 3.2.5 3.2.6 3.2.7 3.3.2 3.3.3 3.3.4 3.3.5 3.3.6 3.3.7 3.4.1 3.4.4 3.4.5 3.5.1 3.5.2 3.6.1 3.6.3 3.6.4 3.6.5 3.6.6 3.6.7 3.6.8 3.6.9
wordfence / lib / wfCache.php
wordfence / lib Last commit date
Diff 6 years ago dashboard 7 years ago rest-api 6 years ago .htaccess 7 years ago Diff.php 6 years ago GeoLite2-Country.mmdb 6 years ago IPTraf.php 6 years ago IPTrafList.php 7 years ago WFLSPHP52Compatability.php 6 years ago compat.php 8 years ago conntest.php 7 years ago cronview.php 8 years ago dbview.php 8 years ago diffResult.php 8 years ago email_genericAlert.php 7 years ago email_newIssues.php 6 years ago email_unlockRequest.php 8 years ago email_unsubscribeRequest.php 7 years ago flags.php 7 years ago live_activity.php 8 years ago menu_dashboard.php 7 years ago menu_dashboard_options.php 7 years ago menu_firewall.php 6 years ago menu_firewall_blocking.php 7 years ago menu_firewall_blocking_options.php 8 years ago menu_firewall_waf.php 7 years ago menu_firewall_waf_options.php 7 years ago menu_options.php 6 years ago menu_scanner.php 6 years ago menu_scanner_credentials.php 8 years ago menu_scanner_options.php 6 years ago menu_support.php 7 years ago menu_tools.php 7 years ago menu_tools_diagnostic.php 6 years ago menu_tools_importExport.php 7 years ago menu_tools_livetraffic.php 6 years ago menu_tools_twoFactor.php 7 years ago menu_tools_whois.php 8 years ago menu_wordfence_central.php 7 years ago noc1.key 7 years ago sysinfo.php 8 years ago unknownFiles.php 8 years ago viewFullActivityLog.php 8 years ago wf503.php 7 years ago wfAPI.php 6 years ago wfActivityReport.php 6 years ago wfAdminNoticeQueue.php 8 years ago wfAlerts.php 6 years ago wfArray.php 7 years ago wfBrowscap.php 6 years ago wfBrowscapCache.php 7 years ago wfBulkCountries.php 7 years ago wfCache.php 6 years ago wfCentralAPI.php 6 years ago wfConfig.php 6 years ago wfCrawl.php 6 years ago wfCredentialsController.php 7 years ago wfCrypt.php 6 years ago wfDB.php 7 years ago wfDashboard.php 7 years ago wfDateLocalization.php 8 years ago wfDiagnostic.php 6 years ago wfDict.php 8 years ago wfDirectoryIterator.php 7 years ago wfHelperBin.php 11 years ago wfHelperString.php 11 years ago wfIPWhitelist.php 7 years ago wfImportExportController.php 7 years ago wfIssues.php 6 years ago wfJWT.php 7 years ago wfLockedOut.php 7 years ago wfLog.php 6 years ago wfMD5BloomFilter.php 8 years ago wfModuleController.php 7 years ago wfNotification.php 8 years ago wfOnboardingController.php 7 years ago wfPersistenceController.php 8 years ago wfRESTAPI.php 7 years ago wfScan.php 6 years ago wfScanEngine.php 6 years ago wfSchema.php 6 years ago wfStyle.php 7 years ago wfSupportController.php 6 years ago wfUnlockMsg.php 6 years ago wfUpdateCheck.php 6 years ago wfUtils.php 6 years ago wfVersionCheckController.php 8 years ago wfView.php 10 years ago wfViewResult.php 8 years ago wordfenceClass.php 6 years ago wordfenceConstants.php 6 years ago wordfenceHash.php 6 years ago wordfenceScanner.php 6 years ago wordfenceURLHoover.php 6 years ago
wfCache.php
204 lines
1 <?php
2 class wfCache {
3 private static $cacheStats = array();
4 private static $cacheClearedThisRequest = false;
5 private static $lastRecursiveDeleteError = false;
6
7 public static function removeCaching() {
8 $cacheType = wfConfig::get('cacheType', false);
9 if ($cacheType === 'disabled') {
10 return;
11 }
12
13 if ($cacheType == 'falcon') {
14 self::addHtaccessCode('remove');
15 self::updateBlockedIPs('remove');
16 }
17
18 wfConfig::set('cacheType', 'disabled');
19
20 $cacheDir = WP_CONTENT_DIR . '/wfcache/';
21 if (file_exists($cacheDir . '.htaccess')) {
22 unlink($cacheDir . '.htaccess');
23 }
24
25 self::clearPageCacheSafe();
26 }
27 public static function clearPageCacheSafe(){
28 if(self::$cacheClearedThisRequest){ return; }
29 self::$cacheClearedThisRequest = true;
30 self::clearPageCache();
31 }
32 public static function clearPageCache(){ //If a clear is in progress this does nothing.
33 self::$cacheStats = array(
34 'dirsDeleted' => 0,
35 'filesDeleted' => 0,
36 'totalData' => 0,
37 'totalErrors' => 0,
38 'error' => '',
39 );
40
41 $cacheDir = WP_CONTENT_DIR . '/wfcache/';
42 if (!file_exists($cacheDir)) {
43 return self::$cacheStats;
44 }
45
46 $cacheClearLock = WP_CONTENT_DIR . '/wfcache/clear.lock';
47 if(! is_file($cacheClearLock)){
48 if(! touch($cacheClearLock)){
49 self::$cacheStats['error'] = "Could not create a lock file $cacheClearLock to clear the cache.";
50 self::$cacheStats['totalErrors']++;
51 return self::$cacheStats;
52 }
53 }
54 $fp = fopen($cacheClearLock, 'w');
55 if(! $fp){
56 self::$cacheStats['error'] = "Could not open the lock file $cacheClearLock to clear the cache. Please make sure the directory is writable by your web server.";
57 self::$cacheStats['totalErrors']++;
58 return self::$cacheStats;
59 }
60 if(flock($fp, LOCK_EX | LOCK_NB)){ //non blocking exclusive flock attempt. If we get a lock then it continues and returns true. If we don't lock, then return false, don't block and don't clear the cache.
61 // This logic means that if a cache clear is currently in progress we don't try to clear the cache.
62 // This prevents web server children from being queued up waiting to be able to also clear the cache.
63 self::$lastRecursiveDeleteError = false;
64 self::recursiveDelete(WP_CONTENT_DIR . '/wfcache/');
65 if(self::$lastRecursiveDeleteError){
66 self::$cacheStats['error'] = self::$lastRecursiveDeleteError;
67 self::$cacheStats['totalErrors']++;
68 }
69 flock($fp, LOCK_UN);
70 @unlink($cacheClearLock);
71 @rmdir($cacheDir);
72 }
73 fclose($fp);
74
75 return self::$cacheStats;
76 }
77 private static function recursiveDelete($dir) {
78 $files = array_diff(scandir($dir), array('.','..'));
79 foreach ($files as $file) {
80 if(is_dir($dir . '/' . $file)){
81 if(! self::recursiveDelete($dir . '/' . $file)){
82 return false;
83 }
84 } else {
85 if($file == 'clear.lock'){ continue; } //Don't delete our lock file
86 $size = filesize($dir . '/' . $file);
87 if($size){
88 self::$cacheStats['totalData'] += round($size / 1024);
89 }
90 if(strpos($dir, 'wfcache/') === false){
91 self::$lastRecursiveDeleteError = "Not deleting file in directory $dir because it appears to be in the wrong path.";
92 self::$cacheStats['totalErrors']++;
93 return false; //Safety check that we're in a subdir of the cache
94 }
95 if(@unlink($dir . '/' . $file)){
96 self::$cacheStats['filesDeleted']++;
97 } else {
98 self::$lastRecursiveDeleteError = "Could not delete file " . $dir . "/" . $file . " : " . wfUtils::getLastError();
99 self::$cacheStats['totalErrors']++;
100 return false;
101 }
102 }
103 }
104 if($dir != WP_CONTENT_DIR . '/wfcache/'){
105 if(strpos($dir, 'wfcache/') === false){
106 self::$lastRecursiveDeleteError = "Not deleting directory $dir because it appears to be in the wrong path.";
107 self::$cacheStats['totalErrors']++;
108 return false; //Safety check that we're in a subdir of the cache
109 }
110 if(@rmdir($dir)){
111 self::$cacheStats['dirsDeleted']++;
112 } else {
113 self::$lastRecursiveDeleteError = "Could not delete directory $dir : " . wfUtils::getLastError();
114 self::$cacheStats['totalErrors']++;
115 return false;
116 }
117 return true;
118 } else {
119 return true;
120 }
121 }
122 public static function addHtaccessCode($action){
123 if($action != 'remove'){
124 die("Error: addHtaccessCode must be called with 'remove' as param");
125 }
126 $htaccessPath = self::getHtaccessPath();
127 if(! $htaccessPath){
128 return "Wordfence could not find your .htaccess file.";
129 }
130 $fh = @fopen($htaccessPath, 'r+');
131 if(! $fh){
132 $err = error_get_last();
133 return $err['message'];
134 }
135 flock($fh, LOCK_EX);
136 fseek($fh, 0, SEEK_SET); //start of file
137 clearstatcache();
138 $contents = fread($fh, filesize($htaccessPath));
139 if(! $contents){
140 fclose($fh);
141 return "Could not read from $htaccessPath";
142 }
143 $contents = preg_replace('/#WFCACHECODE.*WFCACHECODE[\r\s\n\t]*/s', '', $contents);
144 ftruncate($fh, 0);
145 fflush($fh);
146 fseek($fh, 0, SEEK_SET);
147 fwrite($fh, $contents);
148 flock($fh, LOCK_UN);
149 fclose($fh);
150 return false;
151 }
152
153 /**
154 * @param $action
155 * @return bool|string|void
156 */
157 public static function updateBlockedIPs($action){ //'add' or 'remove'
158 $htaccessPath = self::getHtaccessPath();
159 if(! $htaccessPath){
160 return "Wordfence could not find your .htaccess file.";
161 }
162 if($action == 'remove'){
163 $fh = @fopen($htaccessPath, 'r+');
164 if(! $fh){
165 $err = error_get_last();
166 return $err['message'];
167 }
168 flock($fh, LOCK_EX);
169 fseek($fh, 0, SEEK_SET); //start of file
170 clearstatcache();
171 $contents = @fread($fh, filesize($htaccessPath));
172 if(! $contents){
173 fclose($fh);
174 return "Could not read from $htaccessPath";
175 }
176
177 $contents = preg_replace('/#WFIPBLOCKS.*WFIPBLOCKS[\r\s\n\t]*/s', '', $contents);
178
179 ftruncate($fh, 0);
180 fflush($fh);
181 fseek($fh, 0, SEEK_SET);
182 @fwrite($fh, $contents);
183 flock($fh, LOCK_UN);
184 fclose($fh);
185 return false;
186 }
187 return false;
188 }
189 public static function getHtaccessPath(){
190 if (!function_exists('get_home_path')) {
191 include_once(ABSPATH . 'wp-admin/includes/file.php');
192 }
193
194 $homePath = get_home_path();
195 $htaccessFile = $homePath.'.htaccess';
196 return $htaccessFile;
197 }
198 public static function doNotCache(){
199 if(! defined('WFDONOTCACHE')){
200 define('WFDONOTCACHE', true);
201 }
202 }
203 }
204