db_Select("plugin","*","plugin_installflag = ".(int)$flag." ORDER BY plugin_path ASC")) { $ret = $sql->db_getList(); return $ret; } return false; } /** * Check for new plugins, create entry in plugin table and remove deleted plugins */ function update_plugins_table() { $sql = e107::getDb(); $sql2 = e107::getDb('sql2'); $tp = e107::getParser(); $fl = e107::getFile(); global $mySQLprefix, $menu_pref, $pref; $pluginList = $fl->get_files(e_PLUGIN, "^plugin\.(php|xml)$", "standard", 1); $sp = FALSE; // Read all the plugin DB info into an array to save lots of accesses $pluginDBList = array(); if ($sql->db_Select('plugin',"*")) { while ($row = $sql->db_Fetch(MYSQL_ASSOC)) { $pluginDBList[$row['plugin_path']] = $row; $pluginDBList[$row['plugin_path']]['status'] = 'read'; // echo "Found plugin: ".$row['plugin_path']." in DB
"; } } $i = 1; while ( $i < count($pluginList)) { if ($pluginList[$i-1]['path'] == $pluginList[$i]['path']) // Must have plugin.php and plugin.xml { if (($pluginList[$i-1]['fname'] == 'plugin.php') && ($pluginList[$i]['fname'] == 'plugin.xml')) { // echo "deleting: {$pluginList[$i-1]['path']}
"; unset($pluginList[$i-1]); $i++; } if (($pluginList[$i]['fname'] == 'plugin.php') && ($pluginList[$i-1]['fname'] == 'plugin.xml')) { // echo "deleting: {$pluginList[$i]['path']}
"; unset($pluginList[$i]); $i++; } } $i++; } $p_installed = e107::getPref('plug_installed',array()); // load preference; require_once(e_HANDLER."message_handler.php"); $emessage = &eMessage::getInstance(); foreach($pluginList as $p) { $p['path'] = substr(str_replace(e_PLUGIN,"",$p['path']),0,-1); $plugin_path = $p['path']; if(strpos($plugin_path,'e107_')!==FALSE) { $emessage->add("Folder error: {$p['path']}. 'e107_' is not permitted within plugin folder names.", E_MESSAGE_WARNING); continue; } $plug['plug_action'] = 'scan'; // Make sure plugin.php knows what we're up to if(!$this->parse_plugin($p['path'])) { //parsing of plugin.php/plugin.xml failed. $emessage->add("Parsing failed - file format error: {$p['path']}", E_MESSAGE_ERROR); continue; // Carry on and do any others that are OK } $plug_info = $this->plug_vars; // $plugin_path = substr(str_replace(e_PLUGIN,"",$p['path']),0,-1); // scan for addons. $eplug_addons = $this->getAddons($plugin_path); // Returns comma-separated list // $eplug_addons = $this->getAddons($plugin_path,'check'); // Checks opening/closing tags on addon files //Ensure the plugin path lives in the same folder as is configured in the plugin.php/plugin.xml if ($plugin_path == $plug_info['folder']) { if(array_key_exists($plugin_path, $pluginDBList)) { // Update the addons needed by the plugin $pluginDBList[$plugin_path]['status'] = 'exists'; // Check for missing plugin_category in plugin table. if ($pluginDBList[$plugin_path]['plugin_category'] == '') { // print_a($plug_info); $pluginDBList[$plugin_path]['status'] = 'update'; $pluginDBList[$plugin_path]['plugin_category'] = (varsettrue($plug_info['category']) ) ? $plug_info['category'] : "misc"; } // If plugin not installed, and version number of files changed, update version as well if (($pluginDBList[$plugin_path]['plugin_installflag'] == 0) && ($pluginDBList[$plugin_path]['plugin_version'] != $plug_info['@attributes']['version'])) { // Update stored version $pluginDBList[$plugin_path]['plugin_version'] = $plug_info['@attributes']['version']; $pluginDBList[$plugin_path]['status'] = 'update'; } if ($pluginDBList[$plugin_path]['plugin_addons'] != $eplug_addons) { // Update stored addons list $pluginDBList[$plugin_path]['plugin_addons'] = $eplug_addons; $pluginDBList[$plugin_path]['status'] = 'update'; } if ($pluginDBList[$plugin_path]['plugin_installflag'] == 0 ) // Plugin not installed - make sure $pref not set { if(isset($p_installed[$plugin_path])) { unset($p_installed[$plugin_path]); $sp = TRUE; } } else { // Plugin installed - make sure $pref is set if (!isset($p_installed[$plugin_path]) || ($p_installed[$plugin_path] != $pluginDBList[$plugin_path]['plugin_version'])) { // Update prefs array of installed plugins $p_installed[$plugin_path] = $pluginDBList[$plugin_path]['plugin_version']; // echo "Add: ".$plugin_path."->".$ep_row['plugin_version']."
"; $sp = TRUE; } } } else { // New plugin - not in table yet, so add it. If no install needed, mark it as 'installed' //SecretR - update to latest XML version if ($plug_info['@attributes']['name']) { // echo "New plugin to add: {$plug_info['name']}
"; // Can just add to DB - shouldn't matter that its not in our current table // echo "Trying to insert: ".$eplug_folder."
"; $_installed = ($plug_info['@attributes']['installRequired'] == 'true' || $plug_info['@attributes']['installRequired'] == 1 ? 0 : 1 ); e107::getDb()->db_Insert("plugin", "0, '".$tp -> toDB($plug_info['@attributes']['name'], true)."', '".$tp -> toDB($plug_info['@attributes']['version'], true)."', '".$tp -> toDB($plugin_path, true)."', {$_installed}, '{$eplug_addons}', '".$this->manage_category($plug_info['category'])."', '".varset($plug_info['@attributes']['releaseUrl'])."' "); } } } else { // May be useful that we ignore what will usually be copies/backups of plugins - but don't normally say anything // echo "Plugin copied to wrong directory. Is in: {$plugin_path} Should be: {$plug_info['folder']}

"; } // print_a($plug_info); } // Now scan the table, updating the DB where needed foreach ($pluginDBList as $plug_path => $plug_info) { if ($plug_info['status'] == 'read') { // In table, not on server - delete it $sql->db_Delete('plugin', "`plugin_id`={$plug_info['plugin_id']}"); // echo "Deleted: ".$plug_path."
"; } if ($plug_info['status'] == 'update') { $temp = array(); foreach ($this->all_editable_db_fields as $p_f) { $temp[] ="`{$p_f}` = '{$plug_info[$p_f]}'"; } $sql->db_Update('plugin', implode(", ",$temp)." WHERE `plugin_id`={$plug_info['plugin_id']}"); // echo "Updated: ".$plug_path."
"; } } if ($sp && vartrue($p_installed)) { e107::getConfig('core')->setPref('plug_installed',$p_installed); e107::getConfig('core')->save(); } } function manage_category($cat) { if(vartrue($cat) && in_array($cat,$this->accepted_categories)) { return $cat; } else { return 'misc'; } } function manage_icons($plugin='') { global $iconpool,$pref; $sql = e107::getDb(); $tp = e107::getParser(); $fl = e107::getFile(); $query = "SELECT * FROM #plugin WHERE plugin_installflag =0 ORDER BY plugin_path ASC"; $sql->db_Select_gen($query); $list = $sql->db_getList(); $reject_core = array('$.','$..','/','CVS','thumbs.db','*._$', 'index', 'null*'); $reject_plugin = $reject_core; foreach($list as $val) // reject uninstalled plugin folders. { $reject_plugin[] = $val['plugin_path']."/images"; } $filesrch = implode("|",array("_16.png","_16.PNG","_32.png","_32.PNG","_48.png","_48.PNG","_64.png","_64.PNG","_128.png","_128.png")); if($plugin_icons = $fl->get_files(e_PLUGIN,$filesrch,$reject_plugin,2)) { sort($plugin_icons); } if($core_icons = $fl->get_files(e_IMAGE."icons/",$filesrch,$reject_core,2)) { sort($core_icons); } if($theme_icons = $fl->get_files(e_THEME.$pref['sitetheme']."/images/",$filesrch,$reject_core,2)) { sort($theme_icons); } $srch = array(e_IMAGE,"/"); $repl = array("","-"); $iconpool = array(); foreach($core_icons as $file) { $path = str_replace($srch,$repl,$file['path']); $key = substr("core-".$path,0,-1); $iconpool[$key][] = $tp->createConstants($file['path'],1).$file['fname']; } $srch = array(e_PLUGIN,"/images/","/icons/","/icon/"); $repl = array("","",""); foreach($plugin_icons as $file) { $path = str_replace($srch,$repl,$file['path']); $key = "plugin-".$path; $iconpool[$key][] = $tp->createConstants($file['path'],1).$file['fname']; } $srch = array(e_THEME,"/images/","/icons/","/demo/"); $repl = array("","",""); foreach($theme_icons as $file) { $path = str_replace($srch,$repl,$file['path']); $key = "theme-".$path; $iconpool[$key][] = $tp->createConstants($file['path'],1).$file['fname']; } e107::getConfig('ipool')->setPref($iconpool); return (e107::getConfig('ipool')->save(FALSE)) ? TRUE : FALSE; } /** * Returns details of a plugin from the plugin table from it's ID * * @param int $id * @return array plugin info */ function getinfo($id, $force=false) { $sql = e107::getDb(); static $getinfo_results; if(!is_array($getinfo_results)) { $getinfo_results = array(); } $id = (int)$id; if(!isset($getinfo_results[$id]) || $force == true) { if ($sql->db_Select('plugin', '*', "plugin_id = ".$id)) { $getinfo_results[$id] = $sql->db_Fetch(); } else { return false; } } return $getinfo_results[$id]; } function manage_extended_field($action, $field_name, $field_type, $field_default, $field_source) { if(!isset($this->module['ue'])) { include_once(e_HANDLER.'user_extended_class.php'); $this->module['ue'] = new e107_user_extended; } $type = constant($field_type); if($action == 'add') { return $this->module['ue']->user_extended_add_system($field_name, $type, $field_default, $field_source); } if ($action == 'remove') { return $this->module['ue']->user_extended_remove($field_name, $field_name); } } function manage_userclass($action, $class_name, $class_description) { global $e107; $tp = e107::getParser(); $sql = e107::getDb(); if (!$e107->user_class->isAdmin) { $e107->user_class = new user_class_admin; // We need the extra methods of the admin extension } $class_name = strip_tags(strtoupper($class_name)); if ($action == 'add') { if ($e107->user_class->ucGetClassIDFromName($class_name) !== FALSE) { // Class already exists. return TRUE; // That's probably OK } $i = $e107->user_class->findNewClassID(); if ($i !== FALSE) { $tmp = array(); $tmp['userclass_id'] = $i; $tmp['userclass_name'] = $class_name; $tmp['userclass_description'] = $class_description; $tmp['userclass_editclass'] = e_UC_ADMIN; $tmp['userclass_visibility'] = e_UC_ADMIN; $tmp['userclass_type'] = UC_TYPE_STD; $tmp['userclass_parent'] = e_UC_NOBODY; $tmp['_FIELD_TYPES']['userclass_editclass'] = 'int'; $tmp['_FIELD_TYPES']['userclass_visibility'] = 'int'; $tmp['_FIELD_TYPES']['userclass_id'] = 'int'; $tmp['_FIELD_TYPES']['_DEFAULT'] = 'todb'; return $e107->user_class->add_new_class($tmp); } else { return FALSE; } } if ($action == 'remove') { $classID = $e107->user_class->ucGetClassIDFromName($class_name); if (($classID !== FALSE) && ($e107->user_class->deleteClassAndUsers($classID) === TRUE)) { return TRUE; } else { return FALSE; } } } function manage_link($action, $link_url, $link_name, $link_class = 0) { $sql = e107::getDb(); $tp = e107::getParser(); if( ! is_numeric($link_class)) { $link_class = strtolower($link_class); $plug_perm['everyone'] = e_UC_PUBLIC; $plug_perm['guest'] = e_UC_GUEST; $plug_perm['member'] = e_UC_MEMBER; $plug_perm['mainadmin'] = e_UC_MAINADMIN; $plug_perm['admin'] = e_UC_ADMIN; $plug_perm['nobody'] = e_UC_NOBODY; $link_class = ($plug_perm[$link_class]) ? $plug_perm[$link_class] : e_UC_PUBLIC; } $link_url = $tp -> toDB($link_url, true); $link_name = $tp -> toDB($link_name, true); $path = str_replace("../", "", $link_url); // This should clean up 'non-standard' links $path = $tp->createConstants($path); // Add in standard {e_XXXX} directory constants if we can if ($action == 'add') { $link_t = $sql->db_Count('links'); if (!$sql->db_Count('links', '(*)', "WHERE link_url = '{$path}' OR link_name = '{$link_name}'")) { return $sql->db_Insert('links', "0, '{$link_name}', '{$path}', '', '', '1', '".($link_t + 1)."', '0', '0', '{$link_class}' "); } else { return FALSE; } } if ($action == 'remove') { // Look up by URL if we can - should be more reliable. Otherwise try looking up by name (as previously) if (($path && $sql->db_Select('links', 'link_id,link_order', "link_url = '{$path}'")) || $sql->db_Select('links', 'link_id,link_order', "link_name = '{$link_name}'")) { $row = $sql->db_Fetch(); $sql->db_Update('links', "link_order = link_order - 1 WHERE link_order > {$row['link_order']}"); return $sql->db_Delete('links', "link_id = {$row['link_id']}"); } } } // Update prefs array according to $action // $prefType specifies the storage type - may be 'pref', 'listPref' or 'arrayPref' function manage_prefs($action, $var, $prefType = 'pref', $path = '', $unEscape = FALSE) { global $pref; if (!is_array($var)) return; if (($prefType == 'arrayPref') && ($path == '')) return; foreach($var as $k => $v) { if ($unEscape) { $v = str_replace(array('\{','\}'),array('{','}'),$v); } switch ($prefType) { case 'pref' : switch ($action) { case 'add' : $pref[$k] = $v; break; case 'update' : case 'refresh' : // Only update if $pref doesn't exist if (!isset($pref[$k])) $pref[$k] = $v; break; case 'remove' : if (is_numeric($k)) { // Sometimes arrays specified with value being the name of the key to delete unset($pref[$var[$k]]); } else { // This is how the array should be specified - key is the name of the pref unset($pref[$k]); } break; } break; case 'listPref' : $tmp = array(); if (isset($pref[$k])) $tmp = explode(',',$pref[$k]); switch ($action) { case 'add' : case 'update' : case 'refresh' : if (!in_array($v,$tmp)) $tmp[] = $v; break; case 'remove' : if (($tkey = array_search($v,$tmp)) !== FALSE) unset($tmp[$tkey]); break; } $pref[$k] = implode(',',$tmp); // Leaves an empty element if no values - probably acceptable or even preferable break; case 'arrayPref' : switch($action) { case 'add' : $pref[$k][$path] = $v; break; case 'update' : case 'refresh' : if (!isset($pref[$k][$path])) $pref[$k][$path] = $v; break; case 'remove' : if (isset($pref[$k][$path])) unset($pref[$k][$path]); // Leaves an empty element if no values - probably acceptable or even preferable break; } break; } } e107::getConfig('core')->setPref($pref)->save(); // e107::getConfig()->loadData($pref, false)->save(false, true); } function manage_comments($action, $comment_id) { $sql = e107::getDb(); $tp = e107::getParser(); $tmp = array(); if($action == 'remove') { foreach($comment_id as $com) { $tmp[] = "comment_type='".$tp -> toDB($com, true)."'"; } $qry = implode(" OR ",$tmp); // echo $qry."
"; return $sql->db_Delete('comments', $qry); } } // Handle table updates - passed an array of actions. // $var array: // For 'add' - its a query to create the table // For 'upgrade' - its a query to modify the table (not called from the plugin.xml handler) // For 'remove' - its a table name // 'upgrade' and 'remove' operate on all language variants of the same table function manage_tables($action, $var) { $sql = e107::getDB(); if (!is_array($var)) return FALSE; // Return if nothing to do switch ($action) { case 'add' : foreach($var as $tab) { if (!$sql->db_Query($tab)) { return FALSE; } } return TRUE; break; case 'upgrade' : foreach($var as $tab) { if (!$sql->db_Query_all($tab)) { return FALSE; } } return TRUE; break; case 'remove' : foreach($var as $tab) { $qry = 'DROP TABLE '.MPREFIX.$tab; if (!$sql->db_Query_all($qry)) { return $tab; } } return TRUE; break; } return FALSE; } // Handle prefs from arrays (mostly 0.7 stuff, possibly apart from the special cases) function manage_plugin_prefs($action, $prefname, $plugin_folder, $varArray = '') { // These prefs are 'cumulative' - several plugins may contribute an array element // global $pref; /* if ($prefname == 'plug_sc' || $prefname == 'plug_bb') { // Special cases - shortcodes and bbcodes - each plugin may contribute several elements foreach($varArray as $code) { $prefvals[] = "$code:$plugin_folder"; } } else { */ $prefvals[] = $varArray; // $prefvals[] = $plugin_folder; // } $curvals = explode(',', $pref[$prefname]); if ($action == 'add') { $newvals = array_merge($curvals, $prefvals); } if ($action == 'remove') { foreach($prefvals as $v) { if (($i = array_search($v, $curvals)) !== FALSE) { unset($curvals[$i]); } } $newvals = $curvals; } $newvals = array_unique($newvals); $pref[$prefname] = implode(',', $newvals); if(substr($pref[$prefname], 0, 1) == ",") { $pref[$prefname] = substr($pref[$prefname], 1); } e107::getConfig('core')->setPref($pref); e107::getConfig('core')->save(); // save_prefs(); //FIXME - should be a better way to do this. // e107::getConfig()->loadData($pref, false)->save(false, true); } function manage_search($action, $eplug_folder) { global $sysprefs; $sql = e107::getDb(); $search_prefs = e107::getConfig('search')->getPref(); // $search_prefs = $sysprefs -> getArray('search_prefs'); $default = file_exists(e_PLUGIN.$eplug_folder.'/e_search.php') ? TRUE : FALSE; $comments = file_exists(e_PLUGIN.$eplug_folder.'/search/search_comments.php') ? TRUE : FALSE; if ($action == 'add') { $install_default = $default ? TRUE : FALSE; $install_comments = $comments ? TRUE : FALSE; } else if ($action == 'remove') { $uninstall_default = isset($search_prefs['plug_handlers'][$eplug_folder]) ? TRUE : FALSE; $uninstall_comments = isset($search_prefs['comments_handlers'][$eplug_folder]) ? TRUE : FALSE; } else if ($action == 'upgrade') { if (isset($search_prefs['plug_handlers'][$eplug_folder])) { $uninstall_default = $default ? FALSE : TRUE; } else { $install_default = $default ? TRUE : FALSE; } if (isset($search_prefs['comments_handlers'][$eplug_folder])) { $uninstall_comments = $comments ? FALSE : TRUE; } else { $install_comments = $comments ? TRUE : FALSE; } } if (vartrue($install_default)) { $search_prefs['plug_handlers'][$eplug_folder] = array('class' => 0, 'pre_title' => 1, 'pre_title_alt' => '', 'chars' => 150, 'results' => 10); } else if (vartrue($uninstall_default)) { unset($search_prefs['plug_handlers'][$eplug_folder]); } if (vartrue($install_comments)) { require_once(e_PLUGIN.$eplug_folder.'/search/search_comments.php'); $search_prefs['comments_handlers'][$eplug_folder] = array('id' => $comments_type_id, 'class' => 0, 'dir' => $eplug_folder); } else if (vartrue($uninstall_comments)) { unset($search_prefs['comments_handlers'][$eplug_folder]); } e107::getConfig('search')->setPref($search_prefs)->save(); } function manage_notify($action, $eplug_folder) { $tp = e107::getParser(); // $notify_prefs = $sysprefs -> get('notify_prefs'); // $notify_prefs = $eArrayStorage -> ReadArray($notify_prefs); $notify_prefs = e107::getConfig('notify'); $e_notify = file_exists(e_PLUGIN.$eplug_folder.'/e_notify.php') ? TRUE : FALSE; if ($action == 'add') { $install_notify = $e_notify ? TRUE : FALSE; } else if ($action == 'remove') { $uninstall_notify = $notify_prefs->isData('plugins/'.$eplug_folder);//isset($notify_prefs['plugins'][$eplug_folder]) ? TRUE : FALSE; } else if ($action == 'upgrade') { if ($notify_prefs->isData('plugins/'.$eplug_folder)) { $uninstall_notify = $e_notify ? FALSE : TRUE; } else { $install_notify = $e_notify ? TRUE : FALSE; } } if (vartrue($install_notify)) { $notify_prefs->setPref('plugins/'.$eplug_folder, 1); //$notify_prefs['plugins'][$eplug_folder] = TRUE; require_once(e_PLUGIN.$eplug_folder.'/e_notify.php'); foreach ($config_events as $event_id => $event_text) { $notify_prefs->setPref('event/'.$event_id.'/class', e_UC_NOBODY) ->setPref('event/'.$event_id.'/email', ''); //$notify_prefs['event'][$event_id] = array('class' => e_UC_NOBODY, 'email' => ''); } } else if (vartrue($uninstall_notify)) { $notify_prefs->removePref('plugins/'.$eplug_folder); //unset($notify_prefs['plugins'][$eplug_folder]); require_once(e_PLUGIN.$eplug_folder.'/e_notify.php'); foreach ($config_events as $event_id => $event_text) { $notify_prefs->removePref('event/'.$event_id); //unset($notify_prefs['event'][$event_id]); } } //$s_prefs = $tp -> toDB($notify_prefs); //$s_prefs = e107::getArrayStorage()->WriteArray($s_prefs); //e107::getDb() -> db_Update("core", "e107_value='".$s_prefs."' WHERE e107_name='notify_prefs'"); $notify_prefs->save(false); } function displayArray(&$array, $msg='') { $txt = ($msg ? $msg.'
' : ''); foreach($array as $_k => $_v) { $txt .= "{$_k} -> {$_v}
"; } $txt .='
'; return $txt; } //---------------------------------------------------------- // Install routine for XML file //---------------------------------------------------------- // $id - the number of the plugin in the DB // Values for $function: // 'install' // 'upgrade' // 'uninstall' // 'refresh' - adds things that are missing, but doesn't change any existing settings // $options is an array of possible options - ATM used only for uninstall: // 'del_userclasses' - to delete userclasses created // 'del_tables' - to delete DB tables // 'del_extended' - to delete extended fields function manage_plugin_xml($id, $function='', $options = FALSE) { global $pref; $sql = e107::getDb(); $error = array(); // Array of error messages $canContinue = TRUE; // Clear flag if must abort part way through $id = (int)$id; $plug = $this->getinfo($id); // Get plugin info from DB $this->current_plug = $plug; $txt = ''; $path = e_PLUGIN.$plug['plugin_path'].'/'; $addons = explode(',', $plug['plugin_addons']); $sql_list = array(); foreach($addons as $addon) { if(substr($addon, -4) == '_sql') { $sql_list[] = $addon.'.php'; } } if(!file_exists($path.'plugin.xml') || $function == '') { $error[] = EPL_ADLAN_77; $canContinue = FALSE; } if($canContinue && $this->parse_plugin_xml($plug['plugin_path'])) { $plug_vars = $this->plug_vars; } else { $error[] = EPL_ADLAN_76; $canContinue = FALSE; } // First of all, see if there's a language file specific to install if (isset($plug_vars['installLanguageFile']) && isset($plug_vars['installLanguageFile']['@attributes']['filename'])) { include_lan($path.str_replace('--LAN--',e_LANGUAGE, $plug_vars['installLanguageFile']['@attributes']['filename'])); } // Next most important, if installing or upgrading, check that any dependencies are met if ($canContinue && ($function != 'uninstall') && isset($plug_vars['depends'])) { foreach ($plug_vars['depends'] as $dt => $dv) { if (isset($dv['@attributes']) && isset($dv['@attributes']['name'])) { // echo "Check {$dt} dependency: {$dv['@attributes']['name']} version {$dv['@attributes']['min_version']}
"; switch ($dt) { case 'plugin' : if (!isset($pref['plug_installed'][$dv['@attributes']['name']])) { // Plugin not installed $canContinue = FALSE; $error[] = EPL_ADLAN_70.$dv['@attributes']['name']; } elseif (isset($dv['@attributes']['min_version']) && (version_compare($dv['@attributes']['min_version'],$pref['plug_installed'][$dv['@attributes']['name']],'<=') === FALSE)) { $error[] = EPL_ADLAN_71.$dv['@attributes']['name'].EPL_ADLAN_72.$dv['@attributes']['min_version']; $canContinue = FALSE; } break; case 'extension' : if (!extension_loaded($dv['@attributes']['name'])) { $canContinue = FALSE; $error[] = EPL_ADLAN_73.$dv['@attributes']['name']; } elseif (isset($dv['@attributes']['min_version']) && (version_compare($dv['@attributes']['min_version'],phpversion($dv['@attributes']['name']),'<=') === FALSE)) { $error[] = EPL_ADLAN_71.$dv['@attributes']['name'].EPL_ADLAN_72.$dv['@attributes']['min_version']; $canContinue = FALSE; } break; case 'PHP' : if (isset($dv['@attributes']['min_version']) && (version_compare($dv['@attributes']['min_version'],phpversion(),'<=') === FALSE)) { $error[] = EPL_ADLAN_74.$dv['@attributes']['min_version']; $canContinue = FALSE; } break; case 'MySQL' : if (isset($dv['@attributes']['min_version']) && (version_compare($dv['@attributes']['min_version'],mysql_get_server_info(),'<=') === FALSE)) { $error[] = EPL_ADLAN_75.$dv['@attributes']['min_version']; $canContinue = FALSE; } break; default : echo "Unknown dependency: {$dt}
"; } } } } // Temporary error handling - need to do something with this if (!$canContinue) { echo ''.LAN_INSTALL_FAIL.'
'.implode('
',$error); return false; } // All the dependencies are OK - can start the install now if ($canContinue) { // Let's call any custom pre functions defined in section $ret = $this->execute_function($path, $function, 'pre'); if (!is_bool($ret)) $txt .= $ret; } if ($canContinue && count($sql_list)) { // Handle tables require_once(e_HANDLER.'db_table_admin_class.php'); $dbHandler = new db_table_admin; foreach($sql_list as $sqlFile) { $tableList = $dbHandler->get_table_def('',$path.$sqlFile); if (!is_array($tableList)) { $error[] = 'Can\'t read SQL definition: '.$path.$sqlFile; break; } // Got the required definition here foreach ($tableList as $ct) { // Process one table at a time (but they could be multi-language) switch($function) { case 'install' : $sqlTable = str_replace("CREATE TABLE ".MPREFIX.'`', "CREATE TABLE `".MPREFIX, preg_replace("/create table\s+/si", "CREATE TABLE ".MPREFIX, $ct[0])); $txt .= "Adding table: {$ct[1]} ... "; $result = $this->manage_tables('add', array($sqlTable)); // Pass the statement to create the table $txt .= ($result ? "Success" : "Failed!").'
'; break; case 'upgrade' : $tmp = $dbHandler->update_table_structure($ct,FALSE,TRUE, $pref['multilanguage']); if ($tmp === FALSE) { $error[] = 'Error updating table: '.$ct[1]; } elseif ($tmp !== TRUE) { $error[] = $tmp; } break; case 'refresh' : // Leave things alone break; case 'uninstall' : if (varsettrue($options['del_tables'], FALSE)) { $txt .= "Removing table {$ct[1]}
"; $this->manage_tables('remove', array($ct[1])); // Delete the table } else { $txt .= "Table {$ct[1]} left in place
"; } break; } } } } //main menu items if(isset($plug_vars['menuLink'])) { foreach($plug_vars['menuLink'] as $link) { $attrib = $link['@attributes']; $linkName = $attrib['name']; if (defined($linkName)) { $linkName = constant($linkName); } switch($function) { case 'upgrade': case 'install': // Add any active link if(!isset($attrib['active']) || $attrib['active'] == 'true') { $addlink = e_PLUGIN.$attrib['url']; $perm = (isset($attrib['perm']) ? $attrib['perm'] : 0); $txt .= "Adding link {$linkName} with url [{$addlink}] and perm {$perm}
"; $this->manage_link('add', $addlink, $linkName, $perm); } //remove inactive links on upgrade if($function == 'upgrade' && isset($attrib['active']) && $attrib['active'] == 'false') { $txt .= "Removing link {$linkName} with url [{$attrib['url']}]
"; $this->manage_link('remove', $attrib['url'], $linkName); } break; case 'refresh' : // Probably best to leave well alone break; case 'uninstall': //remove all links $txt .= "Removing link {$linkName} with url [{$attrib['url']}]
"; $this->manage_link('remove', $attrib['url'], $linkName); break; } } } //main pref items if(isset($plug_vars['mainPrefs'])) { foreach (array('pref','listPref','arrayPref') as $prefType) { if(isset($plug_vars['mainPrefs'][$prefType])) { $list = $this->parse_prefs($plug_vars['mainPrefs'][$prefType]); switch($function) { case 'install': if(varset($list['active']) && is_array($list['active'])) { $txt .= $this->displayArray($list['active'], "Adding '{$prefType}' prefs:"); $this->manage_prefs('add', $list['active'], $prefType, $plug['plugin_path'], TRUE); } break; case 'upgrade' : case 'refresh' : // Add any defined prefs which don't already exist if(varset($list['active']) && is_array($list['active'])) { $txt .= $this->displayArray($list['active'], "Updating '{$prefType}' prefs:"); $this->manage_prefs('update', $list['active'], $prefType, $plug['plugin_path'], TRUE); // This only adds prefs which aren't already defined } //If upgrading, removing any inactive pref if(varset($list['inactive']) && is_array($list['inactive'])) { $txt .= $this->displayArray($list['inactive'], "Removing '{$prefType}' prefs:"); $this->manage_prefs('remove', $list['inactive'], $prefType, $plug['plugin_path'], TRUE); } break; //If uninstalling, remove all prefs (active or inactive) case 'uninstall': if(varset($list['all']) && is_array($list['all'])) { $txt .= $this->displayArray($list['all'], "Removing '{$prefType}' prefs:"); $this->manage_prefs('remove', $list['all'], $prefType, $plug['plugin_path'], TRUE); } break; } } } } //Userclasses //$this->manage_userclass('add', $eplug_userclass, $eplug_userclass_description); if(isset($plug_vars['userclass'])) { $uclass_list = (isset($plug_vars['userclass'][0]) ? $plug_vars['userclass'] : array($plug_vars['userclass'])); foreach($uclass_list as $uclass) { $attrib = $uclass['@attributes']; switch($function) { case 'install' : case 'upgrade' : case 'refresh' : // Add all active userclasses (code checks for already installed) if(!isset($attrib['active']) || $attrib['active'] == 'true') { $txt .= 'Adding userclass '.$attrib['name'].'
'; $this->manage_userclass('add', $attrib['name'], $attrib['description']); } //If upgrading, removing any inactive userclass if($function == 'upgrade' && isset($attrib['active']) && $attrib['active'] == 'false') { $txt .= 'Removing userclass '.$attrib['name'].'
'; $this->manage_userclass('remove', $attrib['name'], $attrib['description']); } break; //If uninstalling, remove all userclasses (active or inactive) case 'uninstall': if (varsettrue($options['del_userclasses'], FALSE)) { $txt .= 'Removing userclass '.$attrib['name'].'
'; $this->manage_userclass('remove', $attrib['name'], $attrib['description']); } else { $txt .= 'userclass '.$attrib['name'].' left in place
'; } break; } } } //Extended user fields if(isset($plug_vars['extendedField'])) { $efield_list = (isset($plug_vars['extendedField'][0]) ? $plug_vars['extendedField'] : array($plug_vars['extendedFields'])); foreach($efield_list as $efield) { $attrib = $efield['@attributes']; $attrib['default'] = varset($attrib['default']); $attrib['name'] = 'plugin_'.$plug_vars['folder'].'_'.$attrib['name']; $source = 'plugin_'.$plug_vars['folder']; switch($function) { case 'install': case 'upgrade': // Add all active extended fields if(!isset($attrib['active']) || $attrib['active'] == 'true') { $txt .= 'Adding extended field: '.$attrib['name'].' ... '; $result = $this->manage_extended_field('add', $attrib['name'], $attrib['type'], $attrib['default'], $source); $txt .= ($result ? LAN_CREATED : LAN_CREATED_FAILED).'
'; } //If upgrading, removing any inactive extended fields if($function == 'upgrade' && isset($attrib['active']) && $attrib['active'] == 'false') { $txt .= 'Removing extended field: '.$attrib['name'].' ... '; $result = $this->manage_extended_field('remove', $attrib['name'], $source); $txt .= ($result ? LAN_DELETED : LAN_DELETED_FAILED).'
'; } break; //If uninstalling, remove all extended fields (active or inactive) case 'uninstall': if (varsettrue($options['del_extended'], FALSE)) { $txt .= 'Removing extended field: '.$attrib['name'].' ... '; $result = $this->manage_extended_field('remove', $attrib['name'], $source); $txt .= ($result ? LAN_DELETED : LAN_DELETED_FAILED).'
'; } else { $txt .= 'Extended field: '.$attrib['name'].' left in place
'; } break; } } } //If any commentIDs are configured, we need to remove all comments on uninstall if($function == 'uninstall' && isset($plug_vars['commentID'])) { $commentArray = (is_array($plug_vars['commentID']) ? $plug_vars['commentID'] : array($plug_vars['commentID'])); $txt .= 'Removing all plugin comments: ('.implode(', ', $commentArray).')
'; $this->manage_comments('remove', $commentArray); } $this->manage_search($function, $plug_vars['folder']); $this->manage_notify($function, $plug_vars['folder']); // Now any 'custom' values for update, language file definitions etc if (isset($plug_vars['management']['upgradeCheck'])) { $tmp = $plug_vars['management']['upgradeCheck']; switch ($function) { case 'install' : case 'upgrade' : case 'refresh' : $pref['upgradeCheck'][$plug['plugin_path']]['url'] = $tmp['@attributes']['url']; $pref['upgradeCheck'][$plug['plugin_path']]['method'] = varset($tmp['@attributes']['method'],'sf_news'); $pref['upgradeCheck'][$plug['plugin_path']]['id'] = varset($tmp['@attributes']['id'],$plug['plugin_path']); break; case 'uninstall' : unset($pref['upgradeCheck'][$plug['plugin_path']]); break; } unset($tmp); } if (isset($plug_vars['logLanguageFile'])) { switch ($function) { case 'install' : case 'upgrade' : case 'refresh' : $pref['logLanguageFile'][$plug['plugin_path']] = $plug_vars['logLanguageFile']['@attributes']['filename']; break; case 'uninstall' : if (isset($pref['logLanguageFile'][$plug['plugin_path']])) unset($pref['logLanguageFile'][$plug['plugin_path']]); break; } } e107::getConfig()->setPref($pref)->save(false); if ($canContinue) { // Let's call any custom post functions defined in section $ret = $this->execute_function($path, $function, 'post'); if (!is_bool($ret)) $txt .= $ret; } $eplug_addons = $this->getAddons($plug['plugin_path']); $p_installed = e107::getPref('plug_installed',array()); // load preference; if($function == 'install' || $function == 'upgrade') { $sql->db_Update('plugin', "plugin_installflag = 1, plugin_addons = '{$eplug_addons}', plugin_version = '{$plug_vars['@attributes']['version']}' WHERE plugin_id = ".$id); $p_installed[$plug['plugin_path']] = $plug_vars['@attributes']['version']; e107::getConfig('core')->setPref('plug_installed',$p_installed)->save(); } if($function == 'uninstall') { $sql->db_Update('plugin', "plugin_installflag = 0, plugin_addons = '{$eplug_addons}', plugin_version = '{$plug_vars['@attributes']['version']}' WHERE plugin_id = ".$id); unset($p_installed[$plug['plugin_path']]); e107::getConfig('core')->setPref('plug_installed',$p_installed)->save(); } if($function == 'install') { $txt .= LAN_INSTALL_SUCCESSFUL."
"; if(isset($plug_vars['installDone'])) { $txt .= $plug_vars['installDone']; } } return $txt; } function execute_function($path = '', $what='', $when='') { if($what == '' || $when == '') { return true; } if(!isset($this->plug_vars['management'][$what])) { return true; } $vars = $this->plug_vars['management'][$what]; if(count($vars) <= 1) { $vars = array($vars); } foreach($vars as $var) { $attrib = $var['@attributes']; if(isset($attrib['when']) && $attrib['when'] == $when) { if(is_readable($path.$attrib['file'])) { include_once($path.$attrib['file']); if($attrib['type'] == 'fileFunction') { $result = call_user_func($attrib['function'], $this); return $result; } elseif($attrib['type'] == 'classFunction') { $_tmp = new $attrib['class']; $result = call_user_func(array($_tmp, $attrib['function']), $this); return $result; } } } } } function parse_prefs($pref_array) { $ret = array(); if(!isset($pref_array[0])) { $pref_array = array($pref_array); } if(is_array($pref_array)) { foreach($pref_array as $k => $p) { $attrib = $p['@attributes']; if(isset($attrib['type']) && $attrib['type'] == 'array') { $name = $attrib['name']; $tmp = $this->parse_prefs($pref_array[$k]['key']); $ret['all'][$name] = $tmp['all']; $ret['active'][$name] = $tmp['active']; $ret['inactive'][$name] = $tmp['inactive']; } else { $ret['all'][$attrib['name']] = $attrib['value']; if(!isset($attrib['active']) || $attrib['active'] == 'true') { $ret['active'][$attrib['name']] = $attrib['value']; } else { $ret['inactive'][$attrib['name']] = $attrib['value']; } } } } return $ret; } function install_plugin_php($id) { $sql = e107::getDb(); $plug = $this->getinfo($id); $_path = e_PLUGIN.$plug['plugin_path'].'/'; $plug['plug_action'] = 'install'; // $plug_vars = $this->parse_plugin_php($plug['plugin_path']); include($_path.'plugin.php'); $func = $eplug_folder.'_install'; if (function_exists($func)) { $text .= call_user_func($func); } if (is_array($eplug_tables)) { $result = $this->manage_tables('add', $eplug_tables); if ($result === TRUE) { $text .= EPL_ADLAN_19.'
'; //success } else { $text .= EPL_ADLAN_18.'
'; //fail } } if (is_array($eplug_prefs)) { $this->manage_prefs('add', $eplug_prefs); $text .= EPL_ADLAN_8.'
'; } if (is_array($eplug_array_pref)) { foreach($eplug_array_pref as $key => $val) { $this->manage_plugin_prefs('add', $key, $eplug_folder, $val); } } /* if (is_array($eplug_sc)) { $this->manage_plugin_prefs('add', 'plug_sc', $eplug_folder, $eplug_sc); } if (is_array($eplug_bb)) { $this->manage_plugin_prefs('add', 'plug_bb', $eplug_folder, $eplug_bb); } */ if ($eplug_link === TRUE && $eplug_link_url != '' && $eplug_link_name != '') { $linkperm = (isset($eplug_link_perms) ? $eplug_link_perms : e_UC_PUBLIC); $this->manage_link('add', $eplug_link_url, $eplug_link_name, $linkperm); } if ($eplug_userclass) { $this->manage_userclass('add', $eplug_userclass, $eplug_userclass_description); } $this -> manage_search('add', $eplug_folder); $this -> manage_notify('add', $eplug_folder); $eplug_addons = $this->getAddons($eplug_folder); $sql->db_Update('plugin', "plugin_installflag = 1, plugin_addons = '{$eplug_addons}' WHERE plugin_id = ".(int)$id); $p_installed = e107::getPref('plug_installed',array()); // load preference; $p_installed[$plug['plugin_path']] = $plug['plugin_version']; e107::getConfig('core')->setPref('plug_installed',$p_installed)->save(); $text .= (isset($eplug_done) ? "
{$eplug_done}" : "
".LAN_INSTALL_SUCCESSFUL); return $text; } /** * Installs a plugin by ID * * @param int $id */ function install_plugin($id) { global $ns, $sysprefs, $mySQLprefix; $sql = e107::getDb(); $tp = e107::getParser(); // install plugin ... $id = (int)$id; $plug = $this->getinfo($id); $plug['plug_action'] = 'install'; if ($plug['plugin_installflag'] == FALSE) { $_path = e_PLUGIN.$plug['plugin_path'].'/'; if(file_exists($_path.'plugin.xml')) { $text = $this->manage_plugin_xml($id, 'install'); } elseif(file_exists($_path.'plugin.php')) { $text = $this->install_plugin_php($id); } } else { $text = EPL_ADLAN_21; } return $text; } function save_addon_prefs() // scan the plugin table and create path-array-prefs for each addon. { $sql = e107::getDb(); $core = e107::getConfig('core'); foreach($this->plugin_addons as $var) // clear all existing prefs. TODO use a pref function for this. { $core->setPref($var.'_list',""); } $query = "SELECT * FROM #plugin WHERE plugin_addons !='' ORDER BY plugin_path ASC"; if ($sql -> db_Select_gen($query)) { while($row = $sql-> db_Fetch()) { $is_installed = ($row['plugin_installflag'] == 1 ); $tmp = explode(",",$row['plugin_addons']); $path = $row['plugin_path']; if ($is_installed) { foreach($tmp as $val) { if(strpos($val, 'e_') === 0) { // $addpref[$val."_list"][$path] = $path; $core->setPref($val.'_list/'.$path,$path); } } } // search for .bb and .sc files. $sc_array = array(); $bb_array = array(); $sql_array = array(); foreach($tmp as $adds) { if(substr($adds,-3) == ".sc") { $sc_name = substr($adds, 0,-3); // remove the .sc if ($is_installed) { $sc_array[$sc_name] = "0"; // default userclass = e_UC_PUBLIC } else { $sc_array[$sc_name] = e_UC_NOBODY; // register shortcode, but disable it } } if($is_installed && (substr($adds,-3) == ".bb")) { $bb_name = substr($adds, 0,-3); // remove the .bb $bb_array[$bb_name] = "0"; // default userclass. } if($is_installed && (substr($adds,-4) == "_sql")) { $core->setPref('e_sql_list/'.$path,$adds); } } // Build Bbcode list (will be empty if plugin not installed) if(count($bb_array) > 0) { ksort($bb_array); $core->setPref('bbcode_list/'.$path,$sc_array); } // Build shortcode list - do if uninstalled as well if(count($sc_array) > 0) { ksort($sc_array); $core->setPref('shortcode_list/'.$path,$sc_array); } } } $core->save(FALSE); if($this->manage_icons()) { // echo 'IT WORKED'; } else { // echo "didn't work!"; } return; } // return a list of available plugin addons for the specified plugin. e_xxx etc. // $debug = TRUE - prints diagnostics // $debug = 'check' - checks each file found for php tags - prints 'pass' or 'fail' function getAddons($plugin_path, $debug=FALSE) { $fl = e107::getFile(); $p_addons = array(); $addonlist = $fl->get_files(e_PLUGIN.$plugin_path, "^e_.*\.php$", "standard", 1); // print_a($addonlist); foreach($addonlist as $f) { if(preg_match("#^(e_.*)\.php$#", $f['fname'], $matches)) { $addon = $matches[1]; if(is_readable(e_PLUGIN.$plugin_path."/".$f['fname'])) { if ($debug === 'check') { $passfail = ''; $file_text = file_get_contents(e_PLUGIN.$plugin_path."/".$f['fname']); if ((substr($file_text,0,5) != '<'.'?php') || (substr($file_text,-2,2) !='?>')) { $passfail = 'fail'; } else { $passfail = 'pass'; } echo $plugin_path."/".$addon.".php - ".$passfail."
"; } $p_addons[] = $addon; } } } // Grab List of Shortcodes & BBcodes $shortcodeList = $fl->get_files(e_PLUGIN.$plugin_path, ".sc$", "standard", 1); $bbcodeList = $fl->get_files(e_PLUGIN.$plugin_path, ".bb$", "standard", 1); $sqlList = $fl->get_files(e_PLUGIN.$plugin_path, "_sql.php$", "standard", 1); // Search Shortcodes foreach($shortcodeList as $sc) { if(is_readable(e_PLUGIN.$plugin_path."/".$sc['fname'])) { $p_addons[] = $sc['fname']; } } // Search Bbcodes. foreach($bbcodeList as $bb) { if(is_readable(e_PLUGIN.$plugin_path."/".$bb['fname'])) { $p_addons[] = $bb['fname']; } } // Search _sql files. foreach($sqlList as $esql) { if(is_readable(e_PLUGIN.$plugin_path."/".$esql['fname'])) { $fname = str_replace(".php","",$esql['fname']); if (!in_array($fname, $p_addons)) $p_addons[] = $fname; // Probably already found - avoid duplication } } if($debug == true) { echo $plugin_path." = ".implode(",",$p_addons)."
"; } return implode(",",$p_addons); } function checkAddon($plugin_path,$e_xxx) { // Return 0 = OK, 1 = Fail, 2 = inaccessible if(is_readable(e_PLUGIN.$plugin_path."/".$e_xxx.".php")) { $file_text = file_get_contents(e_PLUGIN.$plugin_path."/".$e_xxx.".php"); if ((substr($file_text,0,5) != '<'.'?php') || (substr($file_text,-2,2) !='?>')) return 1; return 0; } return 2; } // Entry point to read plugin configuration data function parse_plugin($plugName, $force=false) { $ret = ""; if(isset($this->parsed_plugin[$plugName]) && $force != true) { $this->plug_vars = $this->parsed_plugin[$plugName]; return true; } unset($this->parsed_plugin[$plugName]); // In case forced parsing which fails if(file_exists(e_PLUGIN.$plugName.'/plugin.xml')) { $ret = $this->parse_plugin_xml($plugName); } elseif(file_exists(e_PLUGIN.$plugName.'/plugin.php')) { $ret = $this->parse_plugin_php($plugName); } if($ret == true) { $this->parsed_plugin[$plugName] = $this->plug_vars; } return $ret; } // Called to parse the (deprecated) plugin.php file function parse_plugin_php($plugName) { include(e_PLUGIN.$plugName.'/plugin.php'); $ret = array(); // $ret['installRequired'] = ($eplug_conffile || is_array($eplug_table_names) || is_array($eplug_prefs) || is_array($eplug_sc) || is_array($eplug_bb) || $eplug_module || $eplug_userclass || $eplug_status || $eplug_latest); $ret['@attributes']['installRequired'] = ($eplug_conffile || is_array($eplug_table_names) || is_array($eplug_prefs) || $eplug_module || $eplug_userclass || $eplug_status || $eplug_latest); $ret['@attributes']['version'] = varset($eplug_version); $ret['@attributes']['name'] = varset($eplug_name); $ret['@attributes']['compatibility'] = varset($eplug_compatible); $ret['folder'] = varset($eplug_folder); $ret['category'] = $this->manage_category($eplug_category); $ret['description'] = varset($eplug_description); $ret['author']['@attributes']['name'] = varset($eplug_author); $ret['author']['@attributes']['url'] = varset($eplug_url); $ret['author']['@attributes']['email'] = varset($eplug_email); $ret['readme'] = varset($eplug_readme); $ret['compliant'] = varset($eplug_compliant); $ret['menuName'] = varset($eplug_menu_name); $ret['administration']['icon'] = varset($eplug_icon); $ret['administration']['caption'] = varset($eplug_caption); $ret['administration']['iconSmall'] = varset($eplug_icon_small); $ret['administration']['configFile'] = varset($eplug_conffile); // Set this key so we know the vars came from a plugin.php file $ret['plugin_php'] = true; $this->plug_vars = $ret; return true; } // Called to parse the plugin.xml file if it exists function parse_plugin_xml($plugName) { $tp = e107::getParser(); // loadLanFiles($plugName, 'admin'); // Look for LAN files on default paths require_once(e_HANDLER.'xml_class.php'); $xml = new xmlClass; $this->plug_vars = $xml->loadXMLfile(e_PLUGIN.$plugName.'/plugin.xml', true, true); if ($this->plug_vars === FALSE) { require_once(e_HANDLER."message_handler.php"); $emessage = &eMessage::getInstance(); $emessage->add("Error reading {$plugName}/plugin.xml", E_MESSAGE_ERROR); return FALSE; } $this->plug_vars['category'] = $this->manage_category($this->plug_vars['category']); $this->plug_vars = $this->cleanXML($this->plug_vars); return TRUE; } /** * Return as an array, even when a single xml tag value is found * @param object $vars * @return array */ private function cleanXml($vars) { $array_tags = array("extendedField","userclass","menuLink"); foreach($array_tags as $vl) { if(is_array($vars[$vl]) && !varset($vars[$vl][0])) { $vars[$vl] = array($vars[$vl]); } } return $vars; } } ?>