/admin444/tabs/AdminModules.php
PHP | 377 lines | 341 code | 20 blank | 16 comment | 50 complexity | 7553c63c68e346cc542452918d44ed08 MD5 | raw file
Possible License(s): LGPL-2.1
- <?php
- /**
- * Modules tab for admin panel, AdminModules.php
- * @category admin
- *
- * @author PrestaShop <support@prestashop.com>
- * @copyright PrestaShop
- * @license http://www.opensource.org/licenses/osl-3.0.php Open-source licence 3.0
- * @version 1.3
- *
- */
- include_once(PS_ADMIN_DIR.'/../classes/AdminTab.php');
- class AdminModules extends AdminTab
- {
- /** @var array map with $_GET keywords and their callback */
- private $map = array(
- 'install' => 'install',
- 'uninstall' => 'uninstall',
- 'configure' => 'getContent'
- );
- public function postProcess()
- {
- global $currentIndex, $cookie;
- if (Tools::isSubmit('all_module_send'))
- {
- if (Tools::getValue('all_module'))
- Configuration::updateValue('PS_SHOW_ALL_MODULES', 0);
- else
- Configuration::updateValue('PS_SHOW_ALL_MODULES', 1);
- }
- /* Automatically copy a module from external URL and unarchive it in the appropriated directory */
- if (Tools::isSubmit('active'))
- {
- if ($this->tabAccess['edit'] === '1')
- {
- $module = Module::getInstanceByName(strval(Tools::getValue('module_name')));
- if (Validate::isLoadedObject($module))
- {
- Db::getInstance()->Execute('
- UPDATE `'._DB_PREFIX_.'module`
- SET `active`= 1
- WHERE `name` = \''.pSQL(Tools::getValue('module_name')).'\'');
- Tools::redirectAdmin($currentIndex.'&conf=5'.'&token='.$this->token);
- } else
- $this->_errors[] = Tools::displayError('Cannot load module object');
- } else
- $this->_errors[] = Tools::displayError('You do not have permission to add anything here.');
- }
- elseif (Tools::isSubmit('desactive'))
- {
- if ($this->tabAccess['edit'] === '1')
- {
- $module = Module::getInstanceByName(Tools::getValue('module_name'));
- if (Validate::isLoadedObject($module))
- {
- Db::getInstance()->Execute('
- UPDATE `'._DB_PREFIX_.'module`
- SET `active`= 0
- WHERE `name` = \''.pSQL(Tools::getValue('module_name')).'\'');
- Tools::redirectAdmin($currentIndex.'&conf=5'.'&token='.$this->token);
- } else
- $this->_errors[] = Tools::displayError('Cannot load module object');
- } else
- $this->_errors[] = Tools::displayError('You do not have permission to add anything here.');
- }
- if (Tools::isSubmit('submitDownload'))
- {
- if ($this->tabAccess['add'] === '1')
- {
- if (Validate::isModuleUrl($url = Tools::getValue('url'), $this->_errors))
- {
- if (!@copy($url, _PS_MODULE_DIR_.basename($url)))
- $this->_errors[] = Tools::displayError('404 Module not found');
- else
- $this->extractArchive(_PS_MODULE_DIR_.basename($url));
- }
- }
- else
- $this->_errors[] = Tools::displayError('You do not have permission to add anything here.');
- }
- if (Tools::isSubmit('submitDownload2'))
- {
- if ($this->tabAccess['add'] === '1')
- {
- if (!isset($_FILES['file']['tmp_name']) OR empty($_FILES['file']['tmp_name']))
- $this->_errors[] = $this->l('no file selected');
- elseif (substr($_FILES['file']['name'], -4) != '.tar' AND substr($_FILES['file']['name'], -4) != '.zip' AND substr($_FILES['file']['name'], -4) != '.tgz' AND substr($_FILES['file']['name'], -7) != '.tar.gz')
- $this->_errors[] = Tools::displayError('unknown archive type');
- elseif (!@copy($_FILES['file']['tmp_name'], _PS_MODULE_DIR_.$_FILES['file']['name']))
- $this->_errors[] = Tools::displayError('an error occured while copying archive to module directory');
- else
- $this->extractArchive(_PS_MODULE_DIR_.$_FILES['file']['name']);
- }
- else
- $this->_errors[] = Tools::displayError('You do not have permission to add anything here.');
- }
- /* Call appropriate module callback */
- else
- {
- $return = false;
- foreach ($this->map as $key => $method)
- {
- $modules = Tools::getValue($key);
- if (strpos($modules, '|'))
- $modules = explode('|', $modules);
- else
- $modules = empty($modules) ? false : array($modules);
- $module_errors = array();
- if ($modules)
- foreach ($modules AS $name)
- {
- if (!($module = @Module::getInstanceByName(urldecode($name))))
- $this->_errors[] = $this->l('module not found');
- elseif ($key == 'install' AND $this->tabAccess['add'] !== '1')
- $this->_errors[] = Tools::displayError('You do not have permission to add anything here.');
- elseif ($key == 'uninstall' AND $this->tabAccess['delete'] !== '1')
- $this->_errors[] = Tools::displayError('You do not have permission to delete here.');
- elseif ($key == 'configure' AND $this->tabAccess['edit'] !== '1')
- $this->_errors[] = Tools::displayError('You do not have permission to edit anything here.');
- elseif (($echo = $module->{$method}()) AND ($key == 'configure') AND Module::isInstalled($module->name))
- {
- echo '
- <p><a href="'.$currentIndex.'&token='.$this->token.'"><img src="../img/admin/arrow2.gif" /> '.$this->l('Back to modules list').'</a></p>
- <br />'.$echo.'<br />
- <p><a href="'.$currentIndex.'&token='.$this->token.'"><img src="../img/admin/arrow2.gif" /> '.$this->l('Back to modules list').'</a></p>';
- }
- elseif($echo)
- $return = ($method == 'install' ? 12 : 13);
- elseif ($echo === false)
- $module_errors[] = $name;
- if ($key != 'configure' AND isset($_GET['bpay']))
- Tools::redirectAdmin('index.php?tab=AdminPayment&conf='.$return.'&token='.Tools::getAdminToken('AdminPayment'.intval(Tab::getIdFromClassName('AdminPayment')).intval($cookie->id_employee)));
- }
- if (sizeof($module_errors))
- {
- echo '<div class="alert">'.$this->l('The following module(s) were not installed successfully:').'<ul>';
- foreach ($module_errors AS $module_error)
- echo '<li>'.$module_error.'</li>';
- echo '</ul></div>';
- }
- }
- if ($return)
- Tools::redirectAdmin($currentIndex.'&conf='.$return.'&token='.$this->token);
- }
- }
- function extractArchive($file)
- {
- global $currentIndex;
- $success = false;
- if (substr($file, -4) == '.zip')
- {
- if (class_exists('ZipArchive', false))
- {
- $zip = new ZipArchive();
- if ($zip->open($file) === true AND $zip->extractTo(_PS_MODULE_DIR_) AND $zip->close())
- $success = true;
- else
- $this->_errors[] = Tools::displayError('error while extracting module (file may be corrupted)');
- }
- else
- $this->_errors[] = Tools::displayError('zip is not installed on your server. Ask your host for further information.');
- }
- else
- {
- $archive = new Archive_Tar($file);
- if ($archive->extract(_PS_MODULE_DIR_))
- $success = true;
- else
- $this->_errors[] = Tools::displayError('error while extracting module (file may be corrupted)');
- }
-
- @unlink($file);
- if ($success)
- Tools::redirectAdmin($currentIndex.'&conf=8'.'&token='.$this->token);
- }
-
- public function display()
- {
- if (!isset($_GET['configure']) OR sizeof($this->_errors))
- $this->displayList();
- }
- public function displayJavascript()
- {
- global $currentIndex;
- echo '
- <script type="text/javascript">
- function modules_management(action)
- {
- var modules = document.getElementsByName(\'modules\');
- var module_list = \'\';
- for (var i = 0; i < modules.length; i++)
- {
- if (modules[i].checked == true)
- {
- rel = modules[i].getAttribute(\'rel\');
- if (rel != "false" && action == "uninstall")
- {
- if (!confirm(rel))
- return false;
- }
- module_list += \'|\'+modules[i].value;
- }
- }
- document.location.href=\''.$currentIndex.'&token='.$this->token.'&\'+action+\'=\'+module_list.substring(1, module_list.length);
- }
- </script>';
- }
-
- public function displayList()
- {
- global $currentIndex, $cookie;
-
- $serialModules = '';
- $modules = Module::getModulesOnDisk();
- foreach ($modules AS $module)
- $serialModules .= $module->name.' '.$module->version.'-'.($module->active ? 'a' : 'i')."\n";
- $serialModules = urlencode($serialModules);
- $this->displayJavascript();
- $linkToSettings = 'index.php?tab=AdminPreferences&token='.Tools::getAdminToken('AdminPreferences'.intval(Tab::getIdFromClassName('AdminPreferences')).intval($cookie->id_employee));
- echo '<span onclick="openCloseLayer(\'module_install\', 0);" style="cursor: pointer;font-weight: 700; float: left;"><img src="../img/admin/add.gif" alt="'.$this->l('Add a new module').'" class="middle" /> '.$this->l('Add a new module').'</span>';
- if (Configuration::get('PRESTASTORE_LIVE') AND @ini_get('allow_url_fopen'))
- echo '<script type="text/javascript">
- function getPrestaStore(){if (getE("prestastore").style.display!=\'block\')return;$.post("'.dirname($currentIndex).'/ajax.php",{page:"prestastore"},function(a){getE("prestastore-content").innerHTML=a;})}
- </script>
- <span onclick="openCloseLayer(\'prestastore\', 0); getPrestaStore();" style="cursor: pointer;font-weight: 700; float: left;margin-left:20px;"><img src="../img/admin/prestastore.gif" class="middle" /> '.$this->l('PrestaShop Addons').'</span> (<a href="'.$linkToSettings.'">'.$this->l('disable').'</a>)';
- echo '
- <div class="clear"> </div>
- <div id="module_install" style="float: left;'.((Tools::isSubmit('submitDownload') OR Tools::isSubmit('submitDownload2')) ? '' : 'display: none;').'" class="width1">
- <fieldset class="width2">
- <legend><img src="../img/admin/add.gif" alt="'.$this->l('Add a new module').'" class="middle" /> '.$this->l('Add a new module').'</legend>
- <p>'.$this->l('The module must be either a zip file or a tarball.').'</p>
- <hr />
- <form action="'.$currentIndex.'&token='.$this->token.'" method="post">
- <label style="width: 100px">'.$this->l('Module URL:').'</label>
- <div class="margin-form" style="padding-left: 140px">
- <input type="text" name="url" style="width: 200px;" value="'.(Tools::getValue('url') ? Tools::getValue('url') : 'http://').'" />
- <p>'.$this->l('Download the module directly from a website.').'</p>
- </div>
- <div class="margin-form" style="padding-left: 140px">
- <input type="submit" name="submitDownload" value="'.$this->l('Download this module').'" class="button" />
- </div>
- </form>
- <hr />
- <form action="'.$currentIndex.'&token='.$this->token.'" method="post" enctype="multipart/form-data">
- <label style="width: 100px">'.$this->l('Module file:').'</label>
- <div class="margin-form" style="padding-left: 140px">
- <input type="file" name="file" />
- <p>'.$this->l('Upload the module from your computer.').'</p>
- </div>
- <div class="margin-form" style="padding-left: 140px">
- <input type="submit" name="submitDownload2" value="'.$this->l('Upload this module').'" class="button" />
- </div>
- </form>
- </fieldset>
- </div>';
- if (Configuration::get('PRESTASTORE_LIVE'))
- echo '
- <div id="prestastore" style="margin-left:40px; display:none; float: left" class="width1">
- <fieldset>
- <legend><img src="http://addons.prestashop.com/modules.php?'.(isset($_SERVER['SERVER_ADDR']) ? 'server='.ip2long($_SERVER['SERVER_ADDR']).'&' : '').'mods='.$serialModules.'" class="middle" />'.$this->l('Live from PrestaShop Addons!').'</legend>
- <div id="prestastore-content"></div>
- </fieldset>
- </div>';
- echo '<div class="clear"> </div>';
-
- $nameCountryDefault = Country::getNameById($cookie->id_lang, Configuration::get('PS_COUNTRY_DEFAULT'));
- $showAllModules = Configuration::get('PS_SHOW_ALL_MODULES');
- $isoCountryDefault = Country::getIsoById(Configuration::get('PS_COUNTRY_DEFAULT'));
-
- /* Scan modules directories and load modules classes */
- $warnings = array();
- $orderModule = array();
- $irow = 0;
- foreach ($modules AS $module)
- {
- if ($showAllModules || (!$showAllModules && ((isset($module->limited_countries) && in_array(strtolower($isoCountryDefault), $module->limited_countries)) || !isset($module->limited_countries))))
- $orderModule[(isset($module->tab) AND !empty($module->tab)) ? $module->tab : $this->l('Not specified')][] = $module;
- }
- asort($orderModule);
- foreach ($orderModule AS $tabModule)
- foreach ($tabModule AS $module)
- if ($module->active AND $module->warning)
- $this->displayWarning('<a href="'.$currentIndex.'&configure='.urlencode($module->name).'&token='.$this->token.'">'.$module->displayName.'</a> - '.stripslashes(pSQL($module->warning)));
- echo '
- <form method="POST" id="form_all_module" name="fomr_all_module" action="">
- <input type="hidden" name="all_module_send" value="" />
- <input type="checkbox" name="all_module" style="vertical-align: middle;" id="all_module" '.(!Configuration::get('PS_SHOW_ALL_MODULES') ? 'checked="checked"' : '').' onclick="document.getElementById(\'form_all_module\').submit();" />
- <label class="t" for="all_module">'.$this->l('Show only modules that can be used in my country').'</label> ('.$this->l('Current country:').' <a href="index.php?tab=AdminCountries&token='.Tools::getAdminToken('AdminCountries'.intval(Tab::getIdFromClassName('AdminCountries')).intval($cookie->id_employee)).'">'.$nameCountryDefault.'</a>)
- </form>';
- echo '
- <div style="float:left; width:300px;">';
- /* Browse modules by tab type */
- foreach ($orderModule AS $tab => $tabModule)
- {
- echo '<br />
- <table cellpadding="0" cellspacing="0" class="table width3">
- <tr>
- <th colspan="4" class="center" style="cursor: pointer" onclick="openCloseLayer(\''.addslashes($tab).'\');"><b>'.$tab.'</b> - <span style="color: red">'.sizeof($tabModule).'</span> '.((sizeof($tabModule) > 1) ? $this->l('modules') : $this->l('module')).'</th>
- </tr>
- </table>
- <div id="'.$tab.'" style="width:600px;">
- <table cellpadding="0" cellspacing="0" class="table width3">';
-
- /* Display modules for each tab type */
- foreach ($tabModule as $module)
- {
- if ($module->id)
- {
- $img = '<img src="../img/admin/enabled.gif" alt="'.$this->l('Module enabled').'" title="'.$this->l('Module enabled').'" />';
- if ($module->warning)
- $img = '<img src="../img/admin/warning.gif" alt="'.$this->l('Module installed but with warnings').'" title="'.$this->l('Module installed but with warnings').'" />';
- if (!$module->active)
- $img = '<img src="../img/admin/disabled.gif" alt="'.$this->l('Module disabled').'" title="'.$this->l('Module disabled').'" />';
- } else
- $img = '<img src="../img/admin/cog.gif" alt="'.$this->l('Module not installed').'" title="'.$this->l('Module not installed').'" />';
- echo '
- <tr'.($irow++ % 2 ? ' class="alt_row"' : '').' style="height: 42px;">
- <td style="padding-left: 10px;"><img src="../modules/'.$module->name.'/logo.gif" alt="" /> <b>'.stripslashes($module->displayName).'</b>'.($module->version ? ' v'.$module->version.(strpos($module->version, '.') !== false ? '' : '.0') : '').'<br />'.$module->description.'</td>
- <td width="85">'.(($module->id AND method_exists($module, 'getContent')) ? '<a href="'.$currentIndex.'&configure='.urlencode($module->name).'&token='.$this->token.'">>> '.$this->l('Configure').'</a>' : '').'</td>
- <td class="center" width="20">';
- if ($module->id)
- echo '<a href="'.$currentIndex.'&token='.$this->token.'&module_name='.$module->name.'&'.($module->active ? 'desactive' : 'active').'">';
- echo $img;
- if ($module->id)
- '</a>';
- echo '
- </td>
- <td class="center" width="80">'.((!$module->id)
- ? '<input type="button" class="button small" name="Install" value="'.$this->l('Install').'"
- onclick="javascript:document.location.href=\''.$currentIndex.'&install='.urlencode($module->name).'&token='.$this->token.'\'" />'
- : '<input type="button" class="button small" name="Uninstall" value="'.$this->l('Uninstall').'"
- onclick="'.(empty($module->confirmUninstall) ? '' : 'if(confirm(\''.addslashes($module->confirmUninstall).'\')) ').'document.location.href=\''.$currentIndex.'&uninstall='.urlencode($module->name).'&token='.$this->token.'\';" />').'</td>
- <td style="padding-right: 10px">
- <input type="checkbox" name="modules" value="'.urlencode($module->name).'" '.(empty($module->confirmUninstall) ? 'rel="false"' : 'rel="'.addslashes($module->confirmUninstall).'"').' />
- </td>
- </tr>';
- }
- echo '</table>
- </div>';
- }
- echo '
- <div style="margin-top: 12px; width:600px;" class="center">
- <input type="button" class="button small" value="'.$this->l('Install the selection').'" onclick="modules_management(\'install\')"/>
- <input type="button" class="button small" value="'.$this->l('Uninstall the selection').'" onclick="modules_management(\'uninstall\')" />
- </div>
- </div>
- <div style="float:right; width:300px;">
- <br />
- <table cellpadding="0" cellspacing="0" class="table width3" style="width:300px;"><tr><th colspan="4" class="center"><strong>'.$this->l('Icon legend').'</strong></th></tr></table>
- <table cellpadding="0" cellspacing="0" class="table width3" style="width:300px;"><tr style="height: 42px;">
- <td>
- <table cellpadding="10" cellspacing="5">
- <tr><td><img src="../img/admin/cog.gif" /> '.$this->l('Module not installed').'</td></tr>
- <tr><td><img src="../img/admin/enabled.gif" /> '.$this->l('Module installed and enabled').'</td></tr>
- <tr><td><img src="../img/admin/disabled.gif" /> '.$this->l('Module installed but disabled').'</td></tr>
- <tr><td><img src="../img/admin/warning.gif" /> '.$this->l('Module installed but some warnings').'</td></tr>
- </table>
- </td>
- </tr></table>
- </div>
- <div style="clear:both"> </div>';
- }
- }
- ?>