Mise à jour possible depuis la v0.6 vers la v0.7

Implémente https://github.com/marienfressinaud/FreshRSS/issues/255
Il manque un peu de i18n et un peu de test, mais le gros est fait.
pull/326/head
Alexandre Alapetite 11 years ago
parent 385b5b1b40
commit 7ad124c69f
  1. 377
      public/install.php

@ -10,61 +10,125 @@ if (isset ($_GET['step'])) {
define ('STEP', 1);
}
define ('SQL_REQ_CREATE_DB', 'CREATE DATABASE %s DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;');
define ('SQL_REQ_CAT', 'CREATE TABLE IF NOT EXISTS `%scategory` (
`id` SMALLINT NOT NULL AUTO_INCREMENT, -- v0.7
`name` varchar(255) NOT NULL,
`color` char(7) NOT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY (`name`) -- v0.7
define ('SQL_CREATE_DB', 'CREATE DATABASE %1$s DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci;');
define ('SQL_CAT', 'CREATE TABLE IF NOT EXISTS `%1$scategory` (
`id` SMALLINT NOT NULL AUTO_INCREMENT, -- v0.7
`name` varchar(255) NOT NULL,
`color` char(7),
PRIMARY KEY (`id`),
UNIQUE KEY (`name`) -- v0.7
) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci
ENGINE = INNODB;');
define ('SQL_REQ_FEED', 'CREATE TABLE IF NOT EXISTS `%sfeed` (
`id` SMALLINT NOT NULL AUTO_INCREMENT, -- v0.7
`url` varchar(511) CHARACTER SET latin1 NOT NULL,
`category` SMALLINT DEFAULT 0, -- v0.7
`name` varchar(255) NOT NULL,
`website` varchar(255) CHARACTER SET latin1 NOT NULL,
`description` text NOT NULL,
`lastUpdate` int(11) NOT NULL,
`priority` tinyint(2) NOT NULL DEFAULT 10,
`pathEntries` varchar(511) DEFAULT NULL,
`httpAuth` varchar(511) DEFAULT NULL,
`error` boolean NOT NULL DEFAULT 0,
`keep_history` boolean NOT NULL DEFAULT 0,
`cache_nbEntries` int NOT NULL DEFAULT 0, -- v0.7
`cache_nbUnreads` int NOT NULL DEFAULT 0, -- v0.7
PRIMARY KEY (`id`),
FOREIGN KEY (`category`) REFERENCES `%scategory`(`id`) ON DELETE SET NULL ON UPDATE CASCADE,
UNIQUE KEY (`url`), -- v0.7
INDEX (`name`), -- v0.7
INDEX (`priority`), -- v0.7
INDEX (`keep_history`) -- v0.7
define ('SQL_FEED', 'CREATE TABLE IF NOT EXISTS `%1$sfeed` (
`id` SMALLINT NOT NULL AUTO_INCREMENT, -- v0.7
`url` varchar(511) CHARACTER SET latin1 NOT NULL,
`category` SMALLINT DEFAULT 0, -- v0.7
`name` varchar(255) NOT NULL,
`website` varchar(255) CHARACTER SET latin1,
`description` text,
`lastUpdate` int(11) DEFAULT 0,
`priority` tinyint(2) NOT NULL DEFAULT 10,
`pathEntries` varchar(511) DEFAULT NULL,
`httpAuth` varchar(511) DEFAULT NULL,
`error` boolean DEFAULT 0,
`keep_history` boolean NOT NULL DEFAULT 0,
`cache_nbEntries` int DEFAULT 0, -- v0.7
`cache_nbUnreads` int DEFAULT 0, -- v0.7
PRIMARY KEY (`id`),
FOREIGN KEY (`category`) REFERENCES `%1$scategory`(`id`) ON DELETE SET NULL ON UPDATE CASCADE,
UNIQUE KEY (`url`), -- v0.7
INDEX (`name`), -- v0.7
INDEX (`priority`), -- v0.7
INDEX (`keep_history`) -- v0.7
) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci
ENGINE = INNODB;');
define ('SQL_REQ_ENTRY', 'CREATE TABLE IF NOT EXISTS `%sentry` (
`id` bigint NOT NULL, -- v0.7
`guid` varchar(760) CHARACTER SET latin1 NOT NULL, -- Maximum for UNIQUE is 767B
`title` varchar(255) NOT NULL,
`author` varchar(255) NOT NULL,
`content_bin` blob NOT NULL, -- v0.7
`link` varchar(1023) CHARACTER SET latin1 NOT NULL,
`date` int(11) NOT NULL,
`is_read` boolean NOT NULL DEFAULT 0,
`is_favorite` boolean NOT NULL DEFAULT 0,
`id_feed` SMALLINT NOT NULL, -- v0.7
`tags` varchar(1023) NOT NULL,
PRIMARY KEY (`id`),
FOREIGN KEY (`id_feed`) REFERENCES `%sfeed`(`id`) ON DELETE CASCADE ON UPDATE CASCADE,
UNIQUE KEY (`id_feed`,`guid`), -- v0.7
INDEX (`is_favorite`), -- v0.7
INDEX (`is_read`) -- v0.7
define ('SQL_ENTRY', 'CREATE TABLE IF NOT EXISTS `%1$sentry` (
`id` bigint NOT NULL, -- v0.7
`guid` varchar(760) CHARACTER SET latin1 NOT NULL, -- Maximum for UNIQUE is 767B
`title` varchar(255) NOT NULL,
`author` varchar(255),
`content_bin` blob, -- v0.7
`link` varchar(1023) CHARACTER SET latin1 NOT NULL,
`date` int(11),
`is_read` boolean NOT NULL DEFAULT 0,
`is_favorite` boolean NOT NULL DEFAULT 0,
`id_feed` SMALLINT, -- v0.7
`tags` varchar(1023),
PRIMARY KEY (`id`),
FOREIGN KEY (`id_feed`) REFERENCES `%1$sfeed`(`id`) ON DELETE CASCADE ON UPDATE CASCADE,
UNIQUE KEY (`id_feed`,`guid`), -- v0.7
INDEX (`is_favorite`), -- v0.7
INDEX (`is_read`) -- v0.7
) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci
ENGINE = INNODB;');
//<updates>
define('SQL_SHOW_TABLES', 'SHOW tables;');
define('SQL_BACKUP006', 'RENAME TABLE `%1$scategory` TO `%1$scategory006`, `%1$sfeed` TO `%1$sfeed006`, `%1$sentry` TO `%1$sentry006`;');
define('SQL_SHOW_COLUMNS_UPDATEv006', 'SHOW columns FROM `%1$sentry006` LIKE "id2";');
define('SQL_UPDATEv006', '
ALTER TABLE `%1$scategory006` ADD id2 SMALLINT;
SET @i = 0;
UPDATE `%1$scategory006` SET id2=(@i:=@i+1) ORDER BY id;
ALTER TABLE `%1$sfeed006` ADD id2 SMALLINT, ADD category2 SMALLINT;
SET @i = 0;
UPDATE `%1$sfeed006` SET id2=(@i:=@i+1) ORDER BY name;
UPDATE `%1$sfeed006` f
INNER JOIN `%1$scategory006` c ON f.category = c.id
SET f.category2 = c.id2;
INSERT IGNORE INTO `%2$scategory` (name, color)
SELECT name, color
FROM `%1$scategory006`
ORDER BY id2;
INSERT IGNORE INTO `%2$sfeed` (url, category, name, website, description, priority, pathEntries, httpAuth, keep_history)
SELECT url, category2, name, website, description, priority, pathEntries, httpAuth, keep_history
FROM `%1$sfeed006`
ORDER BY id2;
ALTER TABLE `%1$sentry006` ADD id2 bigint;
UPDATE `%1$sentry006` SET id2 = ((date * 1000000) + (rand() * 100000000));
INSERT IGNORE INTO `%2$sentry` (id, guid, title, author, link, date, is_read, is_favorite, id_feed, tags)
SELECT e0.id2, e0.guid, e0.title, e0.author, e0.link, e0.date, e0.is_read, e0.is_favorite, f0.id2, e0.tags
FROM `%1$sentry006` e0
INNER JOIN `%1$sfeed006` f0 ON e0.id_feed = f0.id;
');
define('SQL_CONVERT_SELECTv006', '
SELECT e0.id2, e0.content
FROM `%1$sentry006` e0
INNER JOIN `%2$sentry` e1 ON e0.id2 = e1.id
WHERE e1.content_bin IS NULL');
define('SQL_CONVERT_UPDATEv006', 'UPDATE `%1$sentry` SET content_bin=COMPRESS(?) WHERE id=?;');
define('SQL_UPDATE_CACHED_VALUESv006', '
UPDATE `%1$sfeed` f
INNER JOIN (
SELECT e.id_feed,
COUNT(CASE WHEN e.is_read = 0 THEN 1 END) AS nbUnreads,
COUNT(e.id) AS nbEntries
FROM `%1$sentry` e
GROUP BY e.id_feed
) x ON x.id_feed=f.id
SET f.cache_nbEntries=x.nbEntries, f.cache_nbUnreads=x.nbUnreads
');
define('SQL_DROP_BACKUPv006', 'DROP TABLE IF EXISTS `%1$sentry006`, `%1$sfeed006`, `%1$scategory006`;');
//</updates>
function writeLine ($f, $line) {
fwrite ($f, $line . "\n");
@ -191,6 +255,7 @@ function saveStep3 () {
$_SESSION['bd_password'] = addslashes ($_POST['pass']);
$_SESSION['bd_base'] = addslashes ($_POST['base']);
$_SESSION['bd_prefix'] = addslashes ($_POST['prefix']);
$_SESSION['bd_prefix_user'] = $_SESSION['bd_prefix'] . (empty($_SESSION['default_user']) ? '' : ($_SESSION['default_user'] . '_'));
$file_conf = DATA_PATH . '/application.ini';
$f = fopen ($file_conf, 'w');
@ -210,7 +275,6 @@ function saveStep3 () {
writeLine ($f, 'prefix = "' . $_SESSION['bd_prefix'] . '"');
fclose ($f);
$_SESSION['bd_prefix_user'] = $_SESSION['bd_prefix'] . (empty($_SESSION['default_user']) ? '' : ($_SESSION['default_user'] . '_'));
$res = checkBD ();
if ($res) {
@ -222,11 +286,125 @@ function saveStep3 () {
}
invalidateHttpCache();
}
function updateDatabase($perform = false) {
$needs = array('bd_type', 'bd_host', 'bd_base', 'bd_user', 'bd_password', 'bd_prefix', 'bd_prefix_user');
foreach ($needs as $need) {
if (!isset($_SESSION[$need])) {
return false;
}
}
try {
$str = '';
switch ($_SESSION['bd_type']) {
case 'mysql':
$str = 'mysql:host=' . $_SESSION['bd_host'] . ';dbname=' . $_SESSION['bd_base'];
$driver_options = array(
PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8',
);
break;
case 'sqlite':
$str = 'sqlite:' . DATA_PATH . $_SESSION['bd_base'] . '.sqlite';
$driver_options = null;
break;
default:
return false;
}
$c = new PDO($str, $_SESSION['bd_user'], $_SESSION['bd_password'], $driver_options);
$stm = $c->prepare(SQL_SHOW_TABLES);
$stm->execute();
$res = $stm->fetchAll(PDO::FETCH_COLUMN, 0);
if (!in_array($_SESSION['bd_prefix'] . 'entry006', $res)) {
return false;
}
$sql = sprintf(SQL_SHOW_COLUMNS_UPDATEv006, $_SESSION['bd_prefix']);
$stm = $c->prepare($sql);
$stm->execute();
$res = $stm->fetchAll(PDO::FETCH_COLUMN, 0);
if (!in_array('id2', $res)) {
if (!$perform) {
return true;
}
$sql = sprintf(SQL_UPDATEv006, $_SESSION['bd_prefix'], $_SESSION['bd_prefix_user']);
$stm = $c->prepare($sql, array(PDO::ATTR_EMULATE_PREPARES => true));
$stm->execute();
}
$sql = sprintf(SQL_UPDATE_CACHED_VALUESv006, $_SESSION['bd_prefix_user']);
$stm = $c->prepare($sql);
$stm->execute();
$sql = sprintf(SQL_CONVERT_SELECTv006, $_SESSION['bd_prefix'], $_SESSION['bd_prefix_user']);
if (!$perform) {
$sql .= ' LIMIT 1';
}
$stm = $c->prepare($sql);
$stm->execute();
if (!$perform) {
$res = $stm->fetchAll(PDO::FETCH_COLUMN, 0);
return count($res) > 0;
} else {
@set_time_limit(300);
}
$c2 = new PDO($str, $_SESSION['bd_user'], $_SESSION['bd_password'], $driver_options);
$sql = sprintf(SQL_CONVERT_UPDATEv006, $_SESSION['bd_prefix_user']);
$stm2 = $c2->prepare($sql);
while ($row = $stm->fetch(PDO::FETCH_ASSOC)) {
$id = $row['id2'];
$content = unserialize(gzinflate(base64_decode($row['content'])));
$stm2->execute(array($content, $id));
}
return true;
} catch (PDOException $e) {
return false;
}
return false;
}
function deleteInstall () {
$res = unlink (PUBLIC_PATH . '/install.php');
if ($res) {
header ('Location: index.php');
}
$needs = array('bd_type', 'bd_host', 'bd_base', 'bd_user', 'bd_password', 'bd_prefix');
foreach ($needs as $need) {
if (!isset($_SESSION[$need])) {
return false;
}
}
try {
switch ($_SESSION['bd_type']) {
case 'mysql':
$str = 'mysql:host=' . $_SESSION['bd_host'] . ';dbname=' . $_SESSION['bd_base'];
$driver_options = array(
PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8',
);
break;
case 'sqlite':
$str = 'sqlite:' . DATA_PATH . $_SESSION['bd_base'] . '.sqlite';
$driver_options = null;
break;
default:
return false;
}
$c = new PDO($str, $_SESSION['bd_user'], $_SESSION['bd_password'], $driver_options);
$sql = sprintf(SQL_DROP_BACKUPv006, $_SESSION['bd_prefix']);
$stm = $c->prepare($sql);
$stm->execute();
return true;
} catch (PDOException $e) {
return false;
}
return false;
}
function moveOldFiles() {
@ -366,11 +544,11 @@ function checkStep1 () {
}
function checkStep2 () {
$conf = isset ($_SESSION['sel_application']) &&
isset ($_SESSION['title']) &&
isset ($_SESSION['old_entries']) &&
isset ($_SESSION['mail_login']) &&
isset ($_SESSION['default_user']);
$conf = !empty($_SESSION['sel_application']) &&
!empty($_SESSION['title']) &&
!empty($_SESSION['old_entries']) &&
isset($_SESSION['mail_login']) &&
!empty($_SESSION['default_user']);
$defaultUser = empty($_POST['default_user']) ? null : $_POST['default_user'];
if ($defaultUser === null) {
$defaultUser = empty($_SESSION['default_user']) ? '' : $_SESSION['default_user'];
@ -394,7 +572,8 @@ function checkStep3 () {
isset ($_SESSION['bd_user']) &&
isset ($_SESSION['bd_password']) &&
isset ($_SESSION['bd_base']) &&
isset ($_SESSION['bd_prefix']);
isset ($_SESSION['bd_prefix']) &&
isset ($_SESSION['bd_error']);
$conn = !isset ($_SESSION['bd_error']) || !$_SESSION['bd_error'];
return array (
@ -410,47 +589,54 @@ function checkBD () {
try {
$str = '';
$driver_options = null;
if($_SESSION['bd_type'] == 'mysql') {
$driver_options = array(
PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8'
);
// on ouvre une connexion juste pour créer la base si elle n'existe pas
$str = 'mysql:host=' . $_SESSION['bd_host'] . ';';
$c = new PDO ($str,
$_SESSION['bd_user'],
$_SESSION['bd_password'],
$driver_options);
$sql = sprintf (SQL_REQ_CREATE_DB, $_SESSION['bd_base']);
$res = $c->query ($sql);
// on écrase la précédente connexion en sélectionnant la nouvelle BDD
$str = 'mysql:host=' . $_SESSION['bd_host'] . ';dbname=' . $_SESSION['bd_base'];
} elseif($_SESSION['bd_type'] == 'sqlite') {
$str = 'sqlite:' . DATA_PATH . $_SESSION['bd_base'] . '.sqlite';
switch ($_SESSION['bd_type']) {
case 'mysql':
$driver_options = array(
PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8'
);
// on ouvre une connexion juste pour créer la base si elle n'existe pas
$str = 'mysql:host=' . $_SESSION['bd_host'] . ';';
$c = new PDO ($str, $_SESSION['bd_user'], $_SESSION['bd_password'], $driver_options);
$sql = sprintf (SQL_CREATE_DB, $_SESSION['bd_base']);
$res = $c->query ($sql);
// on écrase la précédente connexion en sélectionnant la nouvelle BDD
$str = 'mysql:host=' . $_SESSION['bd_host'] . ';dbname=' . $_SESSION['bd_base'];
break;
case 'sqlite':
$str = 'sqlite:' . DATA_PATH . $_SESSION['bd_base'] . '.sqlite';
break;
default:
return false;
}
$c = new PDO ($str,
$_SESSION['bd_user'],
$_SESSION['bd_password'],
$driver_options);
$c = new PDO ($str, $_SESSION['bd_user'], $_SESSION['bd_password'], $driver_options);
$stm = $c->prepare(SQL_SHOW_TABLES);
$stm->execute();
$res = $stm->fetchAll(PDO::FETCH_COLUMN, 0);
if (in_array($_SESSION['bd_prefix'] . 'entry', $res) && !in_array($_SESSION['bd_prefix'] . 'entry006', $res)) {
$sql = sprintf(SQL_BACKUP006, $_SESSION['bd_prefix']); //v0.6
$res = $c->query($sql); //Backup tables
}
$sql = sprintf (SQL_REQ_CAT, $_SESSION['bd_prefix_user']);
$sql = sprintf (SQL_CAT, $_SESSION['bd_prefix_user']);
$res = $c->query ($sql);
if (!$res) {
$error = true;
}
$sql = sprintf (SQL_REQ_FEED, $_SESSION['bd_prefix_user'], $_SESSION['bd_prefix_user']);
$sql = sprintf (SQL_FEED, $_SESSION['bd_prefix_user']);
$res = $c->query ($sql);
if (!$res) {
$error = true;
}
$sql = sprintf (SQL_REQ_ENTRY, $_SESSION['bd_prefix_user'], $_SESSION['bd_prefix_user']);
$sql = sprintf (SQL_ENTRY, $_SESSION['bd_prefix_user']);
$res = $c->query ($sql);
if (!$res) {
@ -701,12 +887,30 @@ function printStep3 () {
function printStep4 () {
?>
<p class="alert alert-success"><span class="alert-head"><?php echo _t ('congratulations'); ?></span> <?php echo _t ('installation_is_ok'); ?></p>
<a class="btn btn-important next-step" href="?step=5"><?php echo _t ('finish_installation'); ?></a>
<form action="index.php?step=4" method="post">
<legend><?php echo _t ('bdd_update'); ?></legend>
<div class="form-group form-actions">
<div class="group-controls">
<?php if (updateDatabase(false)) { ?>
<input type="hidden" name="updateDatabase" value="1" />
<button type="submit" class="btn btn-important"><?php echo _t ('start'); ?></button> (This can take a long time, depending on the size of your database. You may have to wait for this page to time out (~5 minutes) and then refresh this page.)
<?php } else { ?>
<a class="btn btn-important next-step" href="?step=5"><?php echo _t ('next_step'); ?></a>
<?php } ?>
</div>
</div>
</form>
<?php
}
function printStep5 () {
?>
<p class="alert alert-success"><span class="alert-head"><?php echo _t ('congratulations'); ?></span> <?php echo _t ('installation_is_ok'); ?></p>
<a class="btn btn-important next-step" href="?step=6"><?php echo _t ('finish_installation'); ?></a>
<?php
}
function printStep6 () {
?>
<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>
<?php
@ -730,8 +934,13 @@ case 3:
saveStep3 ();
break;
case 4:
if (!empty($_POST['updateDatabase'])) {
updateDatabase(true);
}
break;
case 5:
break;
case 6:
deleteInstall ();
break;
}
@ -761,7 +970,8 @@ case 5:
<li class="item<?php echo STEP == 1 ? ' active' : ''; ?>"><a href="?step=1"><?php echo _t ('checks'); ?></a></li>
<li class="item<?php echo STEP == 2 ? ' active' : ''; ?>"><a href="?step=2"><?php echo _t ('general_configuration'); ?></a></li>
<li class="item<?php echo STEP == 3 ? ' active' : ''; ?>"><a href="?step=3"><?php echo _t ('bdd_configuration'); ?></a></li>
<li class="item<?php echo STEP == 4 ? ' active' : ''; ?>"><a href="?step=4"><?php echo _t ('this_is_the_end'); ?></a></li>
<li class="item<?php echo STEP == 4 ? ' active' : ''; ?>"><a href="?step=4"><?php echo _t ('bdd_update'); ?></a></li>
<li class="item<?php echo STEP == 5 ? ' active' : ''; ?>"><a href="?step=5"><?php echo _t ('this_is_the_end'); ?></a></li>
</ul>
<div class="post">
@ -786,6 +996,9 @@ case 5:
case 5:
printStep5 ();
break;
case 6:
printStep6 ();
break;
}
?>
</div>

Loading…
Cancel
Save