Blame Identity/Models/Html/phpBB/3.0.4/includes/acp/acp_modules.php

d6e8d8
d6e8d8
/**
d6e8d8
*
d6e8d8
* @package acp
d6e8d8
* @version $Id: acp_modules.php 9179 2008-12-06 18:23:42Z toonarmy $
d6e8d8
* @copyright (c) 2005 phpBB Group
d6e8d8
* @license http://opensource.org/licenses/gpl-license.php GNU Public License
d6e8d8
*
d6e8d8
*/
d6e8d8
d6e8d8
/**
d6e8d8
* @ignore
d6e8d8
*/
d6e8d8
if (!defined('IN_PHPBB'))
d6e8d8
{
d6e8d8
	exit;
d6e8d8
}
d6e8d8
d6e8d8
/**
d6e8d8
* - Able to check for new module versions (modes changed/adjusted/added/removed)
d6e8d8
* Icons for:
d6e8d8
* - module enabled and displayed (common)
d6e8d8
* - module enabled and not displayed
d6e8d8
* - module deactivated
d6e8d8
* - category (enabled)
d6e8d8
* - category disabled
d6e8d8
*/
d6e8d8
d6e8d8
/**
d6e8d8
* @package acp
d6e8d8
*/
d6e8d8
class acp_modules
d6e8d8
{
d6e8d8
	var $module_class = '';
d6e8d8
	var $parent_id;
d6e8d8
	var $u_action;
d6e8d8
d6e8d8
	function main($id, $mode)
d6e8d8
	{
d6e8d8
		global $db, $user, $auth, $template, $module;
d6e8d8
		global $config, $phpbb_admin_path, $phpbb_root_path, $phpEx;
d6e8d8
d6e8d8
		// Set a global define for modules we might include (the author is able to prevent execution of code by checking this constant)
d6e8d8
		define('MODULE_INCLUDE', true);
d6e8d8
d6e8d8
		$user->add_lang('acp/modules');
d6e8d8
		$this->tpl_name = 'acp_modules';
d6e8d8
d6e8d8
		// module class
d6e8d8
		$this->module_class = $mode;
d6e8d8
d6e8d8
		if ($this->module_class == 'ucp')
d6e8d8
		{
d6e8d8
			$user->add_lang('ucp');
d6e8d8
		}
d6e8d8
		else if ($this->module_class == 'mcp')
d6e8d8
		{
d6e8d8
			$user->add_lang('mcp');
d6e8d8
		}
d6e8d8
d6e8d8
		if ($module->p_class != $this->module_class)
d6e8d8
		{
d6e8d8
			$module->add_mod_info($this->module_class);
d6e8d8
		}
d6e8d8
d6e8d8
		$this->page_title = strtoupper($this->module_class);
d6e8d8
d6e8d8
		$this->parent_id = request_var('parent_id', 0);
d6e8d8
		$module_id = request_var('m', 0);
d6e8d8
		$action = request_var('action', '');
d6e8d8
		$errors = array();
d6e8d8
d6e8d8
		switch ($action)
d6e8d8
		{
d6e8d8
			case 'delete':
d6e8d8
				if (!$module_id)
d6e8d8
				{
d6e8d8
					trigger_error($user->lang['NO_MODULE_ID'] . adm_back_link($this->u_action . '&parent_id=' . $this->parent_id), E_USER_WARNING);
d6e8d8
				}
d6e8d8
d6e8d8
				if (confirm_box(true))
d6e8d8
				{
d6e8d8
					// Make sure we are not directly within a module
d6e8d8
					if ($module_id == $this->parent_id)
d6e8d8
					{
d6e8d8
						$sql = 'SELECT parent_id
d6e8d8
							FROM ' . MODULES_TABLE . '
d6e8d8
							WHERE module_id = ' . $module_id;
d6e8d8
						$result = $db->sql_query($sql);
d6e8d8
						$this->parent_id = (int) $db->sql_fetchfield('parent_id');
d6e8d8
						$db->sql_freeresult($result);
d6e8d8
					}
d6e8d8
d6e8d8
					$errors = $this->delete_module($module_id);
d6e8d8
d6e8d8
					if (!sizeof($errors))
d6e8d8
					{
d6e8d8
						$this->remove_cache_file();
d6e8d8
						trigger_error($user->lang['MODULE_DELETED'] . adm_back_link($this->u_action . '&parent_id=' . $this->parent_id));
d6e8d8
					}
d6e8d8
				}
d6e8d8
				else
d6e8d8
				{
d6e8d8
					confirm_box(false, 'DELETE_MODULE', build_hidden_fields(array(
d6e8d8
						'i'			=> $id,
d6e8d8
						'mode'		=> $mode,
d6e8d8
						'parent_id'	=> $this->parent_id,
d6e8d8
						'module_id'	=> $module_id,
d6e8d8
						'action'	=> $action,
d6e8d8
					)));
d6e8d8
				}
d6e8d8
d6e8d8
			break;
d6e8d8
			
d6e8d8
			case 'enable':
d6e8d8
			case 'disable':
d6e8d8
				if (!$module_id)
d6e8d8
				{
d6e8d8
					trigger_error($user->lang['NO_MODULE_ID'] . adm_back_link($this->u_action . '&parent_id=' . $this->parent_id), E_USER_WARNING);
d6e8d8
				}
d6e8d8
d6e8d8
				$sql = 'SELECT *
d6e8d8
					FROM ' . MODULES_TABLE . "
d6e8d8
					WHERE module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
						AND module_id = $module_id";
d6e8d8
				$result = $db->sql_query($sql);
d6e8d8
				$row = $db->sql_fetchrow($result);
d6e8d8
				$db->sql_freeresult($result);
d6e8d8
d6e8d8
				if (!$row)
d6e8d8
				{
d6e8d8
					trigger_error($user->lang['NO_MODULE'] . adm_back_link($this->u_action . '&parent_id=' . $this->parent_id), E_USER_WARNING);
d6e8d8
				}
d6e8d8
d6e8d8
				$sql = 'UPDATE ' . MODULES_TABLE . '
d6e8d8
					SET module_enabled = ' . (($action == 'enable') ? 1 : 0) . "
d6e8d8
					WHERE module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
						AND module_id = $module_id";
d6e8d8
				$db->sql_query($sql);
d6e8d8
d6e8d8
				add_log('admin', 'LOG_MODULE_' . strtoupper($action), $this->lang_name($row['module_langname']));
d6e8d8
				$this->remove_cache_file();
d6e8d8
d6e8d8
			break;
d6e8d8
d6e8d8
			case 'move_up':
d6e8d8
			case 'move_down':
d6e8d8
				if (!$module_id)
d6e8d8
				{
d6e8d8
					trigger_error($user->lang['NO_MODULE_ID'] . adm_back_link($this->u_action . '&parent_id=' . $this->parent_id), E_USER_WARNING);
d6e8d8
				}
d6e8d8
d6e8d8
				$sql = 'SELECT *
d6e8d8
					FROM ' . MODULES_TABLE . "
d6e8d8
					WHERE module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
						AND module_id = $module_id";
d6e8d8
				$result = $db->sql_query($sql);
d6e8d8
				$row = $db->sql_fetchrow($result);
d6e8d8
				$db->sql_freeresult($result);
d6e8d8
d6e8d8
				if (!$row)
d6e8d8
				{
d6e8d8
					trigger_error($user->lang['NO_MODULE'] . adm_back_link($this->u_action . '&parent_id=' . $this->parent_id), E_USER_WARNING);
d6e8d8
				}
d6e8d8
d6e8d8
				$move_module_name = $this->move_module_by($row, $action, 1);
d6e8d8
d6e8d8
				if ($move_module_name !== false)
d6e8d8
				{
d6e8d8
					add_log('admin', 'LOG_MODULE_' . strtoupper($action), $this->lang_name($row['module_langname']), $move_module_name);
d6e8d8
					$this->remove_cache_file();
d6e8d8
				}
d6e8d8
		
d6e8d8
			break;
d6e8d8
d6e8d8
			case 'quickadd':
d6e8d8
				$quick_install = request_var('quick_install', '');
d6e8d8
d6e8d8
				if (confirm_box(true))
d6e8d8
				{
d6e8d8
					if (!$quick_install || strpos($quick_install, '::') === false)
d6e8d8
					{
d6e8d8
						break;
d6e8d8
					}
d6e8d8
d6e8d8
					list($module_basename, $module_mode) = explode('::', $quick_install);
d6e8d8
d6e8d8
					// Check if module name and mode exist...
d6e8d8
					$fileinfo = $this->get_module_infos($module_basename);
d6e8d8
					$fileinfo = $fileinfo[$module_basename];
d6e8d8
d6e8d8
					if (isset($fileinfo['modes'][$module_mode]))
d6e8d8
					{
d6e8d8
						$module_data = array(
d6e8d8
							'module_basename'	=> $module_basename,
d6e8d8
							'module_enabled'	=> 0,
d6e8d8
							'module_display'	=> (isset($fileinfo['modes'][$module_mode]['display'])) ? $fileinfo['modes'][$module_mode]['display'] : 1,
d6e8d8
							'parent_id'			=> $this->parent_id,
d6e8d8
							'module_class'		=> $this->module_class,
d6e8d8
							'module_langname'	=> $fileinfo['modes'][$module_mode]['title'],
d6e8d8
							'module_mode'		=> $module_mode,
d6e8d8
							'module_auth'		=> $fileinfo['modes'][$module_mode]['auth'],
d6e8d8
						);
d6e8d8
d6e8d8
						$errors = $this->update_module_data($module_data);
d6e8d8
d6e8d8
						if (!sizeof($errors))
d6e8d8
						{
d6e8d8
							$this->remove_cache_file();
d6e8d8
	
d6e8d8
							trigger_error($user->lang['MODULE_ADDED'] . adm_back_link($this->u_action . '&parent_id=' . $this->parent_id));
d6e8d8
						}
d6e8d8
					}
d6e8d8
				}
d6e8d8
				else
d6e8d8
				{
d6e8d8
					confirm_box(false, 'ADD_MODULE', build_hidden_fields(array(
d6e8d8
						'i'			=> $id,
d6e8d8
						'mode'		=> $mode,
d6e8d8
						'parent_id'	=> $this->parent_id,
d6e8d8
						'action'	=> 'quickadd',
d6e8d8
						'quick_install'	=> $quick_install,
d6e8d8
					)));
d6e8d8
				}
d6e8d8
d6e8d8
			break;
d6e8d8
d6e8d8
			case 'edit':
d6e8d8
d6e8d8
				if (!$module_id)
d6e8d8
				{
d6e8d8
					trigger_error($user->lang['NO_MODULE_ID'] . adm_back_link($this->u_action . '&parent_id=' . $this->parent_id), E_USER_WARNING);
d6e8d8
				}
d6e8d8
				
d6e8d8
				$module_row = $this->get_module_row($module_id);
d6e8d8
d6e8d8
			// no break
d6e8d8
d6e8d8
			case 'add':
d6e8d8
d6e8d8
				if ($action == 'add')
d6e8d8
				{
d6e8d8
					$module_row = array(
d6e8d8
						'module_basename'	=> '',
d6e8d8
						'module_enabled'	=> 0,
d6e8d8
						'module_display'	=> 1,
d6e8d8
						'parent_id'			=> 0,
d6e8d8
						'module_langname'	=> utf8_normalize_nfc(request_var('module_langname', '', true)),
d6e8d8
						'module_mode'		=> '',
d6e8d8
						'module_auth'		=> '',
d6e8d8
					);
d6e8d8
				}
d6e8d8
				
d6e8d8
				$module_data = array();
d6e8d8
d6e8d8
				$module_data['module_basename'] = request_var('module_basename', (string) $module_row['module_basename']);
d6e8d8
				$module_data['module_enabled'] = request_var('module_enabled', (int) $module_row['module_enabled']);
d6e8d8
				$module_data['module_display'] = request_var('module_display', (int) $module_row['module_display']);
d6e8d8
				$module_data['parent_id'] = request_var('module_parent_id', (int) $module_row['parent_id']);
d6e8d8
				$module_data['module_class'] = $this->module_class;
d6e8d8
				$module_data['module_langname'] = utf8_normalize_nfc(request_var('module_langname', (string) $module_row['module_langname'], true));
d6e8d8
				$module_data['module_mode'] = request_var('module_mode', (string) $module_row['module_mode']);
d6e8d8
d6e8d8
				$submit = (isset($_POST['submit'])) ? true : false;
d6e8d8
d6e8d8
				if ($submit)
d6e8d8
				{
d6e8d8
					if (!$module_data['module_langname'])
d6e8d8
					{
d6e8d8
						trigger_error($user->lang['NO_MODULE_LANGNAME'] . adm_back_link($this->u_action . '&parent_id=' . $this->parent_id), E_USER_WARNING);
d6e8d8
					}
d6e8d8
d6e8d8
					$module_type = request_var('module_type', 'category');
d6e8d8
d6e8d8
					if ($module_type == 'category')
d6e8d8
					{
d6e8d8
						$module_data['module_basename'] = $module_data['module_mode'] = $module_data['module_auth'] = '';
d6e8d8
						$module_data['module_display'] = 1;
d6e8d8
					}
d6e8d8
d6e8d8
					if ($action == 'edit')
d6e8d8
					{
d6e8d8
						$module_data['module_id'] = $module_id;
d6e8d8
					}
d6e8d8
d6e8d8
					// Adjust auth row
d6e8d8
					if ($module_data['module_basename'] && $module_data['module_mode'])
d6e8d8
					{
d6e8d8
						$fileinfo = $this->get_module_infos($module_data['module_basename']);
d6e8d8
						$module_data['module_auth'] = $fileinfo[$module_data['module_basename']]['modes'][$module_data['module_mode']]['auth'];
d6e8d8
					}
d6e8d8
d6e8d8
					$errors = $this->update_module_data($module_data);
d6e8d8
d6e8d8
					if (!sizeof($errors))
d6e8d8
					{
d6e8d8
						$this->remove_cache_file();
d6e8d8
	
d6e8d8
						trigger_error((($action == 'add') ? $user->lang['MODULE_ADDED'] : $user->lang['MODULE_EDITED']) . adm_back_link($this->u_action . '&parent_id=' . $this->parent_id));
d6e8d8
					}
d6e8d8
				}
d6e8d8
d6e8d8
				// Category/not category?
d6e8d8
				$is_cat = (!$module_data['module_basename']) ? true : false;
d6e8d8
d6e8d8
				// Get module information
d6e8d8
				$module_infos = $this->get_module_infos();
d6e8d8
d6e8d8
				// Build name options
d6e8d8
				$s_name_options = $s_mode_options = '';
d6e8d8
				foreach ($module_infos as $option => $values)
d6e8d8
				{
d6e8d8
					if (!$module_data['module_basename'])
d6e8d8
					{
d6e8d8
						$module_data['module_basename'] = $option;
d6e8d8
					}
d6e8d8
d6e8d8
					// Name options
d6e8d8
					$s_name_options .= '<option value="' . $option . '"' . (($option == $module_data['module_basename']) ? ' selected="selected"' : '') . '>' . $this->lang_name($values['title']) . ' [' . $this->module_class . '_' . $option . ']</option>';
d6e8d8
d6e8d8
					$template->assign_block_vars('m_names', array('NAME' => $option, 'A_NAME' => addslashes($option)));
d6e8d8
d6e8d8
					// Build module modes
d6e8d8
					foreach ($values['modes'] as $m_mode => $m_values)
d6e8d8
					{
d6e8d8
						if ($option == $module_data['module_basename'])
d6e8d8
						{
d6e8d8
							$s_mode_options .= '<option value="' . $m_mode . '"' . (($m_mode == $module_data['module_mode']) ? ' selected="selected"' : '') . '>' . $this->lang_name($m_values['title']) . '</option>';
d6e8d8
						}
d6e8d8
						
d6e8d8
						$template->assign_block_vars('m_names.modes', array(
d6e8d8
							'OPTION'		=> $m_mode,
d6e8d8
							'VALUE'			=> $this->lang_name($m_values['title']),
d6e8d8
							'A_OPTION'		=> addslashes($m_mode),
d6e8d8
							'A_VALUE'		=> addslashes($this->lang_name($m_values['title'])))
d6e8d8
						);
d6e8d8
					}
d6e8d8
				}
d6e8d8
				
d6e8d8
				$s_cat_option = '<option value="0"' . (($module_data['parent_id'] == 0) ? ' selected="selected"' : '') . '>' . $user->lang['NO_PARENT'] . '</option>';
d6e8d8
d6e8d8
				$template->assign_vars(array_merge(array(
d6e8d8
					'S_EDIT_MODULE'		=> true,
d6e8d8
					'S_IS_CAT'			=> $is_cat,
d6e8d8
					'S_CAT_OPTIONS'		=> $s_cat_option . $this->make_module_select($module_data['parent_id'], ($action == 'edit') ? $module_row['module_id'] : false, false, false, false, true),
d6e8d8
					'S_MODULE_NAMES'	=> $s_name_options,
d6e8d8
					'S_MODULE_MODES'	=> $s_mode_options,
d6e8d8
					'U_BACK'			=> $this->u_action . '&parent_id=' . $this->parent_id,
d6e8d8
					'U_EDIT_ACTION'		=> $this->u_action . '&parent_id=' . $this->parent_id,
d6e8d8
d6e8d8
					'L_TITLE'			=> $user->lang[strtoupper($action) . '_MODULE'],
d6e8d8
					
d6e8d8
					'MODULENAME'		=> $this->lang_name($module_data['module_langname']),
d6e8d8
					'ACTION'			=> $action,
d6e8d8
					'MODULE_ID'			=> $module_id,
d6e8d8
d6e8d8
				),
d6e8d8
					array_change_key_case($module_data, CASE_UPPER))
d6e8d8
				);
d6e8d8
d6e8d8
				if (sizeof($errors))
d6e8d8
				{
d6e8d8
					$template->assign_vars(array(
d6e8d8
						'S_ERROR'	=> true,
d6e8d8
						'ERROR_MSG'	=> implode('
', $errors))
d6e8d8
					);
d6e8d8
				}
d6e8d8
d6e8d8
				return;
d6e8d8
d6e8d8
			break;
d6e8d8
		}
d6e8d8
d6e8d8
		// Default management page
d6e8d8
		if (sizeof($errors))
d6e8d8
		{
d6e8d8
			$template->assign_vars(array(
d6e8d8
				'S_ERROR'	=> true,
d6e8d8
				'ERROR_MSG'	=> implode('
', $errors))
d6e8d8
			);
d6e8d8
		}
d6e8d8
d6e8d8
		if (!$this->parent_id)
d6e8d8
		{
d6e8d8
			$navigation = strtoupper($this->module_class);
d6e8d8
		}
d6e8d8
		else
d6e8d8
		{
d6e8d8
			$navigation = '' . strtoupper($this->module_class) . '';
d6e8d8
d6e8d8
			$modules_nav = $this->get_module_branch($this->parent_id, 'parents', 'descending');
d6e8d8
d6e8d8
			foreach ($modules_nav as $row)
d6e8d8
			{
d6e8d8
				$langname = $this->lang_name($row['module_langname']);
d6e8d8
d6e8d8
				if ($row['module_id'] == $this->parent_id)
d6e8d8
				{
d6e8d8
					$navigation .= ' -> ' . $langname;
d6e8d8
				}
d6e8d8
				else
d6e8d8
				{
d6e8d8
					$navigation .= ' -> ' . $langname . '';
d6e8d8
				}
d6e8d8
			}
d6e8d8
		}
d6e8d8
d6e8d8
		// Jumpbox
d6e8d8
		$module_box = $this->make_module_select($this->parent_id, false, false, false, false);
d6e8d8
d6e8d8
		$sql = 'SELECT *
d6e8d8
			FROM ' . MODULES_TABLE . "
d6e8d8
			WHERE parent_id = {$this->parent_id}
d6e8d8
				AND module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
			ORDER BY left_id";
d6e8d8
		$result = $db->sql_query($sql);
d6e8d8
d6e8d8
		if ($row = $db->sql_fetchrow($result))
d6e8d8
		{
d6e8d8
			do
d6e8d8
			{
d6e8d8
				$langname = $this->lang_name($row['module_langname']);
d6e8d8
d6e8d8
				if (!$row['module_enabled'])
d6e8d8
				{
d6e8d8
					$module_image = '' . $user->lang['DEACTIVATED_MODULE'] .'';
d6e8d8
				}
d6e8d8
				else
d6e8d8
				{
d6e8d8
					$module_image = (!$row['module_basename'] || $row['left_id'] + 1 != $row['right_id']) ? '' . $user->lang['CATEGORY'] . '' : '' . $user->lang['MODULE'] . '';
d6e8d8
				}
d6e8d8
d6e8d8
				$url = $this->u_action . '&parent_id=' . $this->parent_id . '&m=' . $row['module_id'];
d6e8d8
d6e8d8
				$template->assign_block_vars('modules', array(
d6e8d8
					'MODULE_IMAGE'		=> $module_image,
d6e8d8
					'MODULE_TITLE'		=> $langname,
d6e8d8
					'MODULE_ENABLED'	=> ($row['module_enabled']) ? true : false,
d6e8d8
					'MODULE_DISPLAYED'	=> ($row['module_display']) ? true : false,
d6e8d8
d6e8d8
					'S_ACP_CAT_SYSTEM'			=> ($this->module_class == 'acp' && $row['module_langname'] == 'ACP_CAT_SYSTEM') ? true : false,
d6e8d8
					'S_ACP_MODULE_MANAGEMENT'	=> ($this->module_class == 'acp' && ($row['module_basename'] == 'modules' || $row['module_langname'] == 'ACP_MODULE_MANAGEMENT')) ? true : false,
d6e8d8
d6e8d8
					'U_MODULE'			=> $this->u_action . '&parent_id=' . $row['module_id'],
d6e8d8
					'U_MOVE_UP'			=> $url . '&action=move_up',
d6e8d8
					'U_MOVE_DOWN'		=> $url . '&action=move_down',
d6e8d8
					'U_EDIT'			=> $url . '&action=edit',
d6e8d8
					'U_DELETE'			=> $url . '&action=delete',
d6e8d8
					'U_ENABLE'			=> $url . '&action=enable',
d6e8d8
					'U_DISABLE'			=> $url . '&action=disable')
d6e8d8
				);
d6e8d8
			}
d6e8d8
			while ($row = $db->sql_fetchrow($result));
d6e8d8
		}
d6e8d8
		else if ($this->parent_id)
d6e8d8
		{
d6e8d8
			$row = $this->get_module_row($this->parent_id);
d6e8d8
d6e8d8
			$url = $this->u_action . '&parent_id=' . $this->parent_id . '&m=' . $row['module_id'];
d6e8d8
d6e8d8
			$template->assign_vars(array(
d6e8d8
				'S_NO_MODULES'		=> true,
d6e8d8
				'MODULE_TITLE'		=> $langname,
d6e8d8
				'MODULE_ENABLED'	=> ($row['module_enabled']) ? true : false,
d6e8d8
				'MODULE_DISPLAYED'	=> ($row['module_display']) ? true : false,
d6e8d8
d6e8d8
				'U_EDIT'			=> $url . '&action=edit',
d6e8d8
				'U_DELETE'			=> $url . '&action=delete',
d6e8d8
				'U_ENABLE'			=> $url . '&action=enable',
d6e8d8
				'U_DISABLE'			=> $url . '&action=disable')
d6e8d8
			);
d6e8d8
		}
d6e8d8
		$db->sql_freeresult($result);
d6e8d8
d6e8d8
		// Quick adding module
d6e8d8
		$module_infos = $this->get_module_infos();
d6e8d8
d6e8d8
		// Build quick options
d6e8d8
		$s_install_options = '';
d6e8d8
		foreach ($module_infos as $option => $values)
d6e8d8
		{
d6e8d8
			// Name options
d6e8d8
			$s_install_options .= '<optgroup label="' . $this->lang_name($values['title']) . ' [' . $this->module_class . '_' . $option . ']">';
d6e8d8
d6e8d8
			// Build module modes
d6e8d8
			foreach ($values['modes'] as $m_mode => $m_values)
d6e8d8
			{
d6e8d8
				$s_install_options .= '<option value="' . $option . '::' . $m_mode . '">   ' . $this->lang_name($m_values['title']) . '</option>';
d6e8d8
			}
d6e8d8
d6e8d8
			$s_install_options .= '</optgroup>';
d6e8d8
		}
d6e8d8
d6e8d8
		$template->assign_vars(array(
d6e8d8
			'U_SEL_ACTION'		=> $this->u_action,
d6e8d8
			'U_ACTION'			=> $this->u_action . '&parent_id=' . $this->parent_id,
d6e8d8
			'NAVIGATION'		=> $navigation,
d6e8d8
			'MODULE_BOX'		=> $module_box,
d6e8d8
			'PARENT_ID'			=> $this->parent_id,
d6e8d8
			'S_INSTALL_OPTIONS'	=> $s_install_options,
d6e8d8
			)
d6e8d8
		);
d6e8d8
	}
d6e8d8
d6e8d8
	/**
d6e8d8
	* Get row for specified module
d6e8d8
	*/
d6e8d8
	function get_module_row($module_id)
d6e8d8
	{
d6e8d8
		global $db, $user;
d6e8d8
d6e8d8
		$sql = 'SELECT *
d6e8d8
			FROM ' . MODULES_TABLE . "
d6e8d8
			WHERE module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
				AND module_id = $module_id";
d6e8d8
		$result = $db->sql_query($sql);
d6e8d8
		$row = $db->sql_fetchrow($result);
d6e8d8
		$db->sql_freeresult($result);
d6e8d8
		
d6e8d8
		if (!$row)
d6e8d8
		{
d6e8d8
			trigger_error($user->lang['NO_MODULE'] . adm_back_link($this->u_action . '&parent_id=' . $this->parent_id), E_USER_WARNING);
d6e8d8
		}
d6e8d8
d6e8d8
		return $row;
d6e8d8
	}
d6e8d8
	
d6e8d8
	/**
d6e8d8
	* Get available module information from module files
d6e8d8
	*/
d6e8d8
	function get_module_infos($module = '', $module_class = false)
d6e8d8
	{
d6e8d8
		global $phpbb_root_path, $phpEx;
d6e8d8
		
d6e8d8
		$module_class = ($module_class === false) ? $this->module_class : $module_class;
d6e8d8
d6e8d8
		$directory = $phpbb_root_path . 'includes/' . $module_class . '/info/';
d6e8d8
		$fileinfo = array();
d6e8d8
d6e8d8
		if (!$module)
d6e8d8
		{
d6e8d8
			$dh = @opendir($directory);
d6e8d8
d6e8d8
			if (!$dh)
d6e8d8
			{
d6e8d8
				return $fileinfo;
d6e8d8
			}
d6e8d8
d6e8d8
			while (($file = readdir($dh)) !== false)
d6e8d8
			{
d6e8d8
				// Is module?
d6e8d8
				if (preg_match('/^' . $module_class . '_.+\.' . $phpEx . '$/', $file))
d6e8d8
				{
d6e8d8
					$class = str_replace(".$phpEx", '', $file) . '_info';
d6e8d8
d6e8d8
					if (!class_exists($class))
d6e8d8
					{
d6e8d8
						include($directory . $file);
d6e8d8
					}
d6e8d8
d6e8d8
					// Get module title tag
d6e8d8
					if (class_exists($class))
d6e8d8
					{
d6e8d8
						$c_class = new $class();
d6e8d8
						$module_info = $c_class->module();
d6e8d8
						$fileinfo[str_replace($module_class . '_', '', $module_info['filename'])] = $module_info;
d6e8d8
					}
d6e8d8
				}
d6e8d8
			}
d6e8d8
			closedir($dh);
d6e8d8
d6e8d8
			ksort($fileinfo);
d6e8d8
		}
d6e8d8
		else
d6e8d8
		{
d6e8d8
			$filename = $module_class . '_' . basename($module);
d6e8d8
			$class = $module_class . '_' . basename($module) . '_info';
d6e8d8
d6e8d8
			if (!class_exists($class))
d6e8d8
			{
d6e8d8
				include($directory . $filename . '.' . $phpEx);
d6e8d8
			}
d6e8d8
d6e8d8
			// Get module title tag
d6e8d8
			if (class_exists($class))
d6e8d8
			{
d6e8d8
				$c_class = new $class();
d6e8d8
				$module_info = $c_class->module();
d6e8d8
				$fileinfo[str_replace($module_class . '_', '', $module_info['filename'])] = $module_info;
d6e8d8
			}
d6e8d8
		}
d6e8d8
		
d6e8d8
		return $fileinfo;
d6e8d8
	}
d6e8d8
d6e8d8
	/**
d6e8d8
	* Simple version of jumpbox, just lists modules
d6e8d8
	*/
d6e8d8
	function make_module_select($select_id = false, $ignore_id = false, $ignore_acl = false, $ignore_nonpost = false, $ignore_emptycat = true, $ignore_noncat = false)
d6e8d8
	{
d6e8d8
		global $db, $user, $auth, $config;
d6e8d8
d6e8d8
		$sql = 'SELECT module_id, module_enabled, module_basename, parent_id, module_langname, left_id, right_id, module_auth
d6e8d8
			FROM ' . MODULES_TABLE . "
d6e8d8
			WHERE module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
			ORDER BY left_id ASC";
d6e8d8
		$result = $db->sql_query($sql);
d6e8d8
d6e8d8
		$right = $iteration = 0;
d6e8d8
		$padding_store = array('0' => '');
d6e8d8
		$module_list = $padding = '';
d6e8d8
d6e8d8
		while ($row = $db->sql_fetchrow($result))
d6e8d8
		{
d6e8d8
			if ($row['left_id'] < $right)
d6e8d8
			{
d6e8d8
				$padding .= '   ';
d6e8d8
				$padding_store[$row['parent_id']] = $padding;
d6e8d8
			}
d6e8d8
			else if ($row['left_id'] > $right + 1)
d6e8d8
			{
d6e8d8
				$padding = (isset($padding_store[$row['parent_id']])) ? $padding_store[$row['parent_id']] : '';
d6e8d8
			}
d6e8d8
d6e8d8
			$right = $row['right_id'];
d6e8d8
d6e8d8
			if (!$ignore_acl && $row['module_auth'])
d6e8d8
			{
d6e8d8
				// We use zero as the forum id to check - global setting.
d6e8d8
				if (!p_master::module_auth($row['module_auth'], 0))
d6e8d8
				{
d6e8d8
					continue;
d6e8d8
				}
d6e8d8
			}
d6e8d8
d6e8d8
			// ignore this module?
d6e8d8
			if ((is_array($ignore_id) && in_array($row['module_id'], $ignore_id)) || $row['module_id'] == $ignore_id)
d6e8d8
			{
d6e8d8
				continue;
d6e8d8
			}
d6e8d8
d6e8d8
			// empty category
d6e8d8
			if (!$row['module_basename'] && ($row['left_id'] + 1 == $row['right_id']) && $ignore_emptycat)
d6e8d8
			{
d6e8d8
				continue;
d6e8d8
			}
d6e8d8
d6e8d8
			// ignore non-category?
d6e8d8
			if ($row['module_basename'] && $ignore_noncat)
d6e8d8
			{
d6e8d8
				continue;
d6e8d8
			}
d6e8d8
d6e8d8
			$selected = (is_array($select_id)) ? ((in_array($row['module_id'], $select_id)) ? ' selected="selected"' : '') : (($row['module_id'] == $select_id) ? ' selected="selected"' : '');
d6e8d8
d6e8d8
			$langname = $this->lang_name($row['module_langname']);
d6e8d8
			$module_list .= '<option value="' . $row['module_id'] . '"' . $selected . ((!$row['module_enabled']) ? ' class="disabled"' : '') . '>' . $padding . $langname . '</option>';
d6e8d8
d6e8d8
			$iteration++;
d6e8d8
		}
d6e8d8
		$db->sql_freeresult($result);
d6e8d8
d6e8d8
		unset($padding_store);
d6e8d8
d6e8d8
		return $module_list;
d6e8d8
	}
d6e8d8
d6e8d8
	/**
d6e8d8
	* Get module branch
d6e8d8
	*/
d6e8d8
	function get_module_branch($module_id, $type = 'all', $order = 'descending', $include_module = true)
d6e8d8
	{
d6e8d8
		global $db;
d6e8d8
d6e8d8
		switch ($type)
d6e8d8
		{
d6e8d8
			case 'parents':
d6e8d8
				$condition = 'm1.left_id BETWEEN m2.left_id AND m2.right_id';
d6e8d8
			break;
d6e8d8
d6e8d8
			case 'children':
d6e8d8
				$condition = 'm2.left_id BETWEEN m1.left_id AND m1.right_id';
d6e8d8
			break;
d6e8d8
d6e8d8
			default:
d6e8d8
				$condition = 'm2.left_id BETWEEN m1.left_id AND m1.right_id OR m1.left_id BETWEEN m2.left_id AND m2.right_id';
d6e8d8
			break;
d6e8d8
		}
d6e8d8
d6e8d8
		$rows = array();
d6e8d8
d6e8d8
		$sql = 'SELECT m2.*
d6e8d8
			FROM ' . MODULES_TABLE . ' m1
d6e8d8
			LEFT JOIN ' . MODULES_TABLE . " m2 ON ($condition)
d6e8d8
			WHERE m1.module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
				AND m2.module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
				AND m1.module_id = $module_id
d6e8d8
			ORDER BY m2.left_id " . (($order == 'descending') ? 'ASC' : 'DESC');
d6e8d8
		$result = $db->sql_query($sql);
d6e8d8
d6e8d8
		while ($row = $db->sql_fetchrow($result))
d6e8d8
		{
d6e8d8
			if (!$include_module && $row['module_id'] == $module_id)
d6e8d8
			{
d6e8d8
				continue;
d6e8d8
			}
d6e8d8
d6e8d8
			$rows[] = $row;
d6e8d8
		}
d6e8d8
		$db->sql_freeresult($result);
d6e8d8
d6e8d8
		return $rows;
d6e8d8
	}
d6e8d8
d6e8d8
	/**
d6e8d8
	* Remove modules cache file
d6e8d8
	*/
d6e8d8
	function remove_cache_file()
d6e8d8
	{
d6e8d8
		global $cache;
d6e8d8
d6e8d8
		// Sanitise for future path use, it's escaped as appropriate for queries
d6e8d8
		$p_class = str_replace(array('.', '/', '\\'), '', basename($this->module_class));
d6e8d8
		
d6e8d8
		$cache->destroy('_modules_' . $p_class);
d6e8d8
d6e8d8
		// Additionally remove sql cache
d6e8d8
		$cache->destroy('sql', MODULES_TABLE);
d6e8d8
	}
d6e8d8
d6e8d8
	/**
d6e8d8
	* Return correct language name
d6e8d8
	*/
d6e8d8
	function lang_name($module_langname)
d6e8d8
	{
d6e8d8
		global $user;
d6e8d8
d6e8d8
		return (!empty($user->lang[$module_langname])) ? $user->lang[$module_langname] : $module_langname;
d6e8d8
	}
d6e8d8
d6e8d8
	/**
d6e8d8
	* Update/Add module
d6e8d8
	*
d6e8d8
	* @param bool $run_inline if set to true errors will be returned and no logs being written
d6e8d8
	*/
d6e8d8
	function update_module_data(&$module_data, $run_inline = false)
d6e8d8
	{
d6e8d8
		global $db, $user;
d6e8d8
d6e8d8
		if (!isset($module_data['module_id']))
d6e8d8
		{
d6e8d8
			// no module_id means we're creating a new category/module
d6e8d8
			if ($module_data['parent_id'])
d6e8d8
			{
d6e8d8
				$sql = 'SELECT left_id, right_id
d6e8d8
					FROM ' . MODULES_TABLE . "
d6e8d8
					WHERE module_class = '" . $db->sql_escape($module_data['module_class']) . "'
d6e8d8
						AND module_id = " . (int) $module_data['parent_id'];
d6e8d8
				$result = $db->sql_query($sql);
d6e8d8
				$row = $db->sql_fetchrow($result);
d6e8d8
				$db->sql_freeresult($result);
d6e8d8
d6e8d8
				if (!$row)
d6e8d8
				{
d6e8d8
					if ($run_inline)
d6e8d8
					{
d6e8d8
						return 'PARENT_NO_EXIST';
d6e8d8
					}
d6e8d8
d6e8d8
					trigger_error($user->lang['PARENT_NO_EXIST'] . adm_back_link($this->u_action . '&parent_id=' . $this->parent_id), E_USER_WARNING);
d6e8d8
				}
d6e8d8
d6e8d8
				// Workaround
d6e8d8
				$row['left_id'] = (int) $row['left_id'];
d6e8d8
				$row['right_id'] = (int) $row['right_id'];
d6e8d8
d6e8d8
				$sql = 'UPDATE ' . MODULES_TABLE . "
d6e8d8
					SET left_id = left_id + 2, right_id = right_id + 2
d6e8d8
					WHERE module_class = '" . $db->sql_escape($module_data['module_class']) . "'
d6e8d8
						AND left_id > {$row['right_id']}";
d6e8d8
				$db->sql_query($sql);
d6e8d8
d6e8d8
				$sql = 'UPDATE ' . MODULES_TABLE . "
d6e8d8
					SET right_id = right_id + 2
d6e8d8
					WHERE module_class = '" . $db->sql_escape($module_data['module_class']) . "'
d6e8d8
						AND {$row['left_id']} BETWEEN left_id AND right_id";
d6e8d8
				$db->sql_query($sql);
d6e8d8
d6e8d8
				$module_data['left_id'] = (int) $row['right_id'];
d6e8d8
				$module_data['right_id'] = (int) $row['right_id'] + 1;
d6e8d8
			}
d6e8d8
			else
d6e8d8
			{
d6e8d8
				$sql = 'SELECT MAX(right_id) AS right_id
d6e8d8
					FROM ' . MODULES_TABLE . "
d6e8d8
					WHERE module_class = '" . $db->sql_escape($module_data['module_class']) . "'";
d6e8d8
				$result = $db->sql_query($sql);
d6e8d8
				$row = $db->sql_fetchrow($result);
d6e8d8
				$db->sql_freeresult($result);
d6e8d8
d6e8d8
				$module_data['left_id'] = (int) $row['right_id'] + 1;
d6e8d8
				$module_data['right_id'] = (int) $row['right_id'] + 2;
d6e8d8
			}
d6e8d8
d6e8d8
			$sql = 'INSERT INTO ' . MODULES_TABLE . ' ' . $db->sql_build_array('INSERT', $module_data);
d6e8d8
			$db->sql_query($sql);
d6e8d8
d6e8d8
			$module_data['module_id'] = $db->sql_nextid();
d6e8d8
d6e8d8
			if (!$run_inline)
d6e8d8
			{
d6e8d8
				add_log('admin', 'LOG_MODULE_ADD', $this->lang_name($module_data['module_langname']));
d6e8d8
			}
d6e8d8
		}
d6e8d8
		else
d6e8d8
		{
d6e8d8
			$row = $this->get_module_row($module_data['module_id']);
d6e8d8
d6e8d8
			if ($module_data['module_basename'] && !$row['module_basename'])
d6e8d8
			{
d6e8d8
				// we're turning a category into a module
d6e8d8
				$branch = $this->get_module_branch($module_data['module_id'], 'children', 'descending', false);
d6e8d8
d6e8d8
				if (sizeof($branch))
d6e8d8
				{
d6e8d8
					return array($user->lang['NO_CATEGORY_TO_MODULE']);
d6e8d8
				}
d6e8d8
			}
d6e8d8
d6e8d8
			if ($row['parent_id'] != $module_data['parent_id'])
d6e8d8
			{
d6e8d8
				$this->move_module($module_data['module_id'], $module_data['parent_id']);
d6e8d8
			}
d6e8d8
d6e8d8
			$update_ary = $module_data;
d6e8d8
			unset($update_ary['module_id']);
d6e8d8
d6e8d8
			$sql = 'UPDATE ' . MODULES_TABLE . '
d6e8d8
				SET ' . $db->sql_build_array('UPDATE', $update_ary) . "
d6e8d8
				WHERE module_class = '" . $db->sql_escape($module_data['module_class']) . "'
d6e8d8
					AND module_id = " . (int) $module_data['module_id'];
d6e8d8
			$db->sql_query($sql);
d6e8d8
d6e8d8
			if (!$run_inline)
d6e8d8
			{
d6e8d8
				add_log('admin', 'LOG_MODULE_EDIT', $this->lang_name($module_data['module_langname']));
d6e8d8
			}
d6e8d8
		}
d6e8d8
d6e8d8
		return array();
d6e8d8
	}
d6e8d8
d6e8d8
	/**
d6e8d8
	* Move module around the tree
d6e8d8
	*/
d6e8d8
	function move_module($from_module_id, $to_parent_id)
d6e8d8
	{
d6e8d8
		global $db;
d6e8d8
d6e8d8
		$moved_modules = $this->get_module_branch($from_module_id, 'children', 'descending');
d6e8d8
		$from_data = $moved_modules[0];
d6e8d8
		$diff = sizeof($moved_modules) * 2;
d6e8d8
d6e8d8
		$moved_ids = array();
d6e8d8
		for ($i = 0; $i < sizeof($moved_modules); ++$i)
d6e8d8
		{
d6e8d8
			$moved_ids[] = $moved_modules[$i]['module_id'];
d6e8d8
		}
d6e8d8
d6e8d8
		// Resync parents
d6e8d8
		$sql = 'UPDATE ' . MODULES_TABLE . "
d6e8d8
			SET right_id = right_id - $diff
d6e8d8
			WHERE module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
				AND left_id < " . (int) $from_data['right_id'] . '
d6e8d8
				AND right_id > ' . (int) $from_data['right_id'];
d6e8d8
		$db->sql_query($sql);
d6e8d8
d6e8d8
		// Resync righthand side of tree
d6e8d8
		$sql = 'UPDATE ' . MODULES_TABLE . "
d6e8d8
			SET left_id = left_id - $diff, right_id = right_id - $diff
d6e8d8
			WHERE module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
				AND left_id > " . (int) $from_data['right_id'];
d6e8d8
		$db->sql_query($sql);
d6e8d8
d6e8d8
		if ($to_parent_id > 0)
d6e8d8
		{
d6e8d8
			$to_data = $this->get_module_row($to_parent_id);
d6e8d8
d6e8d8
			// Resync new parents
d6e8d8
			$sql = 'UPDATE ' . MODULES_TABLE . "
d6e8d8
				SET right_id = right_id + $diff
d6e8d8
				WHERE module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
					AND " . (int) $to_data['right_id'] . ' BETWEEN left_id AND right_id
d6e8d8
					AND ' . $db->sql_in_set('module_id', $moved_ids, true);
d6e8d8
			$db->sql_query($sql);
d6e8d8
d6e8d8
			// Resync the righthand side of the tree
d6e8d8
			$sql = 'UPDATE ' . MODULES_TABLE . "
d6e8d8
				SET left_id = left_id + $diff, right_id = right_id + $diff
d6e8d8
				WHERE module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
					AND left_id > " . (int) $to_data['right_id'] . '
d6e8d8
					AND ' . $db->sql_in_set('module_id', $moved_ids, true);
d6e8d8
			$db->sql_query($sql);
d6e8d8
d6e8d8
			// Resync moved branch
d6e8d8
			$to_data['right_id'] += $diff;
d6e8d8
			if ($to_data['right_id'] > $from_data['right_id'])
d6e8d8
			{
d6e8d8
				$diff = '+ ' . ($to_data['right_id'] - $from_data['right_id'] - 1);
d6e8d8
			}
d6e8d8
			else
d6e8d8
			{
d6e8d8
				$diff = '- ' . abs($to_data['right_id'] - $from_data['right_id'] - 1);
d6e8d8
			}
d6e8d8
		}
d6e8d8
		else
d6e8d8
		{
d6e8d8
			$sql = 'SELECT MAX(right_id) AS right_id
d6e8d8
				FROM ' . MODULES_TABLE . "
d6e8d8
				WHERE module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
					AND " . $db->sql_in_set('module_id', $moved_ids, true);
d6e8d8
			$result = $db->sql_query($sql);
d6e8d8
			$row = $db->sql_fetchrow($result);
d6e8d8
			$db->sql_freeresult($result);
d6e8d8
d6e8d8
			$diff = '+ ' . (int) ($row['right_id'] - $from_data['left_id'] + 1);
d6e8d8
		}
d6e8d8
d6e8d8
		$sql = 'UPDATE ' . MODULES_TABLE . "
d6e8d8
			SET left_id = left_id $diff, right_id = right_id $diff
d6e8d8
			WHERE module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
				AND " . $db->sql_in_set('module_id', $moved_ids);
d6e8d8
		$db->sql_query($sql);
d6e8d8
	}
d6e8d8
d6e8d8
	/**
d6e8d8
	* Remove module from tree
d6e8d8
	*/
d6e8d8
	function delete_module($module_id)
d6e8d8
	{
d6e8d8
		global $db, $user;
d6e8d8
d6e8d8
		$row = $this->get_module_row($module_id);
d6e8d8
d6e8d8
		$branch = $this->get_module_branch($module_id, 'children', 'descending', false);
d6e8d8
d6e8d8
		if (sizeof($branch))
d6e8d8
		{
d6e8d8
			return array($user->lang['CANNOT_REMOVE_MODULE']);
d6e8d8
		}
d6e8d8
d6e8d8
		// If not move
d6e8d8
		$diff = 2;
d6e8d8
		$sql = 'DELETE FROM ' . MODULES_TABLE . "
d6e8d8
			WHERE module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
				AND module_id = $module_id";
d6e8d8
		$db->sql_query($sql);
d6e8d8
d6e8d8
		$row['right_id'] = (int) $row['right_id'];
d6e8d8
		$row['left_id'] = (int) $row['left_id'];
d6e8d8
d6e8d8
		// Resync tree
d6e8d8
		$sql = 'UPDATE ' . MODULES_TABLE . "
d6e8d8
			SET right_id = right_id - $diff
d6e8d8
			WHERE module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
				AND left_id < {$row['right_id']} AND right_id > {$row['right_id']}";
d6e8d8
		$db->sql_query($sql);
d6e8d8
d6e8d8
		$sql = 'UPDATE ' . MODULES_TABLE . "
d6e8d8
			SET left_id = left_id - $diff, right_id = right_id - $diff
d6e8d8
			WHERE module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
				AND left_id > {$row['right_id']}";
d6e8d8
		$db->sql_query($sql);
d6e8d8
d6e8d8
		add_log('admin', 'LOG_MODULE_REMOVED', $this->lang_name($row['module_langname']));
d6e8d8
d6e8d8
		return array();
d6e8d8
d6e8d8
	}
d6e8d8
d6e8d8
	/**
d6e8d8
	* Move module position by $steps up/down
d6e8d8
	*/
d6e8d8
	function move_module_by($module_row, $action = 'move_up', $steps = 1)
d6e8d8
	{
d6e8d8
		global $db;
d6e8d8
d6e8d8
		/**
d6e8d8
		* Fetch all the siblings between the module's current spot
d6e8d8
		* and where we want to move it to. If there are less than $steps
d6e8d8
		* siblings between the current spot and the target then the
d6e8d8
		* module will move as far as possible
d6e8d8
		*/
d6e8d8
		$sql = 'SELECT module_id, left_id, right_id, module_langname
d6e8d8
			FROM ' . MODULES_TABLE . "
d6e8d8
			WHERE module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
				AND parent_id = " . (int) $module_row['parent_id'] . '
d6e8d8
				AND ' . (($action == 'move_up') ? 'right_id < ' . (int) $module_row['right_id'] . ' ORDER BY right_id DESC' : 'left_id > ' . (int) $module_row['left_id'] . ' ORDER BY left_id ASC');
d6e8d8
		$result = $db->sql_query_limit($sql, $steps);
d6e8d8
d6e8d8
		$target = array();
d6e8d8
		while ($row = $db->sql_fetchrow($result))
d6e8d8
		{
d6e8d8
			$target = $row;
d6e8d8
		}
d6e8d8
		$db->sql_freeresult($result);
d6e8d8
d6e8d8
		if (!sizeof($target))
d6e8d8
		{
d6e8d8
			// The module is already on top or bottom
d6e8d8
			return false;
d6e8d8
		}
d6e8d8
d6e8d8
		/**
d6e8d8
		* $left_id and $right_id define the scope of the nodes that are affected by the move.
d6e8d8
		* $diff_up and $diff_down are the values to substract or add to each node's left_id
d6e8d8
		* and right_id in order to move them up or down.
d6e8d8
		* $move_up_left and $move_up_right define the scope of the nodes that are moving
d6e8d8
		* up. Other nodes in the scope of ($left_id, $right_id) are considered to move down.
d6e8d8
		*/
d6e8d8
		if ($action == 'move_up')
d6e8d8
		{
d6e8d8
			$left_id = (int) $target['left_id'];
d6e8d8
			$right_id = (int) $module_row['right_id'];
d6e8d8
d6e8d8
			$diff_up = (int) ($module_row['left_id'] - $target['left_id']);
d6e8d8
			$diff_down = (int) ($module_row['right_id'] + 1 - $module_row['left_id']);
d6e8d8
d6e8d8
			$move_up_left = (int) $module_row['left_id'];
d6e8d8
			$move_up_right = (int) $module_row['right_id'];
d6e8d8
		}
d6e8d8
		else
d6e8d8
		{
d6e8d8
			$left_id = (int) $module_row['left_id'];
d6e8d8
			$right_id = (int) $target['right_id'];
d6e8d8
d6e8d8
			$diff_up = (int) ($module_row['right_id'] + 1 - $module_row['left_id']);
d6e8d8
			$diff_down = (int) ($target['right_id'] - $module_row['right_id']);
d6e8d8
d6e8d8
			$move_up_left = (int) ($module_row['right_id'] + 1);
d6e8d8
			$move_up_right = (int) $target['right_id'];
d6e8d8
		}
d6e8d8
d6e8d8
		// Now do the dirty job
d6e8d8
		$sql = 'UPDATE ' . MODULES_TABLE . "
d6e8d8
			SET left_id = left_id + CASE
d6e8d8
				WHEN left_id BETWEEN {$move_up_left} AND {$move_up_right} THEN -{$diff_up}
d6e8d8
				ELSE {$diff_down}
d6e8d8
			END,
d6e8d8
			right_id = right_id + CASE
d6e8d8
				WHEN right_id BETWEEN {$move_up_left} AND {$move_up_right} THEN -{$diff_up}
d6e8d8
				ELSE {$diff_down}
d6e8d8
			END
d6e8d8
			WHERE module_class = '" . $db->sql_escape($this->module_class) . "'
d6e8d8
				AND left_id BETWEEN {$left_id} AND {$right_id}
d6e8d8
				AND right_id BETWEEN {$left_id} AND {$right_id}";
d6e8d8
		$db->sql_query($sql);
d6e8d8
d6e8d8
		$this->remove_cache_file();
d6e8d8
d6e8d8
		return $this->lang_name($target['module_langname']);
d6e8d8
	}
d6e8d8
}
d6e8d8
d6e8d8
?>