#!/usr/bin/php <?php require_once __DIR__. '/../vendor/autoload.php'; use Symfony\Component\Yaml\Yaml; $parameters = Yaml::parse(file_get_contents('app/config/parameters.yml')); echo 'Okay, you want to install wallabag, let\'s go!'; echo "\r\n"; function executeQuery($handle, $sql, $params) { try { $query = $handle->prepare($sql); $query->execute($params); return $query->fetchAll(); } catch (Exception $e) { return false; } } $configFile = 'app/config/config.inc.php'; $dbFile = 'data/db/poche.sqlite'; $username = 'wallabag'; $password = 'wallabag'; $salt = $parameters['parameters']['secret']; $defaultLanguage = 'en_EN.UTF8'; if (!copy('app/config/config.inc.default.php', $configFile)) { die('Installation aborted, impossible to create ' . $configFile . ' file. Maybe you don\'t have write access to create it.'); } $content = file_get_contents($configFile); $content = str_replace("define ('SALT', '');", "define ('SALT', '".$salt."');", $content); file_put_contents($configFile, $content); if (!copy('bin/poche.sqlite', $dbFile)) { die('Impossible to create ' . $dbFile . ' file.'); } chmod($dbFile, 0777); $dbPath = 'sqlite:' . realpath('') . '/' . $dbFile; $handle = new PDO($dbPath); $handle->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); $saltedPassword = sha1($password . $username . $salt); $sql = "INSERT INTO users (username, password, name, email) VALUES (?, ?, ?, '')"; $params = array($username, $saltedPassword, $username); $query = executeQuery($handle, $sql, $params); $idUser = (int)$handle->lastInsertId('users_id_seq'); $sql = 'INSERT INTO users_config ( user_id, name, value ) VALUES (?, ?, ?)'; $params = array($idUser, 'pager', '10'); $query = executeQuery($handle, $sql, $params); $sql = 'INSERT INTO users_config ( user_id, name, value ) VALUES (?, ?, ?)'; $params = array($idUser, 'language', $defaultLanguage); $query = executeQuery($handle, $sql, $params); echo 'wallabag is now installed'; echo "\r\n"; echo 'Just execute `php app/console server:run` for using wallabag:'; echo "\r\n"; echo 'http://localhost:8000';