Diff

plugins/mod_storage_sql2.lua @ 5740:6fce00f61acf

mod_storage_sql2: Create an additional table `prosodyarchive` for chronological collections
author Kim Alvefur <zash@zash.se>
date Fri, 12 Jul 2013 01:34:38 +0200
parent 5735:24f4e73645fe
child 5741:c7a664e496b3
line wrap: on
line diff
--- a/plugins/mod_storage_sql2.lua	Thu Jul 11 22:07:55 2013 +0200
+++ b/plugins/mod_storage_sql2.lua	Fri Jul 12 01:34:38 2013 +0200
@@ -23,7 +23,8 @@
 local engine; -- TODO create engine
 
 local function create_table()
-	--[[local Table,Column,Index = mod_sql.Table,mod_sql.Column,mod_sql.Index;
+	local Table,Column,Index = mod_sql.Table,mod_sql.Column,mod_sql.Index;
+	--[[
 	local ProsodyTable = Table {
 		name="prosody";
 		Column { name="host", type="TEXT", nullable=false };
@@ -78,6 +79,22 @@
 			end
 		end
 	end
+	local ProsodyArchiveTable = Table {
+		name="prosodyarchive";
+		Column { name="sort_id", type="INTEGER PRIMARY KEY AUTOINCREMENT", nullable=false };
+		Column { name="host", type="TEXT", nullable=false };
+		Column { name="user", type="TEXT", nullable=false };
+		Column { name="store", type="TEXT", nullable=false };
+		Column { name="key", type="TEXT", nullable=false }; -- item id
+		Column { name="when", type="INTEGER", nullable=false }; -- timestamp
+		Column { name="with", type="TEXT", nullable=false }; -- related id
+		Column { name="type", type="TEXT", nullable=false };
+		Column { name="value", type=params.driver == "MySQL" and "MEDIUMTEXT" or "TEXT", nullable=false };
+		Index { name="prosodyarchive_index", "host", "user", "store", "key" };
+	};
+	engine:transaction(function()
+		ProsodyArchiveTable:create(engine);
+	end);
 end
 local function set_encoding()
 	if params.driver ~= "SQLite3" then