summaryrefslogtreecommitdiff
path: root/includes/db_schema
diff options
context:
space:
mode:
authorfisharebest <fisharebest@gmail.com>2010-10-03 17:56:42 +0000
committerfisharebest <fisharebest@gmail.com>2010-10-03 17:56:42 +0000
commitf5dcaae55019ffff9ef2aa7ae9d2ee4f825e5f96 (patch)
tree6b28b9e822cce4843386fe2cac61fa609fe20c50 /includes/db_schema
parente5fe0eb347b464da439527bdb5b59944603d9b1a (diff)
downloadwebtrees-f5dcaae55019ffff9ef2aa7ae9d2ee4f825e5f96.tar.gz
webtrees-f5dcaae55019ffff9ef2aa7ae9d2ee4f825e5f96.tar.bz2
webtrees-f5dcaae55019ffff9ef2aa7ae9d2ee4f825e5f96.zip
Session storage - move from filesystem to database
Diffstat (limited to 'includes/db_schema')
-rw-r--r--includes/db_schema/db_schema_1_2.php55
1 files changed, 55 insertions, 0 deletions
diff --git a/includes/db_schema/db_schema_1_2.php b/includes/db_schema/db_schema_1_2.php
new file mode 100644
index 0000000000..6dc301d761
--- /dev/null
+++ b/includes/db_schema/db_schema_1_2.php
@@ -0,0 +1,55 @@
+<?php
+/**
+ * Update the database schema from version 1 to version 2
+ * - create the wt_session table to store session data in the database,
+ * rather than in the filesystem.
+ *
+ * The script should assume that it can be interrupted at
+ * any point, and be able to continue by re-running the script.
+ * Fatal errors, however, should be allowed to throw exceptions,
+ * which will be caught by the framework.
+ * It shouldn't do anything that might take more than a few
+ * seconds, for systems with low timeout values.
+ *
+ * phpGedView: Genealogy Viewer
+ * Copyright (C) 20010 Greg Roach
+ *
+ * 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 2 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, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ *
+ * @version $Id$
+ */
+
+if (!defined('WT_WEBTREES')) {
+ header('HTTP/1.0 403 Forbidden');
+ exit;
+}
+
+define('WT_DB_SCHEMA_1_2', '');
+
+self::exec(
+ "CREATE TABLE IF NOT EXISTS `##session` (".
+ " session_id CHAR(32) NOT NULL,".
+ " session_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,".
+ " user_id INTEGER NOT NULL,".
+ " ip_address VARCHAR(32) NOT NULL,".
+ " session_data MEDIUMBLOB NOT NULL,".
+ " PRIMARY KEY (session_id),".
+ " KEY ix1 (session_time),".
+ " KEY ix2 (user_id, ip_address)".
+ ") COLLATE utf8_unicode_ci ENGINE=InnoDB"
+);
+
+// Update the version to indicate sucess
+set_site_setting($schema_name, $next_version);