d664cb800c
- WARNING to operators: You MUST run fixup_2.sql in order to use this and newer versions of the bridge. - Archiving and full chat history fetches are now a configuration setting (and default to off). - Users now have to enable archiving manually by talking to the admin user, and are warned about the potential privacy implications. - Users can now completely remove themselves from the bridge, deleting all data. - Bridge administrators can now be specified by adding an entry to the 'administrators' SQL table with your JID. These can force-unregister specific users.
86 lines
2.3 KiB
SQL
86 lines
2.3 KiB
SQL
CREATE TABLE configuration (
|
|
rev INT PRIMARY KEY,
|
|
server VARCHAR NOT NULL,
|
|
port INT NOT NULL,
|
|
component_name VARCHAR NOT NULL,
|
|
shared_secret VARCHAR NOT NULL,
|
|
upload_component_name VARCHAR NOT NULL,
|
|
allow_archiving BOOL NOT NULL DEFAULT false,
|
|
allow_history_fetches BOOL NOT NULL DEFAULT false
|
|
);
|
|
|
|
CREATE TABLE users (
|
|
id INTEGER PRIMARY KEY,
|
|
jid VARCHAR UNIQUE NOT NULL,
|
|
session_data VARCHAR,
|
|
enable_archiving BOOL NOT NULL DEFAULT false
|
|
);
|
|
|
|
CREATE TABLE user_contacts (
|
|
id INTEGER PRIMARY KEY,
|
|
user_id INT NOT NULL REFERENCES users,
|
|
wa_jid VARCHAR NOT NULL,
|
|
subscription_state VARCHAR NOT NULL DEFAULT 'none',
|
|
avatar_url VARCHAR,
|
|
name VARCHAR,
|
|
notify VARCHAR,
|
|
status VARCHAR,
|
|
UNIQUE(user_id, wa_jid)
|
|
);
|
|
|
|
CREATE TABLE user_messages (
|
|
id INTEGER PRIMARY KEY,
|
|
user_id INT NOT NULL REFERENCES users,
|
|
xmpp_id VARCHAR NOT NULL,
|
|
wa_id VARCHAR NOT NULL,
|
|
UNIQUE(user_id, wa_id)
|
|
);
|
|
|
|
CREATE TABLE avatar_data (
|
|
avatar_url VARCHAR NOT NULL PRIMARY KEY,
|
|
sha1 VARCHAR NOT NULL,
|
|
image BLOB NOT NULL
|
|
);
|
|
|
|
CREATE TABLE user_chats (
|
|
id INTEGER PRIMARY KEY,
|
|
user_id INT NOT NULL REFERENCES users,
|
|
wa_jid VARCHAR NOT NULL,
|
|
user_resource VARCHAR,
|
|
invitation_state VARCHAR NOT NULL DEFAULT 'none',
|
|
subject VARCHAR
|
|
);
|
|
|
|
CREATE TABLE user_chat_members (
|
|
id INTEGER PRIMARY KEY,
|
|
chat_id INT NOT NULL REFERENCES user_chats,
|
|
wa_jid VARCHAR NOT NULL,
|
|
resource VARCHAR NOT NULL,
|
|
affiliation VARCHAR NOT NULL DEFAULT 'member'
|
|
);
|
|
|
|
CREATE TABLE user_chat_joined (
|
|
id INTEGER PRIMARY KEY,
|
|
chat_id INT NOT NULL REFERENCES user_chats,
|
|
jid VARCHAR NOT NULL
|
|
);
|
|
|
|
CREATE TABLE user_chat_history (
|
|
id INTEGER PRIMARY KEY,
|
|
user_id INT NOT NULL REFERENCES users,
|
|
chat_id INT NOT NULL REFERENCES user_chats,
|
|
user_from VARCHAR NOT NULL,
|
|
ts_unix INT NOT NULL,
|
|
xmpp_id VARCHAR NOT NULL,
|
|
orig_id VARCHAR,
|
|
body VARCHAR NOT NULL,
|
|
oob_url VARCHAR
|
|
);
|
|
|
|
CREATE UNIQUE INDEX user_chat_history_unique ON user_chat_history (user_id, chat_id, xmpp_id);
|
|
|
|
CREATE TABLE administrators (
|
|
id INTEGER PRIMARY KEY,
|
|
jid VARCHAR UNIQUE NOT NULL
|
|
);
|