install.php 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724
  1. <?php
  2. require('../constants.php');
  3. session_start ();
  4. if (isset ($_GET['step'])) {
  5. define ('STEP', $_GET['step']);
  6. } else {
  7. define ('STEP', 1);
  8. }
  9. define ('SQL_REQ_CREATE_DB', 'CREATE DATABASE %s DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;');
  10. define ('SQL_REQ_CAT', 'CREATE TABLE IF NOT EXISTS `%scategory` (
  11. `id` SMALLINT NOT NULL AUTO_INCREMENT, -- v0.7
  12. `name` varchar(255) NOT NULL,
  13. `color` char(7) NOT NULL,
  14. PRIMARY KEY (`id`),
  15. UNIQUE KEY (`name`) -- v0.7
  16. ) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;');
  17. define ('SQL_REQ_FEED', 'CREATE TABLE IF NOT EXISTS `%sfeed` (
  18. `id` SMALLINT NOT NULL AUTO_INCREMENT, -- v0.7
  19. `url` varchar(511) CHARACTER SET latin1 NOT NULL,
  20. `category` SMALLINT DEFAULT 0, -- v0.7
  21. `name` varchar(255) NOT NULL,
  22. `website` varchar(255) CHARACTER SET latin1 NOT NULL,
  23. `description` text NOT NULL,
  24. `lastUpdate` int(11) NOT NULL,
  25. `priority` tinyint(2) NOT NULL DEFAULT 10,
  26. `pathEntries` varchar(511) DEFAULT NULL,
  27. `httpAuth` varchar(511) DEFAULT NULL,
  28. `error` boolean NOT NULL DEFAULT 0,
  29. `keep_history` boolean NOT NULL DEFAULT 0,
  30. `cache_nbEntries` int NOT NULL DEFAULT 0, -- v0.7
  31. `cache_nbUnreads` int NOT NULL DEFAULT 0, -- v0.7
  32. PRIMARY KEY (`id`),
  33. FOREIGN KEY (`category`) REFERENCES %scategory(id) ON DELETE SET NULL ON UPDATE CASCADE,
  34. UNIQUE KEY (`url`), -- v0.7
  35. INDEX (`name`), -- v0.7
  36. INDEX (`priority`), -- v0.7
  37. INDEX (`keep_history`) -- v0.7
  38. ) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;');
  39. define ('SQL_REQ_ENTRY', 'CREATE TABLE IF NOT EXISTS `%sentry` (
  40. `id` char(6) NOT NULL,
  41. `guid` varchar(760) CHARACTER SET latin1 NOT NULL, -- Maximum for UNIQUE is 767B
  42. `title` varchar(255) NOT NULL,
  43. `author` varchar(255) NOT NULL,
  44. `content` text NOT NULL,
  45. `link` varchar(1023) CHARACTER SET latin1 NOT NULL,
  46. `date` int(11) NOT NULL,
  47. `is_read` boolean NOT NULL DEFAULT 0,
  48. `is_favorite` boolean NOT NULL DEFAULT 0,
  49. `id_feed` SMALLINT NOT NULL, -- v0.7
  50. `tags` varchar(1023) NOT NULL,
  51. PRIMARY KEY (`id`),
  52. FOREIGN KEY (`id_feed`) REFERENCES %sfeed(id) ON DELETE CASCADE ON UPDATE CASCADE,
  53. UNIQUE KEY (`id_feed`,`guid`), -- v0.7
  54. INDEX (`is_favorite`), -- v0.7
  55. INDEX (`is_read`), -- v0.7
  56. INDEX (`date`) -- v0.7 //TODO: remove after https://github.com/marienfressinaud/FreshRSS/issues/202
  57. ) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;');
  58. function writeLine ($f, $line) {
  59. fwrite ($f, $line . "\n");
  60. }
  61. function writeArray ($f, $array) {
  62. foreach ($array as $key => $val) {
  63. if (is_array ($val)) {
  64. writeLine ($f, '\'' . $key . '\' => array (');
  65. writeArray ($f, $val);
  66. writeLine ($f, '),');
  67. } else {
  68. writeLine ($f, '\'' . $key . '\' => \'' . $val . '\',');
  69. }
  70. }
  71. }
  72. // tiré de Shaarli de Seb Sauvage //Format RFC 4648 base64url
  73. function small_hash ($txt) {
  74. $t = rtrim (base64_encode (hash ('crc32', $txt, true)), '=');
  75. return strtr ($t, '+/', '-_');
  76. }
  77. // gestion internationalisation
  78. $translates = array ();
  79. $actual = 'en';
  80. function initTranslate () {
  81. global $translates;
  82. global $actual;
  83. $l = getBetterLanguage ('en');
  84. if (isset ($_SESSION['language'])) {
  85. $l = $_SESSION['language'];
  86. }
  87. $actual = $l;
  88. $file = APP_PATH . '/i18n/' . $actual . '.php';
  89. if (file_exists ($file)) {
  90. $translates = include ($file);
  91. }
  92. }
  93. function getBetterLanguage ($fallback) {
  94. $available = availableLanguages ();
  95. $accept = $_SERVER['HTTP_ACCEPT_LANGUAGE'];
  96. $language = strtolower (substr ($accept, 0, 2));
  97. if (isset ($available[$language])) {
  98. return $language;
  99. } else {
  100. return $fallback;
  101. }
  102. }
  103. function availableLanguages () {
  104. return array (
  105. 'en' => 'English',
  106. 'fr' => 'Français'
  107. );
  108. }
  109. function _t ($key) {
  110. global $translates;
  111. $translate = $key;
  112. if (isset ($translates[$key])) {
  113. $translate = $translates[$key];
  114. }
  115. $args = func_get_args ();
  116. unset($args[0]);
  117. return vsprintf ($translate, $args);
  118. }
  119. /*** SAUVEGARDES ***/
  120. function saveLanguage () {
  121. if (!empty ($_POST)) {
  122. if (!isset ($_POST['language'])) {
  123. return false;
  124. }
  125. $_SESSION['language'] = $_POST['language'];
  126. header ('Location: index.php?step=1');
  127. }
  128. }
  129. function saveStep2 () {
  130. if (!empty ($_POST)) {
  131. if (empty ($_POST['title']) ||
  132. empty ($_POST['old_entries'])) {
  133. return false;
  134. }
  135. $_SESSION['sel'] = md5 (
  136. uniqid (mt_rand (), true).implode ('', stat (__FILE__))
  137. );
  138. $_SESSION['base_url'] = addslashes ($_POST['base_url']);
  139. $_SESSION['title'] = addslashes ($_POST['title']);
  140. $_SESSION['old_entries'] = $_POST['old_entries'];
  141. if (!is_int (intval ($_SESSION['old_entries'])) ||
  142. $_SESSION['old_entries'] < 1) {
  143. $_SESSION['old_entries'] = 3;
  144. }
  145. $_SESSION['mail_login'] = addslashes ($_POST['mail_login']);
  146. $_SESSION['default_user'] = substr(preg_replace ('/[^a-zA-Z0-9]/', '', $_POST['default_user']), 0, 16);
  147. $token = '';
  148. if ($_SESSION['mail_login']) {
  149. $token = small_hash (time () . $_SESSION['sel'])
  150. . small_hash ($_SESSION['base_url'] . $_SESSION['sel']);
  151. }
  152. $file_data = DATA_PATH . '/' . $_SESSION['default_user'] . '_user.php';
  153. $f = fopen ($file_data, 'w');
  154. writeLine ($f, '<?php');
  155. writeLine ($f, 'return array (');
  156. writeArray ($f, array (
  157. 'language' => $_SESSION['language'],
  158. 'old_entries' => $_SESSION['old_entries'],
  159. 'mail_login' => $_SESSION['mail_login'],
  160. 'token' => $token
  161. ));
  162. writeLine ($f, ');');
  163. fclose ($f);
  164. header ('Location: index.php?step=3');
  165. }
  166. }
  167. function saveStep3 () {
  168. if (!empty ($_POST)) {
  169. if (empty ($_POST['type']) ||
  170. empty ($_POST['host']) ||
  171. empty ($_POST['user']) ||
  172. empty ($_POST['base'])) {
  173. $_SESSION['bd_error'] = true;
  174. }
  175. $_SESSION['bd_type'] = isset ($_POST['type']) ? $_POST['type'] : 'mysql';
  176. $_SESSION['bd_host'] = addslashes ($_POST['host']);
  177. $_SESSION['bd_user'] = addslashes ($_POST['user']);
  178. $_SESSION['bd_pass'] = addslashes ($_POST['pass']);
  179. $_SESSION['bd_name'] = addslashes ($_POST['base']);
  180. $_SESSION['bd_prefix'] = addslashes ($_POST['prefix']);
  181. $file_conf = DATA_PATH . '/application.ini';
  182. $f = fopen ($file_conf, 'w');
  183. writeLine ($f, '[general]');
  184. writeLine ($f, 'environment = "production"');
  185. writeLine ($f, 'use_url_rewriting = false');
  186. writeLine ($f, 'sel_application = "' . $_SESSION['sel'] . '"');
  187. writeLine ($f, 'base_url = "' . $_SESSION['base_url'] . '"');
  188. writeLine ($f, 'title = "' . $_SESSION['title'] . '"');
  189. writeLine ($f, 'default_user = "' . $_SESSION['default_user'] . '"');
  190. writeLine ($f, '[db]');
  191. writeLine ($f, 'type = "' . $_SESSION['bd_type'] . '"');
  192. writeLine ($f, 'host = "' . $_SESSION['bd_host'] . '"');
  193. writeLine ($f, 'user = "' . $_SESSION['bd_user'] . '"');
  194. writeLine ($f, 'password = "' . $_SESSION['bd_pass'] . '"');
  195. writeLine ($f, 'base = "' . $_SESSION['bd_name'] . '"');
  196. writeLine ($f, 'prefix = "' . $_SESSION['bd_prefix'] . '"');
  197. fclose ($f);
  198. $_SESSION['bd_prefix'] .= (empty($_SESSION['default_user']) ? '' : ($_SESSION['default_user'] . '_'));
  199. $res = checkBD ();
  200. if ($res) {
  201. $_SESSION['bd_error'] = false;
  202. header ('Location: index.php?step=4');
  203. } else {
  204. $_SESSION['bd_error'] = true;
  205. }
  206. }
  207. }
  208. function deleteInstall () {
  209. $res = unlink (PUBLIC_PATH . '/install.php');
  210. if ($res) {
  211. header ('Location: index.php');
  212. }
  213. }
  214. /*** VÉRIFICATIONS ***/
  215. function checkStep () {
  216. $s0 = checkStep0 ();
  217. $s1 = checkStep1 ();
  218. $s2 = checkStep2 ();
  219. $s3 = checkStep3 ();
  220. if (STEP > 0 && $s0['all'] != 'ok') {
  221. header ('Location: index.php?step=0');
  222. } elseif (STEP > 1 && $s1['all'] != 'ok') {
  223. header ('Location: index.php?step=1');
  224. } elseif (STEP > 2 && $s2['all'] != 'ok') {
  225. header ('Location: index.php?step=2');
  226. } elseif (STEP > 3 && $s3['all'] != 'ok') {
  227. header ('Location: index.php?step=3');
  228. }
  229. }
  230. function checkStep0 () {
  231. $languages = availableLanguages ();
  232. $language = isset ($_SESSION['language']) &&
  233. isset ($languages[$_SESSION['language']]);
  234. return array (
  235. 'language' => $language ? 'ok' : 'ko',
  236. 'all' => $language ? 'ok' : 'ko'
  237. );
  238. }
  239. function checkStep1 () {
  240. $php = version_compare (PHP_VERSION, '5.1.0') >= 0;
  241. $minz = file_exists (LIB_PATH . '/minz');
  242. $curl = extension_loaded ('curl');
  243. $pdo = extension_loaded ('pdo_mysql');
  244. $dom = class_exists('DOMDocument');
  245. $data = DATA_PATH && is_writable (DATA_PATH);
  246. $cache = CACHE_PATH && is_writable (CACHE_PATH);
  247. $log = LOG_PATH && is_writable (LOG_PATH);
  248. $favicons = is_writable (PUBLIC_PATH . '/favicons');
  249. return array (
  250. 'php' => $php ? 'ok' : 'ko',
  251. 'minz' => $minz ? 'ok' : 'ko',
  252. 'curl' => $curl ? 'ok' : 'ko',
  253. 'pdo-mysql' => $pdo ? 'ok' : 'ko',
  254. 'dom' => $dom ? 'ok' : 'ko',
  255. 'data' => $data ? 'ok' : 'ko',
  256. 'cache' => $cache ? 'ok' : 'ko',
  257. 'log' => $log ? 'ok' : 'ko',
  258. 'favicons' => $favicons ? 'ok' : 'ko',
  259. 'all' => $php && $minz && $curl && $pdo && $dom && $data && $cache && $log && $favicons ? 'ok' : 'ko'
  260. );
  261. }
  262. function checkStep2 () {
  263. $conf = isset ($_SESSION['sel']) &&
  264. isset ($_SESSION['base_url']) &&
  265. isset ($_SESSION['title']) &&
  266. isset ($_SESSION['old_entries']) &&
  267. isset ($_SESSION['mail_login']) &&
  268. isset ($_SESSION['default_user']);
  269. $defaultUser = empty($_POST['default_user']) ? null : $_POST['default_user'];
  270. if ($defaultUser === null) {
  271. $defaultUser = empty($_SESSION['default_user']) ? '' : $_SESSION['default_user'];
  272. }
  273. $data = file_exists (DATA_PATH . '/' . $defaultUser . '_user.php');
  274. return array (
  275. 'conf' => $conf ? 'ok' : 'ko',
  276. 'data' => $data ? 'ok' : 'ko',
  277. 'all' => $conf && $data ? 'ok' : 'ko'
  278. );
  279. }
  280. function checkStep3 () {
  281. $conf = file_exists (DATA_PATH . '/application.ini');
  282. $bd = isset ($_SESSION['bd_type']) &&
  283. isset ($_SESSION['bd_host']) &&
  284. isset ($_SESSION['bd_user']) &&
  285. isset ($_SESSION['bd_pass']) &&
  286. isset ($_SESSION['bd_name']);
  287. $conn = !isset ($_SESSION['bd_error']) || !$_SESSION['bd_error'];
  288. return array (
  289. 'bd' => $bd ? 'ok' : 'ko',
  290. 'conn' => $conn ? 'ok' : 'ko',
  291. 'conf' => $conf ? 'ok' : 'ko',
  292. 'all' => $bd && $conn && $conf ? 'ok' : 'ko'
  293. );
  294. }
  295. function checkBD () {
  296. $error = false;
  297. try {
  298. $str = '';
  299. $driver_options = null;
  300. if($_SESSION['bd_type'] == 'mysql') {
  301. $driver_options = array(
  302. PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8'
  303. );
  304. // on ouvre une connexion juste pour créer la base si elle n'existe pas
  305. $str = 'mysql:host=' . $_SESSION['bd_host'] . ';';
  306. $c = new PDO ($str,
  307. $_SESSION['bd_user'],
  308. $_SESSION['bd_pass'],
  309. $driver_options);
  310. $sql = sprintf (SQL_REQ_CREATE_DB, $_SESSION['bd_name']);
  311. $res = $c->query ($sql);
  312. // on écrase la précédente connexion en sélectionnant la nouvelle BDD
  313. $str = 'mysql:host=' . $_SESSION['bd_host'] . ';dbname=' . $_SESSION['bd_name'];
  314. } elseif($_SESSION['bd_type'] == 'sqlite') {
  315. $str = 'sqlite:' . DATA_PATH . $_SESSION['bd_name'] . '.sqlite';
  316. }
  317. $c = new PDO ($str,
  318. $_SESSION['bd_user'],
  319. $_SESSION['bd_pass'],
  320. $driver_options);
  321. $sql = sprintf (SQL_REQ_CAT, $_SESSION['bd_prefix']);
  322. $res = $c->query ($sql);
  323. if (!$res) {
  324. $error = true;
  325. }
  326. $sql = sprintf (SQL_REQ_FEED, $_SESSION['bd_prefix'], $_SESSION['bd_prefix']);
  327. $res = $c->query ($sql);
  328. if (!$res) {
  329. $error = true;
  330. }
  331. $sql = sprintf (SQL_REQ_ENTRY, $_SESSION['bd_prefix'], $_SESSION['bd_prefix']);
  332. $res = $c->query ($sql);
  333. if (!$res) {
  334. $error = true;
  335. }
  336. } catch (PDOException $e) {
  337. $error = true;
  338. }
  339. if ($error && file_exists (DATA_PATH . '/application.ini')) {
  340. unlink (DATA_PATH . '/application.ini');
  341. }
  342. return !$error;
  343. }
  344. /*** AFFICHAGE ***/
  345. function printStep0 () {
  346. global $actual;
  347. ?>
  348. <?php $s0 = checkStep0 (); if ($s0['all'] == 'ok') { ?>
  349. <p class="alert alert-success"><span class="alert-head"><?php echo _t ('ok'); ?></span> <?php echo _t ('language_defined'); ?></p>
  350. <?php } ?>
  351. <form action="index.php?step=0" method="post">
  352. <legend><?php echo _t ('choose_language'); ?></legend>
  353. <div class="form-group">
  354. <label class="group-name" for="language"><?php echo _t ('language'); ?></label>
  355. <div class="group-controls">
  356. <select name="language" id="language">
  357. <?php $languages = availableLanguages (); ?>
  358. <?php foreach ($languages as $short => $lib) { ?>
  359. <option value="<?php echo $short; ?>"<?php echo $actual == $short ? ' selected="selected"' : ''; ?>><?php echo $lib; ?></option>
  360. <?php } ?>
  361. </select>
  362. </div>
  363. </div>
  364. <div class="form-group form-actions">
  365. <div class="group-controls">
  366. <button type="submit" class="btn btn-important"><?php echo _t ('save'); ?></button>
  367. <button type="reset" class="btn"><?php echo _t ('cancel'); ?></button>
  368. <?php if ($s0['all'] == 'ok') { ?>
  369. <a class="btn btn-important next-step" href="?step=1"><?php echo _t ('next_step'); ?></a>
  370. <?php } ?>
  371. </div>
  372. </div>
  373. </form>
  374. <?php
  375. }
  376. function printStep1 () {
  377. $res = checkStep1 ();
  378. ?>
  379. <noscript><p class="alert alert-warn"><span class="alert-head"><?php echo _t ('attention'); ?></span> <?php echo _t ('javascript_is_better'); ?></p></noscript>
  380. <?php if ($res['php'] == 'ok') { ?>
  381. <p class="alert alert-success"><span class="alert-head"><?php echo _t ('ok'); ?></span> <?php echo _t ('php_is_ok', PHP_VERSION); ?></p>
  382. <?php } else { ?>
  383. <p class="alert alert-error"><span class="alert-head"><?php echo _t ('damn'); ?></span> <?php echo _t ('php_is_nok', PHP_VERSION, '5.1.0'); ?></p>
  384. <?php } ?>
  385. <?php if ($res['minz'] == 'ok') { ?>
  386. <p class="alert alert-success"><span class="alert-head"><?php echo _t ('ok'); ?></span> <?php echo _t ('minz_is_ok'); ?></p>
  387. <?php } else { ?>
  388. <p class="alert alert-error"><span class="alert-head"><?php echo _t ('damn'); ?></span> <?php echo _t ('minz_is_nok', LIB_PATH . '/minz'); ?></p>
  389. <?php } ?>
  390. <?php if ($res['curl'] == 'ok') { ?>
  391. <?php $version = curl_version(); ?>
  392. <p class="alert alert-success"><span class="alert-head"><?php echo _t ('ok'); ?></span> <?php echo _t ('curl_is_ok', $version['version']); ?></p>
  393. <?php } else { ?>
  394. <p class="alert alert-error"><span class="alert-head"><?php echo _t ('damn'); ?></span> <?php echo _t ('curl_is_nok'); ?></p>
  395. <?php } ?>
  396. <?php if ($res['pdo-mysql'] == 'ok') { ?>
  397. <p class="alert alert-success"><span class="alert-head"><?php echo _t ('ok'); ?></span> <?php echo _t ('pdomysql_is_ok'); ?></p>
  398. <?php } else { ?>
  399. <p class="alert alert-error"><span class="alert-head"><?php echo _t ('damn'); ?></span> <?php echo _t ('pdomysql_is_nok'); ?></p>
  400. <?php } ?>
  401. <?php if ($res['dom'] == 'ok') { ?>
  402. <p class="alert alert-success"><span class="alert-head"><?php echo _t ('ok'); ?></span> <?php echo _t ('dom_is_ok'); ?></p>
  403. <?php } else { ?>
  404. <p class="alert alert-error"><span class="alert-head"><?php echo _t ('damn'); ?></span> <?php echo _t ('dom_is_nok'); ?></p>
  405. <?php } ?>
  406. <?php if ($res['data'] == 'ok') { ?>
  407. <p class="alert alert-success"><span class="alert-head"><?php echo _t ('ok'); ?></span> <?php echo _t ('data_is_ok'); ?></p>
  408. <?php } else { ?>
  409. <p class="alert alert-error"><span class="alert-head"><?php echo _t ('damn'); ?></span> <?php echo _t ('file_is_nok', DATA_PATH); ?></p>
  410. <?php } ?>
  411. <?php if ($res['cache'] == 'ok') { ?>
  412. <p class="alert alert-success"><span class="alert-head"><?php echo _t ('ok'); ?></span> <?php echo _t ('cache_is_ok'); ?></p>
  413. <?php } else { ?>
  414. <p class="alert alert-error"><span class="alert-head"><?php echo _t ('damn'); ?></span> <?php echo _t ('file_is_nok', CACHE_PATH); ?></p>
  415. <?php } ?>
  416. <?php if ($res['log'] == 'ok') { ?>
  417. <p class="alert alert-success"><span class="alert-head"><?php echo _t ('ok'); ?></span> <?php echo _t ('log_is_ok'); ?></p>
  418. <?php } else { ?>
  419. <p class="alert alert-error"><span class="alert-head"><?php echo _t ('damn'); ?></span> <?php echo _t ('file_is_nok', LOG_PATH); ?></p>
  420. <?php } ?>
  421. <?php if ($res['favicons'] == 'ok') { ?>
  422. <p class="alert alert-success"><span class="alert-head"><?php echo _t ('ok'); ?></span> <?php echo _t ('favicons_is_ok'); ?></p>
  423. <?php } else { ?>
  424. <p class="alert alert-error"><span class="alert-head"><?php echo _t ('damn'); ?></span> <?php echo _t ('file_is_nok', PUBLIC_PATH . '/favicons'); ?></p>
  425. <?php } ?>
  426. <?php if ($res['all'] == 'ok') { ?>
  427. <a class="btn btn-important next-step" href="?step=2"><?php echo _t ('next_step'); ?></a>
  428. <?php } else { ?>
  429. <p class="alert alert-error"><?php echo _t ('fix_errors_before'); ?></p>
  430. <?php } ?>
  431. <?php
  432. }
  433. function printStep2 () {
  434. ?>
  435. <?php $s2 = checkStep2 (); if ($s2['all'] == 'ok') { ?>
  436. <p class="alert alert-success"><span class="alert-head"><?php echo _t ('ok'); ?></span> <?php echo _t ('general_conf_is_ok'); ?></p>
  437. <?php } ?>
  438. <form action="index.php?step=2" method="post">
  439. <legend><?php echo _t ('general_configuration'); ?></legend>
  440. <?php
  441. $url = substr ($_SERVER['PHP_SELF'], 0, -10);
  442. ?>
  443. <div class="form-group" style="display:none">
  444. <!-- TODO: if no problem during version 0.6, remove for version 0.7 -->
  445. <label class="group-name" for="base_url"><?php echo _t ('base_url'); ?></label>
  446. <div class="group-controls">
  447. <input type="text" id="base_url" name="base_url" value="<?php echo isset ($_SESSION['base_url']) ? $_SESSION['base_url'] : $url; ?>" /> <i class="icon i_help">ⓘ</i> <?php echo _t ('do_not_change_if_doubt'); ?>
  448. </div>
  449. </div>
  450. <div class="form-group">
  451. <label class="group-name" for="title"><?php echo _t ('title'); ?></label>
  452. <div class="group-controls">
  453. <input type="text" id="title" name="title" value="<?php echo isset ($_SESSION['title']) ? $_SESSION['title'] : _t ('freshrss'); ?>" />
  454. </div>
  455. </div>
  456. <div class="form-group">
  457. <label class="group-name" for="old_entries"><?php echo _t ('delete_articles_every'); ?></label>
  458. <div class="group-controls">
  459. <input type="number" id="old_entries" name="old_entries" value="<?php echo isset ($_SESSION['old_entries']) ? $_SESSION['old_entries'] : '3'; ?>" /> <?php echo _t ('month'); ?>
  460. </div>
  461. </div>
  462. <div class="form-group">
  463. <label class="group-name" for="default_user"><?php echo _t ('default_user'); ?></label>
  464. <div class="group-controls">
  465. <input type="text" id="default_user" name="default_user" maxlength="16" value="<?php echo isset ($_SESSION['default_user']) ? $_SESSION['default_user'] : ''; ?>" placeholder="user1" />
  466. </div>
  467. </div>
  468. <div class="form-group">
  469. <label class="group-name" for="mail_login"><?php echo _t ('persona_connection_email'); ?></label>
  470. <div class="group-controls">
  471. <input type="email" id="mail_login" name="mail_login" value="<?php echo isset ($_SESSION['mail_login']) ? $_SESSION['mail_login'] : ''; ?>" placeholder="<?php echo _t ('blank_to_disable'); ?>" />
  472. <noscript><b><?php echo _t ('javascript_should_be_activated'); ?></b></noscript>
  473. </div>
  474. </div>
  475. <div class="form-group form-actions">
  476. <div class="group-controls">
  477. <button type="submit" class="btn btn-important"><?php echo _t ('save'); ?></button>
  478. <button type="reset" class="btn"><?php echo _t ('cancel'); ?></button>
  479. <?php if ($s2['all'] == 'ok') { ?>
  480. <a class="btn btn-important next-step" href="?step=3"><?php echo _t ('next_step'); ?></a>
  481. <?php } ?>
  482. </div>
  483. </div>
  484. </form>
  485. <?php
  486. }
  487. function printStep3 () {
  488. ?>
  489. <?php $s3 = checkStep3 (); if ($s3['all'] == 'ok') { ?>
  490. <p class="alert alert-success"><span class="alert-head"><?php echo _t ('ok'); ?></span> <?php echo _t ('bdd_conf_is_ok'); ?></p>
  491. <?php } elseif ($s3['conn'] == 'ko') { ?>
  492. <p class="alert alert-error"><span class="alert-head"><?php echo _t ('damn'); ?></span> <?php echo _t ('bdd_conf_is_ko'); ?></p>
  493. <?php } ?>
  494. <form action="index.php?step=3" method="post">
  495. <legend><?php echo _t ('bdd_configuration'); ?></legend>
  496. <!--
  497. TODO : l'utilisation de SQLite n'est pas encore possible. Pour tester tout de même, décommentez ce bloc
  498. <div class="form-group">
  499. <label class="group-name" for="type"><?php echo _t ('bdd_type'); ?></label>
  500. <div class="group-controls">
  501. <select name="type" id="type">
  502. <option value="mysql"
  503. <?php echo (isset($_SESSION['bd_type']) && $_SESSION['bd_type'] === 'mysql') ? 'selected="selected"' : ''; ?>>
  504. MySQL
  505. </option>
  506. <option value="sqlite"
  507. <?php echo (isset($_SESSION['bd_type']) && $_SESSION['bd_type'] === 'sqlite') ? 'selected="selected"' : ''; ?>>
  508. SQLite
  509. </option>
  510. </select>
  511. </div>
  512. </div>
  513. -->
  514. <div class="form-group">
  515. <label class="group-name" for="host"><?php echo _t ('host'); ?></label>
  516. <div class="group-controls">
  517. <input type="text" id="host" name="host" value="<?php echo isset ($_SESSION['bd_host']) ? $_SESSION['bd_host'] : 'localhost'; ?>" />
  518. </div>
  519. </div>
  520. <div class="form-group">
  521. <label class="group-name" for="user"><?php echo _t ('username'); ?></label>
  522. <div class="group-controls">
  523. <input type="text" id="user" name="user" value="<?php echo isset ($_SESSION['bd_user']) ? $_SESSION['bd_user'] : ''; ?>" />
  524. </div>
  525. </div>
  526. <div class="form-group">
  527. <label class="group-name" for="pass"><?php echo _t ('password'); ?></label>
  528. <div class="group-controls">
  529. <input type="password" id="pass" name="pass" value="<?php echo isset ($_SESSION['bd_pass']) ? $_SESSION['bd_pass'] : ''; ?>" />
  530. </div>
  531. </div>
  532. <div class="form-group">
  533. <label class="group-name" for="base"><?php echo _t ('bdd'); ?></label>
  534. <div class="group-controls">
  535. <input type="text" id="base" name="base" maxlength="64" value="<?php echo isset ($_SESSION['bd_name']) ? $_SESSION['bd_name'] : ''; ?>" />
  536. </div>
  537. </div>
  538. <div class="form-group">
  539. <label class="group-name" for="prefix"><?php echo _t ('prefix'); ?></label>
  540. <div class="group-controls">
  541. <input type="text" id="prefix" name="prefix" maxlength="16" value="<?php echo isset ($_SESSION['bd_prefix']) ? $_SESSION['bd_prefix'] : 'freshrss_'; ?>" />
  542. </div>
  543. </div>
  544. <div class="form-group form-actions">
  545. <div class="group-controls">
  546. <button type="submit" class="btn btn-important"><?php echo _t ('save'); ?></button>
  547. <button type="reset" class="btn"><?php echo _t ('cancel'); ?></button>
  548. <?php if ($s3['all'] == 'ok') { ?>
  549. <a class="btn btn-important next-step" href="?step=4"><?php echo _t ('next_step'); ?></a>
  550. <?php } ?>
  551. </div>
  552. </div>
  553. </form>
  554. <?php
  555. }
  556. function printStep4 () {
  557. ?>
  558. <p class="alert alert-success"><span class="alert-head"><?php echo _t ('congratulations'); ?></span> <?php echo _t ('installation_is_ok'); ?></p>
  559. <a class="btn btn-important next-step" href="?step=5"><?php echo _t ('finish_installation'); ?></a>
  560. <?php
  561. }
  562. function printStep5 () {
  563. ?>
  564. <p class="alert alert-error"><span class="alert-head"><?php echo _t ('oops'); ?></span> <?php echo _t ('install_not_deleted', PUBLIC_PATH . '/install.php'); ?></p>
  565. <?php
  566. }
  567. initTranslate ();
  568. checkStep ();
  569. switch (STEP) {
  570. case 0:
  571. default:
  572. saveLanguage ();
  573. break;
  574. case 1:
  575. break;
  576. case 2:
  577. saveStep2 ();
  578. break;
  579. case 3:
  580. saveStep3 ();
  581. break;
  582. case 4:
  583. break;
  584. case 5:
  585. deleteInstall ();
  586. break;
  587. }
  588. ?>
  589. <!DOCTYPE html>
  590. <html lang="fr">
  591. <head>
  592. <meta charset="utf-8">
  593. <meta name="viewport" content="initial-scale=1.0">
  594. <title><?php echo _t ('freshrss_installation'); ?></title>
  595. <link rel="stylesheet" type="text/css" media="all" href="themes/default/global.css" />
  596. <link rel="stylesheet" type="text/css" media="all" href="themes/default/freshrss.css" />
  597. </head>
  598. <body>
  599. <div class="header">
  600. <div class="item title">
  601. <h1><a href="index.php"><?php echo _t ('freshrss'); ?></a></h1>
  602. <h2><?php echo _t ('installation_step', STEP); ?></h2>
  603. </div>
  604. </div>
  605. <div id="global">
  606. <ul class="nav nav-list aside">
  607. <li class="nav-header"><?php echo _t ('steps'); ?></li>
  608. <li class="item<?php echo STEP == 0 ? ' active' : ''; ?>"><a href="?step=0"><?php echo _t ('language'); ?></a></li>
  609. <li class="item<?php echo STEP == 1 ? ' active' : ''; ?>"><a href="?step=1"><?php echo _t ('checks'); ?></a></li>
  610. <li class="item<?php echo STEP == 2 ? ' active' : ''; ?>"><a href="?step=2"><?php echo _t ('general_configuration'); ?></a></li>
  611. <li class="item<?php echo STEP == 3 ? ' active' : ''; ?>"><a href="?step=3"><?php echo _t ('bdd_configuration'); ?></a></li>
  612. <li class="item<?php echo STEP == 4 ? ' active' : ''; ?>"><a href="?step=4"><?php echo _t ('this_is_the_end'); ?></a></li>
  613. </ul>
  614. <div class="post">
  615. <?php
  616. switch (STEP) {
  617. case 0:
  618. default:
  619. printStep0 ();
  620. break;
  621. case 1:
  622. printStep1 ();
  623. break;
  624. case 2:
  625. printStep2 ();
  626. break;
  627. case 3:
  628. printStep3 ();
  629. break;
  630. case 4:
  631. printStep4 ();
  632. break;
  633. case 5:
  634. printStep5 ();
  635. break;
  636. }
  637. ?>
  638. </div>
  639. </div>
  640. </body>
  641. </html>