From 77647a9d31fd4e7b49347711c313252f7771cf00 Mon Sep 17 00:00:00 2001 From: Ralf Becker Date: Mon, 21 Nov 2011 09:51:15 +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 8375ce90a1..9b8fef6cdd 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; @@ -378,12 +378,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() &&