<?php /** * This file is part of Zwii. * * For full copyright and license information, please see the LICENSE * file that was distributed with this source code. * * @author Rémi Jean <remi.jean@outlook.com> * @copyright Copyright (C) 2008-2018, Rémi Jean * @license GNU General Public License, version 3 * @link http://zwiicms.com/ */ class install extends common { public static $actions = [ 'index' => self::GROUP_VISITOR, 'steps' => self::GROUP_ADMIN, 'update' => self::GROUP_ADMIN, 'removeAll' => self::GROUP_ADMIN, ]; public static $newVersion; /** * Installation */ public function index() { // Accès refusé if($this->getData(['user']) !== []) { // Valeurs en sortie $this->addOutput([ 'access' => false ]); } // Accès autorisé else { // Soumission du formulaire if($this->isPost()) { // Double vérification pour le mot de passe if($this->getInput('installPassword', helper::FILTER_STRING_SHORT, true) !== $this->getInput('installConfirmPassword', helper::FILTER_STRING_SHORT, true)) { self::$inputNotices['installConfirmPassword'] = 'Incorrect'; } // Crée l'utilisateur $userFirstname = $this->getInput('installFirstname', helper::FILTER_STRING_SHORT, true); $userLastname = $this->getInput('installLastname', helper::FILTER_STRING_SHORT, true); $userMail = $this->getInput('installMail', helper::FILTER_MAIL, true); $userId = $this->getInput('installId', helper::FILTER_ID, true); // Configure certaines données par défaut if ($this->getInput('installDefaultData',helper::FILTER_BOOLEAN) === FALSE) { foreach($this->getHierarchy(null, false) as $parentPageId => $childrenPageIds) { if ( $parentPageId !== 'accueil') { if ($this->getdata(['page',$parentPageId,'moduleId'])) { $this->deleteData(['page',$parentPageId]); } } foreach($childrenPageIds as $childKey) { $this->deleteData(['page', $childKey]); } } // Effacer les barres $this->deleteData(['page', 'barre']); $this->deleteData(['page', 'barrelateraleavecmenu']); // Effacer les modules $this->deleteData(['module']); // Ajouter ici la liste des pages privées qui ne sont pas vues lors de l'installation. $this->deleteData(['page', 'privee']); // Effacer les fichiers par défaut if (is_dir(self::FILE_DIR.'source/galerie')) { $this->removeAll(self::FILE_DIR.'source/galerie'); $this->removeAll(self::FILE_DIR.'thumb/galerie'); } } else { $this->setData(['module', 'blog', 'mon-premier-article', 'userId', $userId]); $this->setData(['module', 'blog', 'mon-deuxieme-article', 'userId', $userId]); $this->setData(['module', 'blog', 'mon-troisieme-article', 'userId', $userId]); } $this->setData([ 'user', $userId, [ 'firstname' => $userFirstname, 'forgot' => 0, 'group' => self::GROUP_ADMIN, 'lastname' => $userLastname, 'mail' => $userMail, 'password' => $this->getInput('installPassword', helper::FILTER_PASSWORD, true) ] ]); // Envoie le mail $sent = $this->sendMail( $userMail, 'Installation de votre site', 'Bonjour' . ' <strong>' . $userFirstname . ' ' . $userLastname . '</strong>,<br><br>' . 'Voici les détails de votre installation.<br><br>' . '<strong>URL du site :</strong> <a href="' . helper::baseUrl(false) . '" target="_blank">' . helper::baseUrl(false) . '</a><br>' . '<strong>Identifiant du compte :</strong> ' . $this->getInput('installId') . '<br>', null ); // Générer un fichier robots.txt $this->createRobots(); // Créer sitemap $this->createSitemap('all'); // Valeurs en sortie $this->addOutput([ 'redirect' => helper::baseUrl(false), 'notification' => ($sent === true ? 'Installation terminée' : $sent), 'state' => ($sent === true ? true : null) ]); } // Valeurs en sortie $this->addOutput([ 'display' => self::DISPLAY_LAYOUT_LIGHT, 'title' => 'Installation', 'view' => 'index' ]); } } /** * Étapes de mise à jour */ public function steps() { switch($this->getInput('step', helper::FILTER_INT)) { // Préparation case 1: $success = true; // Copie du fichier de données copy(self::DATA_DIR.'core.json', self::BACKUP_DIR . date('Y-m-d', time()) . '-core-update.json'); copy(self::DATA_DIR.'theme.json', self::BACKUP_DIR . date('Y-m-d', time()) . '-theme-update.json'); // Nettoyage des fichiers temporaires if(file_exists(self::TEMP_DIR.'update.tar.gz')) { $success = unlink(self::TEMP_DIR.'update.tar.gz'); } if(file_exists(self::TEMP_DIR.'update.tar') && $success === true) { $success = unlink(self::TEMP_DIR.'update.tar'); } // Valeurs en sortie $this->addOutput([ 'display' => self::DISPLAY_JSON, 'content' => [ 'success' => $success, 'data' => null ] ]); break; // Téléchargement case 2: // Téléchargement depuis le serveur de Zwii $success = (file_put_contents(self::TEMP_DIR.'update.tar.gz', file_get_contents('https://zwiicms.com/update/' . common::ZWII_UPDATE_CHANNEL . '/update.tar.gz')) !== false); // Valeurs en sortie $this->addOutput([ 'display' => self::DISPLAY_JSON, 'content' => [ 'success' => $success, 'data' => null ] ]); break; // Installation case 3: $success = true; // Check la réécriture d'URL avant d'écraser les fichiers $rewrite = helper::checkRewrite(); // Décompression et installation try { // Décompression dans le dossier de fichier temporaires $pharData = new PharData(self::TEMP_DIR.'update.tar.gz'); $pharData->decompress(); // Installation $pharData->extractTo(__DIR__ . '/../../../', null, true); } catch (Exception $e) { $success = $e->getMessage(); } // Netooyage du dossier if(file_exists(self::TEMP_DIR.'update.tar.gz')) { unlink(self::TEMP_DIR.'update.tar.gz'); } if(file_exists(self::TEMP_DIR.'update.tar')) { unlink(self::TEMP_DIR.'update.tar'); } // Valeurs en sortie $this->addOutput([ 'display' => self::DISPLAY_JSON, 'content' => [ 'success' => $success, 'data' => $rewrite ] ]); break; // Configuration case 4: $success = true; $rewrite = $this->getInput('data'); // Réécriture d'URL if ($rewrite === "true") { $success = (file_put_contents( '.htaccess', PHP_EOL . '<ifModule mod_rewrite.c>' . PHP_EOL . "\tRewriteEngine on" . PHP_EOL . "\tRewriteBase " . helper::baseUrl(false, false) . PHP_EOL . "\tRewriteCond %{REQUEST_FILENAME} !-f" . PHP_EOL . "\tRewriteCond %{REQUEST_FILENAME} !-d" . PHP_EOL . "\tRewriteRule ^(.*)$ index.php?$1 [L]" . PHP_EOL . '</ifModule>', FILE_APPEND ) !== false); } // Valeurs en sortie $this->addOutput([ 'display' => self::DISPLAY_JSON, 'content' => [ 'success' => $success, 'data' => null ] ]); break; } } /** * Mise à jour */ public function update() { // Nouvelle version self::$newVersion = file_get_contents('http://zwiicms.com/update/' . common::ZWII_UPDATE_CHANNEL . '/version'); // Valeurs en sortie $this->addOutput([ 'display' => self::DISPLAY_LAYOUT_LIGHT, 'title' => 'Mise à jour', 'view' => 'update' ]); } /** * Effacer un dossier non vide. */ private function removeAll ( $path ) { foreach ( new DirectoryIterator($path) as $item ): if ( $item->isFile() ) unlink($item->getRealPath()); if ( !$item->isDot() && $item->isDir() ) $this->removeAll($item->getRealPath()); endforeach; rmdir($path); } }