1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/webtrees_ynh.git synced 2024-09-03 18:26:37 +02:00
webtrees_ynh/sources/admin_pgv_to_wt.php

1155 lines
48 KiB
PHP
Raw Normal View History

<?php
/**
* webtrees: online genealogy
* Copyright (C) 2016 webtrees development team
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
namespace Fisharebest\Webtrees;
use Fisharebest\Webtrees\Controller\PageController;
use PDO;
use PDOException;
/**
* Defined in session.php
*
* @global Tree $WT_TREE
*/
global $WT_TREE;
define('WT_SCRIPT_NAME', 'admin_pgv_to_wt.php');
require './includes/session.php';
// We can only import into an empty system, so deny access if we have already created a gedcom or added users.
if ($WT_TREE || count(User::all()) > 1) {
header('Location: ' . WT_BASE_URL);
return;
}
$controller = new PageController;
$controller
->restrictAccess(Auth::isAdmin())
->setPageTitle(I18N::translate('PhpGedView to webtrees transfer wizard'));
$error = false;
$PGV_PATH = Filter::post('PGV_PATH');
// We read these variables from PhpGedView's config.php, and set them here in case any are missing.
$INDEX_DIRECTORY = '';
$DBHOST = '';
$DBNAME = '';
$TBLPREFIX = '';
$PGV_SCHEMA_VERSION = '';
$USE_REGISTRATION_MODULE = '';
$ALLOW_USER_THEMES = '';
$ALLOW_CHANGE_GEDCOM = '';
$PGV_SESSION_TIME = '';
$PGV_SMTP_ACTIVE = '';
$PGV_SMTP_HOST = '';
$PGV_SMTP_HELO = '';
$PGV_SMTP_PORT = '';
$PGV_SMTP_AUTH = '';
$PGV_SMTP_AUTH_USER = '';
$PGV_SMTP_AUTH_PASS = '';
$PGV_SMTP_SSL = '';
$PGV_SMTP_FROM_NAME = '';
if ($PGV_PATH) {
if (!is_dir($PGV_PATH) || !is_readable($PGV_PATH . '/config.php')) {
FlashMessages::addMessage('The specified folder does not contain an installation of PhpGedView.', 'danger');
$PGV_PATH = null;
} else {
// Load the configuration settings
$config_php = file_get_contents($PGV_PATH . '/config.php');
// The easiest way to do this is to exec() the file - but not lines containing require or PHP tags
$config_php = preg_replace(
array(
'/^\s*(include|require).*/m',
'/.*<\?php.*/',
'/.*\?>.*/',
), '', $config_php
);
eval($config_php);
// $INDEX_DIRECTORY can be either absolute or relative to the PhpGedView root.
if (preg_match('/^(\/|\\|[A-Z]:)/', $INDEX_DIRECTORY)) {
$INDEX_DIRECTORY = realpath($INDEX_DIRECTORY) . DIRECTORY_SEPARATOR;
} else {
$INDEX_DIRECTORY = realpath($PGV_PATH . '/' . $INDEX_DIRECTORY) . DIRECTORY_SEPARATOR;
}
$wt_config = parse_ini_file(WT_ROOT . 'data/config.ini.php');
if ($DBHOST != $wt_config['dbhost']) {
FlashMessages::addMessage(I18N::translate('PhpGedView must use the same database as webtrees.', 'danger'));
$PGV_PATH = null;
unset($wt_config);
} else {
unset($wt_config);
try {
$PGV_SCHEMA_VERSION = Database::prepare(
"SELECT site_setting_value FROM `{$DBNAME}`.`{$TBLPREFIX}site_setting` WHERE site_setting_name='PGV_SCHEMA_VERSION'"
)->fetchOne();
if ($PGV_SCHEMA_VERSION < 10) {
FlashMessages::addMessage(I18N::translate('The version of %s is too old.', 'PhpGedView'), 'danger');
$PGV_PATH = null;
} elseif ($PGV_SCHEMA_VERSION > 14) {
FlashMessages::addMessage(I18N::translate('The version of %s is too new.', 'PhpGedView'), 'danger');
$PGV_PATH = null;
}
} catch (PDOException $ex) {
FlashMessages::addMessage(
/* I18N: %s is a database name/identifier */
I18N::translate('webtrees cannot connect to the PhpGedView database: %s.', $DBNAME . '@' . $DBHOST) .
'<br>' .
/* I18N: %s is an error message */
I18N::translate('MySQL gave the error: %s', $ex->getMessage()), 'danger');
$PGV_PATH = null;
}
}
}
}
if ($PGV_PATH) {
// The account we are using is about to be deleted.
Session::forget('wt_user');
}
$controller->pageHeader();
?>
<ol class="breadcrumb small">
<li><a href="admin.php"><?php echo I18N::translate('Control panel'); ?></a></li>
<li><a href="admin_trees_manage.php"><?php echo I18N::translate('Manage family trees'); ?></a></li>
<li class="active"><?php echo $controller->getPageTitle(); ?></li>
</ol>
<h1><?php echo $controller->getPageTitle(); ?></h1>
<?php
if (!$PGV_PATH) {
// Look for PhpGedView in some nearby directories
$pgv_dirs = array();
$dir = opendir(realpath('..'));
while (($subdir = readdir($dir)) !== false) {
// Exclude '..' as ascending too many levels can trigger open_basedir_restriction errors.
if ($subdir !== '..' && is_dir('../' . $subdir) && file_exists('../' . $subdir . '/config.php')) {
$pgv_dirs[] = '../' . $subdir;
}
}
closedir($dir);
if (count($pgv_dirs) > 1) {
$html = I18N::translate('PhpGedView might be installed in one of these folders:');
foreach ($pgv_dirs as $pgv_dir) {
$html .= '<div onclick="jQuery(\'#PGV_PATH\').val(\'' . Filter::escapeHtml($pgv_dir) . '\')">' . Filter::escapeHtml($pgv_dir) . '</div>';
}
echo Theme::theme()->htmlAlert($html, 'info', true);
}
?>
<form class="form-horizontal" method="post">
<div class="form-group">
<label class="control-label col-sm-3" for="PGV_PATH">
<?php echo I18N::translate('Where is your PhpGedView installation?'); ?>
</label>
<div class="col-sm-9">
<input
type="text"
class="form-control"
dir="ltr"
id="PGV_PATH"
name="PGV_PATH"
size="40"
placeholder="<?php echo I18N::translate('Installation folder'); ?>"
value="<?php echo count($pgv_dirs) === 1 ? Filter::escapeHtml($pgv_dirs[0]) : ''; ?>"
required
>
</div>
</div>
<div class="form-group">
<div class="col-sm-offset-3 col-sm-9">
<button type="submit" class="btn btn-primary">
<?php echo I18N::translate('continue'); ?>
</button>
</div>
</div>
</form>
<?php
return;
}
// Run in a transaction
Database::beginTransaction();
// Delete the existing user accounts, and any information associated with it
Database::exec("UPDATE `##log` SET user_id=NULL");
Database::exec("DELETE FROM `##change`");
Database::exec("DELETE `##block_setting` FROM `##block_setting` JOIN `##block` USING (block_id) WHERE user_id>0 OR gedcom_id>0");
Database::exec("DELETE FROM `##block` WHERE user_id>0 OR gedcom_id>0");
Database::exec("DELETE FROM `##message`");
Database::exec("DELETE FROM `##user_gedcom_setting` WHERE user_id>0");
Database::exec("DELETE FROM `##user_setting` WHERE user_id>0");
Database::exec("DELETE FROM `##user` WHERE user_id>0");
////////////////////////////////////////////////////////////////////////////////
echo '<p>', $INDEX_DIRECTORY, 'config.php => wt_site_setting…</p>';
Site::setPreference('USE_REGISTRATION_MODULE', $USE_REGISTRATION_MODULE);
Site::setPreference('ALLOW_USER_THEMES', $ALLOW_USER_THEMES);
Site::setPreference('ALLOW_CHANGE_GEDCOM', $ALLOW_CHANGE_GEDCOM);
Site::setPreference('SESSION_TIME', $PGV_SESSION_TIME);
Site::setPreference('SMTP_ACTIVE', $PGV_SMTP_ACTIVE ? 'external' : 'internal');
Site::setPreference('SMTP_HOST', $PGV_SMTP_HOST);
Site::setPreference('SMTP_HELO', $PGV_SMTP_HELO);
Site::setPreference('SMTP_PORT', $PGV_SMTP_PORT);
Site::setPreference('SMTP_AUTH', $PGV_SMTP_AUTH);
Site::setPreference('SMTP_AUTH_USER', $PGV_SMTP_AUTH_USER);
Site::setPreference('SMTP_AUTH_PASS', $PGV_SMTP_AUTH_PASS);
Site::setPreference('SMTP_SSL', $PGV_SMTP_SSL);
Site::setPreference('SMTP_FROM_NAME', $PGV_SMTP_FROM_NAME);
////////////////////////////////////////////////////////////////////////////////
echo '<p>pgv_site_setting => wt_site_setting…</p>';
Database::prepare(
"REPLACE INTO `##site_setting` (setting_name, setting_value)" .
" SELECT site_setting_name, site_setting_value FROM `{$DBNAME}`.`{$TBLPREFIX}site_setting`" .
" WHERE site_setting_name IN ('DEFAULT_GEDCOM', 'LAST_CHANGE_EMAIL')"
)->execute();
////////////////////////////////////////////////////////////////////////////////
if ($PGV_SCHEMA_VERSION >= 12) {
echo '<p>pgv_gedcom => wt_gedcom…</p>';
Database::prepare(
"INSERT INTO `##gedcom` (gedcom_id, gedcom_name)" .
" SELECT gedcom_id, gedcom_name FROM `{$DBNAME}`.`{$TBLPREFIX}gedcom`"
)->execute();
echo '<p>pgv_gedcom_setting => wt_gedcom_setting…</p>';
Database::prepare(
"INSERT INTO `##gedcom_setting` (gedcom_id, setting_name, setting_value)" .
" SELECT gedcom_id, setting_name," .
" CASE setting_name" .
" WHEN 'THEME_DIR' THEN" .
" CASE setting_value" .
" WHEN '' THEN ''" .
" WHEN 'themes/cloudy/' THEN 'clouds'" .
" WHEN 'themes/minimal/' THEN 'minimal'" .
" WHEN 'themes/simplyblue/' THEN 'colors'" .
" WHEN 'themes/simplygreen/' THEN 'colors'" .
" WHEN 'themes/simplyred/' THEN 'colors'" .
" WHEN 'themes/xenea/' THEN 'xenea'" .
" ELSE 'themes/webtrees/'" . // ocean, simplyred/blue/green, standard, wood
" END" .
" WHEN 'LANGUAGE' THEN" .
" CASE setting_value" .
" WHEN 'arabic' THEN 'ar'" .
" WHEN 'catalan' THEN 'ca'" .
" WHEN 'chinese' THEN 'zh_CN'" .
" WHEN 'croatian' THEN 'hr'" .
" WHEN 'danish' THEN 'da'" .
" WHEN 'dutch' THEN 'nl'" .
" WHEN 'english' THEN 'en_US'" .
" WHEN 'english-uk' THEN 'en_GB'" . // PhpGedView once had the config for this, but no language files
" WHEN 'estonian' THEN 'et'" .
" WHEN 'finnish' THEN 'fi'" .
" WHEN 'french' THEN 'fr'" .
" WHEN 'german' THEN 'de'" .
" WHEN 'greek' THEN 'el'" .
" WHEN 'hebrew' THEN 'he'" .
" WHEN 'hungarian' THEN 'hu'" .
" WHEN 'indonesian' THEN 'id'" .
" WHEN 'italian' THEN 'it'" .
" WHEN 'lithuanian' THEN 'lt'" .
" WHEN 'norwegian' THEN 'nn'" .
" WHEN 'polish' THEN 'pl'" .
" WHEN 'portuguese' THEN 'pt'" .
" WHEN 'romainian' THEN 'ro'" .
" WHEN 'russian' THEN 'ru'" .
" WHEN 'serbian-la' THEN 'sr@Latn'" .
" WHEN 'slovak' THEN 'sk'" .
" WHEN 'slovenian' THEN 'sl'" .
" WHEN 'spanish' THEN 'es'" .
" WHEN 'spanish-ar' THEN 'es'" . // webtrees does not yet have this variant
" WHEN 'swedish' THEN 'sv'" .
" WHEN 'turkish' THEN 'tr'" .
" WHEN 'vietnamese' THEN 'vi'" .
" ELSE 'en_US'" .
" END" .
" ELSE setting_value" .
" END" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}gedcom_setting`" .
" WHERE setting_name NOT IN ('HOME_SITE_TEXT', 'HOME_SITE_URL')"
)->execute();
echo '<p>pgv_user => wt_user…</p>';
try {
// "INSERT IGNORE" is needed to allow for PhpGedView users with duplicate emails. Only the first will be imported.
Database::prepare(
"INSERT IGNORE INTO `##user` (user_id, user_name, real_name, email, password)" .
" SELECT user_id, user_name, CONCAT_WS(' ', us1.setting_value, us2.setting_value), us3.setting_value, password FROM `{$DBNAME}`.`{$TBLPREFIX}user`" .
" LEFT JOIN `{$DBNAME}`.`{$TBLPREFIX}user_setting` us1 USING (user_id)" .
" LEFT JOIN `{$DBNAME}`.`{$TBLPREFIX}user_setting` us2 USING (user_id)" .
" JOIN `{$DBNAME}`.`{$TBLPREFIX}user_setting` us3 USING (user_id)" .
" WHERE us1.setting_name='firstname'" .
" AND us2.setting_name='lastname'" .
" AND us3.setting_name='email'"
)->execute();
} catch (PDOException $ex) {
// Ignore duplicates
}
echo '<p>pgv_user_setting => wt_user_setting…</p>';
Database::prepare(
"INSERT INTO `##user_setting` (user_id, setting_name, setting_value)" .
" SELECT user_id, setting_name," .
" CASE setting_name" .
" WHEN 'language' THEN " .
" CASE setting_value" .
" WHEN 'arabic' THEN 'ar'" .
" WHEN 'catalan' THEN 'ca'" .
" WHEN 'chinese' THEN 'zh_CN'" .
" WHEN 'croatian' THEN 'hr'" .
" WHEN 'danish' THEN 'da'" .
" WHEN 'dutch' THEN 'nl'" .
" WHEN 'english' THEN 'en_US'" .
" WHEN 'english-uk' THEN 'en_GB'" . // PhpGedView once had the config for this, but no language files
" WHEN 'estonian' THEN 'et'" .
" WHEN 'finnish' THEN 'fi'" .
" WHEN 'french' THEN 'fr'" .
" WHEN 'german' THEN 'de'" .
" WHEN 'greek' THEN 'el'" .
" WHEN 'hebrew' THEN 'he'" .
" WHEN 'hungarian' THEN 'hu'" .
" WHEN 'indonesian' THEN 'id'" .
" WHEN 'italian' THEN 'it'" .
" WHEN 'lithuanian' THEN 'lt'" .
" WHEN 'norwegian' THEN 'nn'" .
" WHEN 'polish' THEN 'pl'" .
" WHEN 'portuguese' THEN 'pt'" .
" WHEN 'romainian' THEN 'ro'" .
" WHEN 'russian' THEN 'ru'" .
" WHEN 'serbian-la' THEN 'sr@Latn'" .
" WHEN 'slovak' THEN 'sk'" .
" WHEN 'slovenian' THEN 'sl'" .
" WHEN 'spanish' THEN 'es'" .
" WHEN 'spanish-ar' THEN 'es'" . // webtrees does not yet have this variant
" WHEN 'swedish' THEN 'sv'" .
" WHEN 'turkish' THEN 'tr'" .
" WHEN 'vietnamese' THEN 'vi'" .
" ELSE 'en_US'" .
" END" .
" WHEN 'theme' THEN" .
" CASE setting_value" .
" WHEN '' THEN ''" .
" WHEN 'themes/cloudy/' THEN 'clouds'" .
" WHEN 'themes/minimal/' THEN 'minimal'" .
" WHEN 'themes/simplyblue/' THEN 'colors'" .
" WHEN 'themes/simplygreen/' THEN 'colors'" .
" WHEN 'themes/simplyred/' THEN 'colors'" .
" WHEN 'themes/xenea/' THEN 'xenea'" .
" ELSE 'themes/webtrees/'" . // ocean, simplyred/blue/green, standard, wood
" END" .
" ELSE" .
" CASE" .
" WHEN setting_value IN ('Y', 'yes') THEN 1 WHEN setting_value IN ('N', 'no') THEN 0 ELSE setting_value END" .
" END" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}user_setting`" .
" JOIN `##user` USING (user_id)" .
" WHERE setting_name NOT IN ('email', 'firstname', 'lastname', 'loggedin')"
)->execute();
echo '<p>pgv_user_gedcom_setting => wt_user_gedcom_setting…</p>';
Database::prepare(
"INSERT INTO `##user_gedcom_setting` (user_id, gedcom_id, setting_name, setting_value)" .
" SELECT user_id, gedcom_id, setting_name, setting_value FROM `{$DBNAME}`.`{$TBLPREFIX}user_gedcom_setting`" .
" JOIN `##user` USING (user_id)"
)->execute();
} else {
// Copied from PhpGedView's db_schema_11_12
if (file_exists($INDEX_DIRECTORY . 'gedcoms.php')) {
require_once $INDEX_DIRECTORY . 'gedcoms.php';
echo '<p>', $INDEX_DIRECTORY . 'gedcoms.php', ' => wt_gedcom…</p>';
if (isset($GEDCOMS) && is_array($GEDCOMS)) {
foreach ($GEDCOMS as $array) {
try {
Database::prepare("INSERT INTO `##gedcom` (gedcom_id, gedcom_name) VALUES (?,?)")
->execute(array($array['id'], $array['gedcom']));
} catch (PDOException $ex) {
// Ignore duplicates
}
// insert gedcom
foreach ($array as $key => $value) {
if ($key != 'id' && $key != 'gedcom' && $key != 'commonsurnames') {
try {
Database::prepare("INSERT INTO `##gedcom_setting` (gedcom_id, setting_name, setting_value) VALUES (?,?, ?)")
->execute(array($array['id'], $key, $value));
} catch (PDOException $ex) {
// Ignore duplicates
}
}
}
}
}
}
// Migrate the data from pgv_users into pgv_user/pgv_user_setting/pgv_user_gedcom_setting
echo '<p>pgv_users => wt_user…</p>';
try {
// "INSERT IGNORE" is needed to allow for PhpGedView users with duplicate emails. Only the first will be imported.
Database::prepare(
"INSERT IGNORE INTO `##user` (user_name, real_name, email, password)" .
" SELECT u_username, CONCAT_WS(' ', u_firstname, u_lastname), u_email, u_password FROM `{$DBNAME}`.`{$TBLPREFIX}users`"
)->execute();
} catch (PDOException $ex) {
// This could only fail if;
// a) we've already done it (upgrade)
// b) it doesn't exist (new install)
}
echo '<p>pgv_users => wt_user_setting…</p>';
try {
Database::prepare(
"INSERT INTO `##user_setting` (user_id, setting_name, setting_value)" .
" SELECT user_id, 'canadmin', " .
" CASE WHEN u_canadmin IN ('Y', 'yes') THEN 1 WHEN u_canadmin IN ('N', 'no') THEN 0 ELSE u_canadmin END" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}users`" .
" JOIN `##user` ON (user_name=CONVERT(u_username USING utf8) COLLATE utf8_unicode_ci)" .
" UNION ALL" .
" SELECT user_id, 'verified', " .
" CASE WHEN u_verified IN ('Y', 'yes') THEN 1 WHEN u_verified IN ('N', 'no') THEN 0 ELSE u_verified END" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}users`" .
" JOIN `##user` ON (user_name=CONVERT(u_username USING utf8) COLLATE utf8_unicode_ci)" .
" UNION ALL" .
" SELECT user_id, 'verified_by_admin', " .
" CASE WHEN u_verified_by_admin IN ('Y', 'yes') THEN 1 WHEN u_verified_by_admin IN ('N', 'no') THEN 0 ELSE u_verified_by_admin END" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}users`" .
" JOIN `##user` ON (user_name=CONVERT(u_username USING utf8) COLLATE utf8_unicode_ci)" .
" UNION ALL" .
" SELECT user_id, 'language', " .
" CASE u_language" .
" WHEN 'catalan' THEN 'ca'" .
" WHEN 'danish' THEN 'da'" .
" WHEN 'dutch' THEN 'nl'" .
" WHEN 'english' THEN 'en_US'" .
" WHEN 'english-uk' THEN 'en_GB'" . // PhpGedView had the config for en_GB, but no language files
" WHEN 'estonian' THEN 'et'" .
" WHEN 'finnish' THEN 'fi'" .
" WHEN 'french' THEN 'fr'" .
" WHEN 'german' THEN 'de'" .
" WHEN 'hebrew' THEN 'he'" .
" WHEN 'hungarian' THEN 'hu'" .
" WHEN 'italian' THEN 'it'" .
" WHEN 'norwegian' THEN 'nn'" .
" WHEN 'polish' THEN 'pl'" .
" WHEN 'portuguese' THEN 'pt'" .
" WHEN 'russian' THEN 'ru'" .
" WHEN 'slovak' THEN 'sk'" .
" WHEN 'slovenian' THEN 'sl'" .
" WHEN 'spanish' THEN 'es'" .
" WHEN 'swedish' THEN 'sv'" .
" WHEN 'turkish' THEN 'tr'" .
" ELSE 'en_US'" . // PhpGedView supports other languages that webtrees does not (yet)
" END" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}users`" .
" JOIN `##user` ON (user_name=CONVERT(u_username USING utf8) COLLATE utf8_unicode_ci)" .
" UNION ALL" .
" SELECT user_id, 'reg_timestamp', u_reg_timestamp" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}users`" .
" JOIN `##user` ON (user_name=CONVERT(u_username USING utf8) COLLATE utf8_unicode_ci)" .
" UNION ALL" .
" SELECT user_id, 'reg_hashcode', u_reg_hashcode" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}users`" .
" JOIN `##user` ON (user_name=CONVERT(u_username USING utf8) COLLATE utf8_unicode_ci)" .
" UNION ALL" .
" SELECT user_id, 'theme', " .
" CASE u_theme" .
" WHEN '' THEN ''" .
" WHEN 'themes/cloudy/' THEN 'clouds'" .
" WHEN 'themes/minimal/' THEN 'minimal'" .
" WHEN 'themes/simplyblue/' THEN 'colors'" .
" WHEN 'themes/simplygreen/' THEN 'colors'" .
" WHEN 'themes/simplyred/' THEN 'colors'" .
" WHEN 'themes/xenea/' THEN 'xenea'" .
" ELSE 'themes/webtrees/'" . // ocean, simplyred/blue/green, standard, wood
" END" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}users`" .
" JOIN `##user` ON (user_name=CONVERT(u_username USING utf8) COLLATE utf8_unicode_ci)" .
" UNION ALL" .
" SELECT user_id, 'sessiontime', u_sessiontime" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}users`" .
" JOIN `##user` ON (user_name=CONVERT(u_username USING utf8) COLLATE utf8_unicode_ci)" .
" UNION ALL" .
" SELECT user_id, 'contactmethod', u_contactmethod" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}users`" .
" JOIN `##user` ON (user_name=CONVERT(u_username USING utf8) COLLATE utf8_unicode_ci)" .
" UNION ALL" .
" SELECT user_id, 'visibleonline', " .
" CASE WHEN u_visibleonline IN ('Y', 'yes') THEN 1 WHEN u_visibleonline IN ('N', 'no') THEN 0 ELSE u_visibleonline END" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}users`" .
" JOIN `##user` ON (user_name=CONVERT(u_username USING utf8) COLLATE utf8_unicode_ci)" .
" UNION ALL" .
" SELECT user_id, 'comment', u_comment" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}users`" .
" JOIN `##user` ON (user_name=CONVERT(u_username USING utf8) COLLATE utf8_unicode_ci)" .
" UNION ALL" .
" SELECT user_id, 'relationship_privacy', " .
" CASE WHEN u_relationship_privacy IN ('Y', 'yes') THEN 1 WHEN u_relationship_privacy IN ('N', 'no') THEN 0 ELSE u_relationship_privacy END" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}users`" .
" JOIN `##user` ON (user_name=CONVERT(u_username USING utf8) COLLATE utf8_unicode_ci)" .
" UNION ALL" .
" SELECT user_id, 'max_relation_path', u_max_relation_path" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}users`" .
" JOIN `##user` ON (user_name=CONVERT(u_username USING utf8) COLLATE utf8_unicode_ci)" .
" UNION ALL" .
" SELECT user_id, 'auto_accept', " .
" CASE WHEN u_auto_accept IN ('Y', 'yes') THEN 1 WHEN u_auto_accept IN ('N', 'no') THEN 0 ELSE u_auto_accept END" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}users`" .
" JOIN `##user` ON (user_name=CONVERT(u_username USING utf8) COLLATE utf8_unicode_ci)"
)->execute();
} catch (PDOException $ex) {
// This could only fail if;
// a) we've already done it (upgrade)
// b) it doesn't exist (new install)
}
// Some PhpGedView installations store the u_reg_timestamp in the format "2010-03-07 21:41:07"
Database::prepare(
"UPDATE `##user_setting` SET setting_value=UNIX_TIMESTAMP(setting_value) WHERE setting_name='reg_timestamp' AND setting_value LIKE '____-__-__ __:__:__'"
)->execute();
// Some PhpGedView installations have empty/invalid values for reg_timestamp
Database::prepare(
"UPDATE `##user_setting` SET setting_value=CAST(setting_value AS UNSIGNED) WHERE setting_name='reg_timestamp'"
)->execute();
echo '<p>pgv_users => wt_user_gedcom_setting…</p>';
$user_gedcom_settings =
Database::prepare(
"SELECT user_id, u_gedcomid, u_rootid, u_canedit" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}users`" .
" JOIN `##user` ON (user_name=CONVERT(u_username USING utf8) COLLATE utf8_unicode_ci)"
)->fetchAll();
foreach ($user_gedcom_settings as $setting) {
try {
$array = unserialize($setting->u_gedcomid);
foreach ($array as $gedcom => $value) {
$tree = Tree::findByName($gedcom);
if ($tree !== null) {
Database::prepare(
"INSERT IGNORE INTO `##user_gedcom_setting` (user_id, gedcom_id, setting_name, setting_value) VALUES (?, ?, ?, ?)"
)->execute(array($setting->user_id, $tree->getTreeId(), 'gedcomid', $value));
}
}
} catch (\ErrorException $ex) {
// Invalid serialized data?
}
try {
$array = unserialize($setting->u_rootid);
foreach ($array as $gedcom => $value) {
$tree = Tree::findByName($gedcom);
if ($tree !== null) {
Database::prepare(
"INSERT IGNORE INTO `##user_gedcom_setting` (user_id, gedcom_id, setting_name, setting_value) VALUES (?, ?, ?, ?)"
)->execute(array($setting->user_id, $tree->getTreeId(), 'rootid', $value));
}
}
} catch (\ErrorException $ex) {
// Invalid serialized data?
}
try {
$array = unserialize($setting->u_canedit);
foreach ($array as $gedcom => $value) {
$tree = Tree::findByName($gedcom);
if ($tree !== null) {
Database::prepare(
"INSERT IGNORE INTO `##user_gedcom_setting` (user_id, gedcom_id, setting_name, setting_value) VALUES (?, ?, ?, ?)"
)->execute(array($setting->user_id, $tree->getTreeId(), 'canedit', $value));
}
}
} catch (\ErrorException $ex) {
// Invalid serialized data?
}
}
}
define('PGV_PHPGEDVIEW', true);
define('PGV_PRIV_PUBLIC', Auth::PRIV_PRIVATE);
define('PGV_PRIV_USER', Auth::PRIV_USER);
define('PGV_PRIV_NONE', Auth::PRIV_NONE);
define('PGV_PRIV_HIDE', Auth::PRIV_HIDE);
$PRIV_PUBLIC = Auth::PRIV_PRIVATE;
$PRIV_USER = Auth::PRIV_USER;
$PRIV_NONE = Auth::PRIV_NONE;
$PRIV_HIDE = Auth::PRIV_HIDE;
// Old versions of PhpGedView used a $GEDCOMS[] array.
// New versions used a database.
$GEDCOMS = Database::prepare(
"SELECT" .
" gedcom_id AS id," .
" gedcom_name AS gedcom," .
" gs1.setting_value AS config," .
" gs2.setting_value AS privacy" .
" FROM `##gedcom`" .
" JOIN `##gedcom_setting` AS gs1 USING (gedcom_id)" .
" JOIN `##gedcom_setting` AS gs2 USING (gedcom_id)" .
" WHERE gedcom_id>0" .
" AND gs1.setting_name='config'" .
" AND gs2.setting_name='privacy'"
)->fetchAll(PDO::FETCH_ASSOC);
foreach ($GEDCOMS as $GEDCOM => $GED_DATA) {
// We read these variables from PhpGedView's index/*_conf.php, and set them here in case any are missing.
$ADVANCED_NAME_FACTS = '';
$ADVANCED_PLAC_FACTS = '';
$ALLOW_THEME_DROPDOWN = '';
$CALENDAR_FORMAT = '';
$CHART_BOX_TAGS = '';
$CONTACT_EMAIL = '';
$DEFAULT_PEDIGREE_GENERATIONS = '';
$EXPAND_NOTES = '';
$EXPAND_RELATIVES_EVENTS = '';
$EXPAND_SOURCES = '';
$FAM_FACTS_ADD = '';
$FAM_FACTS_QUICK = '';
$FAM_FACTS_UNIQUE = '';
$FAM_ID_PREFIX = '';
$FULL_SOURCES = '';
$GEDCOM_ID_PREFIX = '';
$GENERATE_UIDS = '';
$HIDE_GEDCOM_ERRORS = '';
$HIDE_LIVE_PEOPLE = '';
$INDI_FACTS_ADD = '';
$INDI_FACTS_QUICK = '';
$INDI_FACTS_UNIQUE = '';
$LANGUAGE = '';
$MAX_ALIVE_AGE = '';
$MAX_DESCENDANCY_GENERATIONS = '';
$MAX_PEDIGREE_GENERATIONS = '';
$MAX_RELATION_PATH_LENGTH = '';
$MEDIA_ID_PREFIX = '';
$META_DESCRIPTION = '';
$META_TITLE = '';
$MULTI_MEDIA = '';
$NOTE_FACTS_ADD = '';
$NOTE_FACTS_QUICK = '';
$NOTE_FACTS_UNIQUE = '';
$NO_UPDATE_CHAN = '';
$PEDIGREE_FULL_DETAILS = '';
$PEDIGREE_LAYOUT = '';
$PEDIGREE_ROOT_ID = '';
$PEDIGREE_SHOW_GENDER = '';
$PREFER_LEVEL2_SOURCES = '';
$QUICK_REQUIRED_FACTS = '';
$QUICK_REQUIRED_FAMFACTS = '';
$REPO_FACTS_ADD = '';
$REPO_FACTS_QUICK = '';
$REPO_FACTS_UNIQUE = '';
$REPO_ID_PREFIX = '';
$REQUIRE_AUTHENTICATION = '';
$SAVE_WATERMARK_IMAGE = '';
$SAVE_WATERMARK_THUMB = '';
$SHOW_AGE_DIFF = '';
$SHOW_COUNTER = '';
$SHOW_DEAD_PEOPLE = '';
$SHOW_EST_LIST_DATES = '';
$SHOW_FACT_ICONS = '';
$SHOW_GEDCOM_RECORD = '';
$SHOW_HIGHLIGHT_IMAGES = '';
$SHOW_LDS_AT_GLANCE = '';
$SHOW_LEVEL2_NOTES = '';
$SHOW_LIST_PLACES = '';
$SHOW_LIVING_NAMES = '';
$SHOW_MEDIA_DOWNLOAD = '';
$SHOW_PARENTS_AGE = '';
$SHOW_PEDIGREE_PLACES = '';
$SHOW_PRIVATE_RELATIONSHIPS = '';
$SHOW_RELATIVES_EVENTS = '';
$SOURCE_ID_PREFIX = '';
$SOUR_FACTS_ADD = '';
$SOUR_FACTS_QUICK = '';
$SOUR_FACTS_UNIQUE = '';
$SUBLIST_TRIGGER_I = '';
$SURNAME_LIST_STYLE = '';
$SURNAME_TRADITION = '';
$THEME_DIR = '';
$THUMBNAIL_WIDTH = '';
$USE_RELATIONSHIP_PRIVACY = '';
$USE_RIN = '';
$WATERMARK_THUMB = '';
$WEBMASTER_EMAIL = '';
$WORD_WRAPPED_NOTES = '';
$config = str_replace(array('$INDEX_DIRECTORY', '${INDEX_DIRECTORY}'), $INDEX_DIRECTORY, $GED_DATA['config']);
if (substr($config, 0, 1) === '.') {
$config = $PGV_PATH . '/' . $config;
}
if (is_readable($config)) {
echo '<p>Reading configuration file ', $config, '</p>';
require $config;
} else {
echo '<p>Error - could not read configuration file ', $config, '</p>';
}
$stmt_default_resn = Database::prepare("INSERT INTO `##default_resn` (gedcom_id, xref, tag_type, resn) VALUES (?, ?, ?, CASE ? WHEN -1 THEN 'hidden' WHEN 0 THEN 'confidential' WHEN 1 THEN 'privacy' ELSE 'none' END)");
$stmt_gedcom_setting = Database::prepare("INSERT INTO `##gedcom_setting` (gedcom_id, setting_name, setting_value) VALUES (?,?,?)");
$privacy = str_replace(array('$INDEX_DIRECTORY', '${INDEX_DIRECTORY}'), $INDEX_DIRECTORY, $GED_DATA['privacy']);
if (substr($config, 0, 1) == '.') {
$privacy = $PGV_PATH . '/' . $privacy;
}
if (is_readable($privacy)) {
// initialise this, in case it is missing from the file
$person_privacy = array();
$person_facts = array();
$global_facts = array();
echo '<p>Reading privacy file ', $privacy, '</p>';
require $privacy;
foreach ($global_facts as $key => $value) {
if (isset($value['details'])) {
$stmt_default_resn->execute(array($GED_DATA['id'], null, $key, $value['details']));
}
}
foreach ($person_privacy as $key => $value) {
if (isset($value['details'])) {
$stmt_default_resn->execute(array($GED_DATA['id'], $key, null, $value['details']));
}
}
foreach ($person_facts as $key1 => $array) {
foreach ($array as $key2 => $value) {
if (isset($value['details'])) {
$stmt_default_resn->execute(array($GED_DATA['id'], $key1, $key2, $value['details']));
}
}
}
} else {
echo '<p>Could not read privacy file ', $privacy, '</p>';
}
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'ADVANCED_NAME_FACTS', $ADVANCED_NAME_FACTS));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'ADVANCED_PLAC_FACTS', $ADVANCED_PLAC_FACTS));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'ALLOW_THEME_DROPDOWN', $ALLOW_THEME_DROPDOWN));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'CALENDAR_FORMAT', $CALENDAR_FORMAT));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'CHART_BOX_TAGS', $CHART_BOX_TAGS));
$user = User::findByIdentifier($CONTACT_EMAIL);
if ($user) {
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'CONTACT_USER_ID', $user->getUserId()));
}
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'DEFAULT_PEDIGREE_GENERATIONS', $DEFAULT_PEDIGREE_GENERATIONS));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'EXPAND_NOTES', $EXPAND_NOTES));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'EXPAND_SOURCES', $EXPAND_SOURCES));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'FAM_FACTS_ADD', $FAM_FACTS_ADD));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'FAM_FACTS_QUICK', $FAM_FACTS_QUICK));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'FAM_FACTS_UNIQUE', $FAM_FACTS_UNIQUE));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'FAM_ID_PREFIX', $FAM_ID_PREFIX));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'FULL_SOURCES', $FULL_SOURCES));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'GEDCOM_ID_PREFIX', $GEDCOM_ID_PREFIX));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'GENERATE_UIDS', $GENERATE_UIDS));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'HIDE_GEDCOM_ERRORS', $HIDE_GEDCOM_ERRORS));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'HIDE_LIVE_PEOPLE', $HIDE_LIVE_PEOPLE));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'INDI_FACTS_ADD', $INDI_FACTS_ADD));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'INDI_FACTS_QUICK', $INDI_FACTS_QUICK));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'INDI_FACTS_UNIQUE', $INDI_FACTS_UNIQUE));
switch ($LANGUAGE) {
case 'catalan':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'ca'));
break;
case 'english-uk':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'en-GB'));
break;
case 'polish':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'pl'));
break;
case 'italian':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'it'));
break;
case 'spanish':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'es'));
break;
case 'finnish':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'fi'));
break;
case 'french':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'fr'));
break;
case 'german':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'de'));
break;
case 'danish':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'da'));
break;
case 'portuguese':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'pt'));
break;
case 'hebrew':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'he'));
break;
case 'estonian':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'et'));
break;
case 'turkish':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'tr'));
break;
case 'dutch':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'nl'));
break;
case 'slovak':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'sk'));
break;
case 'norwegian':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'nn'));
break;
case 'slovenian':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'sl'));
break;
case 'hungarian':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'hu'));
break;
case 'swedish':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'sv'));
break;
case 'russian':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'ru'));
break;
default:
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'LANGUAGE', 'en-US'));
break;
}
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'MAX_ALIVE_AGE', $MAX_ALIVE_AGE));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'MAX_DESCENDANCY_GENERATIONS', $MAX_DESCENDANCY_GENERATIONS));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'MAX_PEDIGREE_GENERATIONS', $MAX_PEDIGREE_GENERATIONS));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'MAX_RELATION_PATH_LENGTH', $MAX_RELATION_PATH_LENGTH));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'MEDIA_DIRECTORY', 'media/'));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'MEDIA_ID_PREFIX', $MEDIA_ID_PREFIX));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'META_DESCRIPTION', $META_DESCRIPTION));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'META_TITLE', $META_TITLE));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'MEDIA_UPLOAD', $MULTI_MEDIA)); // see schema v12-13
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'NOTE_FACTS_ADD', $NOTE_FACTS_ADD));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'NOTE_FACTS_QUICK', $NOTE_FACTS_QUICK));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'NOTE_FACTS_UNIQUE', $NOTE_FACTS_UNIQUE));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'NOTE_ID_PREFIX', 'N'));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'NO_UPDATE_CHAN', $NO_UPDATE_CHAN));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'PEDIGREE_FULL_DETAILS', $PEDIGREE_FULL_DETAILS));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'PEDIGREE_LAYOUT', $PEDIGREE_LAYOUT));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'PEDIGREE_ROOT_ID', $PEDIGREE_ROOT_ID));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'PEDIGREE_SHOW_GENDER', $PEDIGREE_SHOW_GENDER));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'PREFER_LEVEL2_SOURCES', $PREFER_LEVEL2_SOURCES));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'QUICK_REQUIRED_FACTS', $QUICK_REQUIRED_FACTS));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'QUICK_REQUIRED_FAMFACTS', $QUICK_REQUIRED_FAMFACTS));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'REPO_FACTS_ADD', $REPO_FACTS_ADD));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'REPO_FACTS_QUICK', $REPO_FACTS_QUICK));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'REPO_FACTS_UNIQUE', $REPO_FACTS_UNIQUE));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'REPO_ID_PREFIX', $REPO_ID_PREFIX));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'REQUIRE_AUTHENTICATION', $REQUIRE_AUTHENTICATION));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SAVE_WATERMARK_IMAGE', $SAVE_WATERMARK_IMAGE));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SAVE_WATERMARK_THUMB', $SAVE_WATERMARK_THUMB));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SHOW_COUNTER', $SHOW_COUNTER));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SHOW_DEAD_PEOPLE', $SHOW_DEAD_PEOPLE));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SHOW_EST_LIST_DATES', $SHOW_EST_LIST_DATES));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SHOW_FACT_ICONS', $SHOW_FACT_ICONS));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SHOW_GEDCOM_RECORD', $SHOW_GEDCOM_RECORD));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SHOW_HIGHLIGHT_IMAGES', $SHOW_HIGHLIGHT_IMAGES));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SHOW_LDS_AT_GLANCE', $SHOW_LDS_AT_GLANCE));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SHOW_LIST_PLACES', $SHOW_LIST_PLACES));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SHOW_LIVING_NAMES', $SHOW_LIVING_NAMES));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SHOW_MEDIA_DOWNLOAD', $SHOW_MEDIA_DOWNLOAD));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SHOW_PARENTS_AGE', $SHOW_PARENTS_AGE));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SHOW_PEDIGREE_PLACES', $SHOW_PEDIGREE_PLACES));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SHOW_PRIVATE_RELATIONSHIPS', $SHOW_PRIVATE_RELATIONSHIPS));
// Update these - see db_schema_5_6.php
$SHOW_RELATIVES_EVENTS = preg_replace('/_(BIRT|MARR|DEAT)_(COUS|MSIB|FSIB|GGCH|NEPH|GGPA)/', '', $SHOW_RELATIVES_EVENTS);
$SHOW_RELATIVES_EVENTS = preg_replace('/_FAMC_(RESI_EMIG)/', '', $SHOW_RELATIVES_EVENTS);
$SHOW_RELATIVES_EVENTS = preg_replace('/_MARR_(MOTH|FATH|FAMC)/', '_MARR_PARE', $SHOW_RELATIVES_EVENTS);
$SHOW_RELATIVES_EVENTS = preg_replace('/_DEAT_(MOTH|FATH)/', '_DEAT_PARE', $SHOW_RELATIVES_EVENTS);
preg_match_all('/[_A-Z]+/', $SHOW_RELATIVES_EVENTS, $match);
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SHOW_RELATIVES_EVENTS', implode(',', array_unique($match[0]))));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SOURCE_ID_PREFIX', $SOURCE_ID_PREFIX));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SOUR_FACTS_ADD', $SOUR_FACTS_ADD));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SOUR_FACTS_QUICK', $SOUR_FACTS_QUICK));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SOUR_FACTS_UNIQUE', $SOUR_FACTS_UNIQUE));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SUBLIST_TRIGGER_I', $SUBLIST_TRIGGER_I));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SURNAME_LIST_STYLE', $SURNAME_LIST_STYLE));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'SURNAME_TRADITION', $SURNAME_TRADITION));
switch ($THEME_DIR) {
case '':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'THEME_DIR', ''));
break;
case 'themes/cloudy/':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'THEME_DIR', 'clouds'));
break;
case 'themes/minimal/':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'THEME_DIR', 'minimal'));
break;
case 'themes/simplyblue/':
case 'themes/simplygreen/':
case 'themes/simplyred/':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'THEME_DIR', 'colors'));
break;
case 'themes/xenea/':
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'THEME_DIR', 'xenea'));
break;
default:
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'THEME_DIR', 'webtrees'));
break;
}
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'THUMBNAIL_WIDTH', $THUMBNAIL_WIDTH));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'USE_RELATIONSHIP_PRIVACY', $USE_RELATIONSHIP_PRIVACY));
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'WATERMARK_THUMB', $WATERMARK_THUMB));
$user = User::findByIdentifier($WEBMASTER_EMAIL);
if ($user) {
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'WEBMASTER_USER_ID', $user->getUserId()));
}
$stmt_gedcom_setting->execute(array($GED_DATA['id'], 'WORD_WRAPPED_NOTES', $WORD_WRAPPED_NOTES));
}
Database::prepare("DELETE FROM `##gedcom_setting` WHERE setting_name IN ('config', 'privacy', 'path', 'pgv_ver', 'imported')")->execute();
// webtrees 1.0.5 combines user and gedcom settings for relationship privacy
// into a combined user-gedcom setting, for more granular control
Database::exec(
"INSERT IGNORE INTO `##user_gedcom_setting` (user_id, gedcom_id, setting_name, setting_value)" .
" SELECT u.user_id, g.gedcom_id, 'RELATIONSHIP_PATH_LENGTH', LEAST(us1.setting_value, gs1.setting_value)" .
" FROM `##user` u" .
" CROSS JOIN `##gedcom` g" .
" LEFT JOIN `##user_setting` us1 ON (u.user_id =us1.user_id AND us1.setting_name='max_relation_path')" .
" LEFT JOIN `##user_setting` us2 ON (u.user_id =us2.user_id AND us2.setting_name='relationship_privacy')" .
" LEFT JOIN `##gedcom_setting` gs1 ON (g.gedcom_id=gs1.gedcom_id AND gs1.setting_name='MAX_RELATION_PATH_LENGTH')" .
" LEFT JOIN `##gedcom_setting` gs2 ON (g.gedcom_id=gs2.gedcom_id AND gs2.setting_name='USE_RELATIONSHIP_PRIVACY')" .
" WHERE us2.setting_value AND gs2.setting_value"
);
Database::exec(
"DELETE FROM `##gedcom_setting` WHERE setting_name IN ('MAX_RELATION_PATH_LENGTH', 'USE_RELATIONSHIP_PRIVACY')"
);
Database::exec(
"DELETE FROM `##user_setting` WHERE setting_name IN ('relationship_privacy', 'max_relation_path_length')"
);
////////////////////////////////////////////////////////////////////////////////
// The PhpGedView blocks don't migrate easily.
// Just give everybody and every tree default blocks
////////////////////////////////////////////////////////////////////////////////
Database::prepare(
"INSERT INTO `##block` (user_id, location, block_order, module_name)" .
" SELECT `##user`.user_id, location, block_order, module_name" .
" FROM `##block`" .
" JOIN `##user`" .
" WHERE `##block`.user_id = -1" .
" AND `##user`.user_id > 0"
)->execute();
Database::prepare(
"INSERT INTO `##block` (gedcom_id, location, block_order, module_name)" .
" SELECT `##gedcom`.gedcom_id, location, block_order, module_name" .
" FROM `##block`" .
" JOIN `##gedcom`" .
" WHERE `##block`.gedcom_id = -1" .
" AND `##gedcom`.gedcom_id > 0"
)->execute();
////////////////////////////////////////////////////////////////////////////////
// Hit counter
////////////////////////////////////////////////////////////////////////////////
//
if ($PGV_SCHEMA_VERSION >= 13) {
echo '<p>pgv_hit_counter => wt_hit_counter…</p>';
Database::prepare(
"REPLACE INTO `##hit_counter` (gedcom_id, page_name, page_parameter, page_count)" .
" SELECT gedcom_id, page_name, page_parameter, page_count FROM `{$DBNAME}`.`{$TBLPREFIX}hit_counter`"
)->execute();
} else {
// Copied from PhpGedView's db_schema_12_13
$statement = Database::prepare("INSERT IGNORE INTO `##hit_counter` (gedcom_id, page_name, page_parameter, page_count) VALUES (?, ?, ?, ?)");
foreach ($GEDCOMS as $GEDCOM => $GED_DATA) {
$file = $INDEX_DIRECTORY . '/' . $GED_DATA['gedcom'] . 'pgv_counters.txt';
echo '<p>', $file, ' => wt_hit_counter…</p>';
if (file_exists($file)) {
foreach (file($file) as $line) {
if (preg_match('/(@([A-Za-z0-9:_-]+)@ )?(\d+)/', $line, $match)) {
if ($match[2]) {
$page_name = 'individual.php';
$page_parameter = $match[2];
} else {
$page_name = 'index.php';
$page_parameter = 'gedcom:' . $GED_DATA['id'];
}
try {
$statement->execute(array($GED_DATA['id'], $page_name, $page_parameter, $match[3]));
} catch (PDOException $ex) {
// Primary key violation? Ignore?
}
}
}
}
}
}
////////////////////////////////////////////////////////////////////////////////
foreach ($GEDCOMS as $GED_DATA) {
Module::setDefaultAccess($GED_DATA['id']);
}
echo '<p>pgv_site_setting => wt_module_setting…</p>';
Database::prepare(
"REPLACE INTO `##module_setting` (module_name, setting_name, setting_value)" .
" SELECT 'googlemap', site_setting_name, site_setting_value FROM `{$DBNAME}`.`{$TBLPREFIX}site_setting`" .
" WHERE site_setting_name LIKE 'GM_%'"
)->execute();
Database::prepare(
"REPLACE INTO `##module_setting` (module_name, setting_name, setting_value)" .
" SELECT 'lightbox', site_setting_name, site_setting_value FROM `{$DBNAME}`.`{$TBLPREFIX}site_setting`" .
" WHERE site_setting_name LIKE 'LB_%'"
)->execute();
////////////////////////////////////////////////////////////////////////////////
echo '<p>pgv_favorites => wt_favorite…</p>';
try {
Database::prepare(
"REPLACE INTO `##favorite` (favorite_id, user_id, gedcom_id, xref, favorite_type, url, title, note)" .
" SELECT fv_id, u.user_id, g.gedcom_id, fv_gid, fv_type, fv_url, fv_title, fv_note" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}favorites` f" .
" LEFT JOIN `##gedcom` g ON (f.fv_username=g.gedcom_name)" .
" LEFT JOIN `##user` u ON (f.fv_username=u.user_name)"
)->execute();
} catch (PDOException $ex) {
// This table will only exist if the favorites module is installed in WT
}
////////////////////////////////////////////////////////////////////////////////
echo '<p>pgv_news => wt_news…</p>';
try {
Database::prepare(
"REPLACE INTO `##news` (news_id, user_id, gedcom_id, subject, body, updated)" .
" SELECT n_id, u.user_id, g.gedcom_id, n_title, n_text, FROM_UNIXTIME(n_date)" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}news` n" .
" LEFT JOIN `##gedcom` g ON (n.n_username=g.gedcom_name)" .
" LEFT JOIN `##user` u ON (n.n_username=u.user_name)"
)->execute();
} catch (PDOException $ex) {
// This table will only exist if the news/blog module is installed in WT
}
////////////////////////////////////////////////////////////////////////////////
echo '<p>pgv_nextid => wt_next_id…</p>';
Database::prepare(
"REPLACE INTO `##next_id` (gedcom_id, record_type, next_id)" .
" SELECT ni_gedfile, ni_type, ni_id" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}nextid`" .
" JOIN `##gedcom` ON (ni_gedfile = gedcom_id)" .
" WHERE ni_type IN ('INDI', 'FAM', 'SOUR', 'REPO', 'OBJE', 'NOTE')"
)->execute();
////////////////////////////////////////////////////////////////////////////////
echo '<p>pgv_messages => wt_message…</p>';
Database::prepare(
"REPLACE INTO `##message` (message_id, sender, ip_address, user_id, subject, body, created)" .
" SELECT m_id, m_from, '127.0.0.1', user_id, m_subject, m_body, STR_TO_DATE(LEFT(m_created,25),'%a, %d %M %Y %H:%i:%s')" .
" FROM `{$DBNAME}`.`{$TBLPREFIX}messages`" .
" JOIN `##user` ON (CONVERT(m_to USING utf8) COLLATE utf8_unicode_ci=user_name)"
)->execute();
////////////////////////////////////////////////////////////////////////////////
try {
echo '<p>pgv_placelocation => wt_placelocation…</p>';
Database::prepare(
"REPLACE INTO `##placelocation` (pl_id, pl_parent_id, pl_level, pl_place, pl_long, pl_lati, pl_zoom, pl_icon)" .
" SELECT pl_id, pl_parent_id, pl_level, pl_place, pl_long, pl_lati, pl_zoom, pl_icon FROM `{$DBNAME}`.`{$TBLPREFIX}placelocation`"
)->execute();
} catch (PDOException $ex) {
// This table will only exist if the gm module is installed in PhpGedView/WT
}
////////////////////////////////////////////////////////////////////////////////
echo '<p>Genealogy records…</p>';
Database::prepare(
"INSERT INTO `##gedcom_chunk` (gedcom_id, chunk_data, imported)" .
" SELECT o_file, o_gedcom, 0 FROM `{$DBNAME}`.`{$TBLPREFIX}other`" .
" JOIN `##gedcom` ON (o_file = gedcom_id)" .
" ORDER BY o_type!='HEAD'" // Must load HEAD record first
)->execute();
Database::prepare(
"INSERT INTO `##gedcom_chunk` (gedcom_id, chunk_data, imported)" .
" SELECT i_file, i_gedcom, 0 FROM `{$DBNAME}`.`{$TBLPREFIX}individuals`" .
" JOIN `##gedcom` ON (i_file = gedcom_id)"
)->execute();
Database::prepare(
"INSERT INTO `##gedcom_chunk` (gedcom_id, chunk_data, imported)" .
" SELECT f_file, f_gedcom, 0 FROM `{$DBNAME}`.`{$TBLPREFIX}families`" .
" JOIN `##gedcom` ON (f_file = gedcom_id)"
)->execute();
Database::prepare(
"INSERT INTO `##gedcom_chunk` (gedcom_id, chunk_data, imported)" .
" SELECT s_file, s_gedcom, 0 FROM `{$DBNAME}`.`{$TBLPREFIX}sources`" .
" JOIN `##gedcom` ON (s_file = gedcom_id)"
)->execute();
Database::prepare(
"INSERT INTO `##gedcom_chunk` (gedcom_id, chunk_data, imported)" .
" SELECT m_gedfile, m_gedrec, 0 FROM `{$DBNAME}`.`{$TBLPREFIX}media`" .
" JOIN `##gedcom` ON (m_gedfile = gedcom_id)"
)->execute();
Database::prepare(
"UPDATE `##gedcom_setting` SET setting_value='0' WHERE setting_name='imported'"
)->execute();
////////////////////////////////////////////////////////////////////////////////
Database::commit();
echo '<hr>';
echo '<p>', I18N::translate('You need to sign in again, using your PhpGedView username and password.'), '</p>';
echo '<a href="index.php"><button class="btn btn-primary">', I18N::translate('continue'), '</button></a>';