mirror of
https://github.com/owncloudarchive/contacts.git
synced 2024-11-29 11:24:11 +01:00
53 lines
2.2 KiB
PHP
53 lines
2.2 KiB
PHP
<?php
|
|
/**
|
|
* @author Thomas Tanghus
|
|
* @copyright 2012-2014 Thomas Tanghus (thomas@tanghus.net)
|
|
* This file is licensed under the Affero General Public License version 3 or
|
|
* later.
|
|
* See the COPYING-README file.
|
|
*/
|
|
|
|
$installedVersion = OCP\Config::getAppValue('contacts', 'installed_version');
|
|
|
|
if (version_compare($installedVersion, '0.2.5', '>=')) {
|
|
// Set all address books active as (de)activating went awol at rewrite.
|
|
$stmt = OCP\DB::prepare('UPDATE `*PREFIX*contacts_addressbooks` SET `active`= 1');
|
|
$result = $stmt->execute(array());
|
|
} elseif (version_compare($installedVersion, '0.2.4', '==')) {
|
|
// First set all address books in-active.
|
|
$stmt = OCP\DB::prepare('UPDATE `*PREFIX*contacts_addressbooks` SET `active`=0');
|
|
$result = $stmt->execute(array());
|
|
|
|
// Then get all the active address books.
|
|
$stmt = OCP\DB::prepare('SELECT `userid`,`configvalue` FROM `*PREFIX*preferences` WHERE `appid`=\'contacts\' AND `configkey`=\'openaddressbooks\'');
|
|
$result = $stmt->execute(array());
|
|
|
|
// Prepare statement for updating the new 'active' field.
|
|
$stmt = OCP\DB::prepare('UPDATE `*PREFIX*contacts_addressbooks` SET `active`=? WHERE `id`=? AND `userid`=?');
|
|
while ($row = $result->fetchRow()) {
|
|
$ids = explode(';', $row['configvalue']);
|
|
foreach ($ids as $id) {
|
|
$r = $stmt->execute(array(1, $id, $row['userid']));
|
|
}
|
|
}
|
|
|
|
// Remove the old preferences.
|
|
$stmt = OCP\DB::prepare( 'DELETE FROM `*PREFIX*preferences` WHERE `appid`=\'contacts\' AND `configkey`=\'openaddressbooks\'');
|
|
$result = $stmt->execute(array());
|
|
}
|
|
if (version_compare($installedVersion, '0.3.0.14', '==')) {
|
|
// Rebuild this while we can
|
|
$stmt = OCP\DB::prepare('DELETE FROM `*PREFIX*contacts_ocu_cards`');
|
|
$result = $stmt->execute(array());
|
|
$stmt = OCP\DB::prepare('DELETE FROM `*PREFIX*contacts_ocu_cards_properties`');
|
|
$result = $stmt->execute(array());
|
|
}
|
|
|
|
if(version_compare($installedVersion, '0.3.0.18', '<')){
|
|
$stmt = OCP\DB::prepare('DELETE FROM `*PREFIX*contacts_cards_properties`
|
|
WHERE NOT EXISTS(SELECT NULL
|
|
FROM `*PREFIX*contacts_cards`
|
|
WHERE `*PREFIX*contacts_cards`.id = `*PREFIX*contacts_cards_properties`.contactid)');
|
|
$result = $stmt->execute(array());
|
|
}
|