2 /************************************************************************
3 * Mailer v0.2.1-FINAL Start: 06/02/2011 *
4 * =================== Last change: 06/02/2011 *
6 * -------------------------------------------------------------------- *
8 * -------------------------------------------------------------------- *
9 * Short description : Filters for ext- *
10 * -------------------------------------------------------------------- *
11 * Kurzbeschreibung : Filter fuer ext- *
12 * -------------------------------------------------------------------- *
15 * $Tag:: 0.2.1-FINAL $ *
17 * -------------------------------------------------------------------- *
18 * Copyright (c) 2003 - 2009 by Roland Haeder *
19 * Copyright (c) 2009 - 2012 by Mailer Developer Team *
20 * For more information visit: http://mxchange.org *
22 * This program is free software; you can redistribute it and/or modify *
23 * it under the terms of the GNU General Public License as published by *
24 * the Free Software Foundation; either version 2 of the License, or *
25 * (at your option) any later version. *
27 * This program is distributed in the hope that it will be useful, *
28 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
29 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
30 * GNU General Public License for more details. *
32 * You should have received a copy of the GNU General Public License *
33 * along with this program; if not, write to the Free Software *
34 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, *
36 ************************************************************************/
38 // Some security stuff...
39 if (!defined('__SECURITY')) {
43 // Destroy the cache on extension changes
44 function FILTER_CACHE_DESTROY_ON_EXT_CHANGE ($filterData) {
45 // Return the data anyway if there is no cache extension
46 //* DEBUG: */ logDebugMessage(__FUNCTION__, __LINE__, 'Called!');
47 if (!isCacheInstanceValid()) {
52 foreach (array('config', 'extension', 'filter', 'modules', 'earning', 'points_data') as $cache) {
53 // Is this cache there?
54 if ($GLOBALS['cache_instance']->loadCacheFile($cache)) {
55 // Yes, then remove it
56 $GLOBALS['cache_instance']->removeCacheFile();
61 //* DEBUG: */ logDebugMessage(__FUNCTION__, __LINE__, 'Done!');
65 // Destroy the cache on changing admin
66 function FILTER_CACHE_DESTROY_ON_ADMIN_CHANGE ($filterData) {
67 // Skip this step if the cache instance is not there
68 //* DEBUG: */ logDebugMessage(__FUNCTION__, __LINE__, 'Called!');
69 if (!isCacheInstanceValid()) {
74 if ($GLOBALS['cache_instance']->loadCacheFile('admin')) {
75 $GLOBALS['cache_instance']->removeCacheFile();
79 //* DEBUG: */ logDebugMessage(__FUNCTION__, __LINE__, 'Done!');
83 // Destroy all cache files
84 function FILTER_CACHE_DESTROY_ALL ($filterData) {
85 // Skip this step if the cache instance is not there
86 //* DEBUG: */ logDebugMessage(__FUNCTION__, __LINE__, 'Called!');
87 if (!isCacheInstanceValid()) {
92 foreach (array('admin', 'admin_acls', 'config', 'extension', 'earning', 'filter', 'imprint', 'modules', 'payments', 'points_data', 'refdepths', 'refsystem', 'themes') as $cache) {
93 // Is the cache file readable?
94 // @TODO This should be rewritten not to load the cache file for just checking if it is there for save removal.
95 if ($GLOBALS['cache_instance']->loadCacheFile($cache)) {
96 // Remove the cache file
97 $GLOBALS['cache_instance']->removeCacheFile();
101 //* DEBUG: */ logDebugMessage(__FUNCTION__, __LINE__, 'Done!');
105 // Filter for purging 'filter' cache
106 function FILTER_CACHE_DESTROY_FILTER ($filterData) {
107 // Skip this step if the cache instance is not there
108 //* DEBUG: */ logDebugMessage(__FUNCTION__, __LINE__, 'Called!');
109 if ((!isCacheInstanceValid()) || ((isConfigEntrySet('update_filter_usage')) && (getConfig('update_filter_usage') != 'Y'))) {
113 // Remove cache files
114 rebuildCache('filter', 'filter');
116 //* DEBUG: */ logDebugMessage(__FUNCTION__, __LINE__, 'Done!');