Software /
code /
prosody
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