From 2d7584d459656adcc1e72725d42e83f40fcfd2ed Mon Sep 17 00:00:00 2001 From: Ralf Becker Date: Mon, 21 Nov 2011 09:50:02 +0000 Subject: [PATCH] only check for class.$classname.inc.php files, when scanning for plugins, as backupfiles postfixing the filename with an other extension stall EGroupware completly (Fatal Error: Can not redeclar class) --- .../inc/class.importexport_helper_functions.inc.php | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/importexport/inc/class.importexport_helper_functions.inc.php b/importexport/inc/class.importexport_helper_functions.inc.php index 7f62f2582a..7efc1b046c 100755 --- a/importexport/inc/class.importexport_helper_functions.inc.php +++ b/importexport/inc/class.importexport_helper_functions.inc.php @@ -124,7 +124,7 @@ class importexport_helper_functions { $account_ids[] = $account_id; continue; } - + // Handle groups listed as Group, if ( $account_lid[0] == ' ' && $account_id = $GLOBALS['egw']->accounts->name2id( trim($account_lid))) { $account_ids[] = $account_id; @@ -381,12 +381,12 @@ class importexport_helper_functions { while (false !== ($entry = $d->read())) { // Blacklisted? if(is_array(self::$blacklist_files[$appname]) && in_array($entry, self::$blacklist_files[$appname])) continue; - - list( ,$classname, ,$extension) = explode('.',$entry); + if (!preg_match('/^class\.([^.]+)\.inc\.php$/', $entry, $matches)) continue; + $classname = $matches[1]; $file = $appdir. '/'. $entry; foreach ($types as $type) { - if( !is_file($file) || strpos($entry, $type) === false || $extension != 'php' ) continue; + if( !is_file($file) || strpos($entry, $type) === false) continue; require_once($file); $reflectionClass = new ReflectionClass($classname); if($reflectionClass->IsInstantiable() &&