* @copyright Since 2007 PrestaShop SA and Contributors * @license https://opensource.org/licenses/AFL-3.0 Academic Free License version 3.0 */ namespace PrestaShop\Module\PsAccounts\Module; use Tools; class Install { const PARENT_TAB_NAME = -1; const TAB_ACTIVE = 0; /** * @var \Ps_accounts */ private $module; /** * @var \Db */ private $db; public function __construct(\Ps_accounts $module, \Db $db) { $this->module = $module; $this->db = $db; } /** * installInMenu. * * @return bool * * @throws \PrestaShopDatabaseException * @throws \PrestaShopException */ public function installInMenu() { foreach ($this->module->getAdminControllers() as $k => $controllerName) { $tabId = (int) \Tab::getIdFromClassName($controllerName); if (!$tabId) { $tabId = null; } $tab = new \Tab($tabId); $tab->active = (bool) self::TAB_ACTIVE; $tab->class_name = $controllerName; $tab->name = []; foreach (\Language::getLanguages(true) as $lang) { $tab->name[$lang['id_lang']] = $this->module->displayName . ' (' . $k . ')'; } $tab->id_parent = -1 == self::PARENT_TAB_NAME ? (int) \Tab::getIdFromClassName((string) self::PARENT_TAB_NAME) : -1; $tab->module = $this->module->name; $tab->save(); } return true; } /** * Installs database tables * * @return bool */ public function installDatabaseTables() { $dbInstallFile = "{$this->module->getLocalPath()}/sql/install.sql"; if (!file_exists($dbInstallFile)) { return false; } $sql = Tools::file_get_contents($dbInstallFile); if (empty($sql) || !is_string($sql)) { return false; } $sql = str_replace(['PREFIX_', 'ENGINE_TYPE'], [_DB_PREFIX_, _MYSQL_ENGINE_], $sql); $sql = preg_split("/;\s*[\r\n]+/", trim($sql)); if (!empty($sql)) { foreach ($sql as $query) { if (!$this->db->execute($query)) { return false; } } } return true; } }