mirror of
https://git.anonymousland.org/anonymousland/synapse.git
synced 2025-01-04 08:30:50 -05:00
25f43faa70
The hope here is that by moving all the schema files into synapse/storage/schema, it gets a bit easier for newcomers to navigate. It certainly got easier for me to write a helpful README. There's more to do on that front, but I'll follow up with other PRs for that.
57 lines
1.5 KiB
SQL
57 lines
1.5 KiB
SQL
-- Convert `access_tokens`.user from rowids to user strings.
|
|
-- MUST BE DONE BEFORE REMOVING ID COLUMN FROM USERS TABLE BELOW
|
|
CREATE TABLE IF NOT EXISTS new_access_tokens(
|
|
id BIGINT UNSIGNED PRIMARY KEY,
|
|
user_id TEXT NOT NULL,
|
|
device_id TEXT,
|
|
token TEXT NOT NULL,
|
|
last_used BIGINT UNSIGNED,
|
|
UNIQUE(token)
|
|
);
|
|
|
|
INSERT INTO new_access_tokens
|
|
SELECT a.id, u.name, a.device_id, a.token, a.last_used
|
|
FROM access_tokens as a
|
|
INNER JOIN users as u ON u.id = a.user_id;
|
|
|
|
DROP TABLE access_tokens;
|
|
|
|
ALTER TABLE new_access_tokens RENAME TO access_tokens;
|
|
|
|
-- Remove ID column from `users` table
|
|
CREATE TABLE IF NOT EXISTS new_users(
|
|
name TEXT,
|
|
password_hash TEXT,
|
|
creation_ts BIGINT UNSIGNED,
|
|
admin BOOL DEFAULT 0 NOT NULL,
|
|
UNIQUE(name)
|
|
);
|
|
|
|
INSERT INTO new_users SELECT name, password_hash, creation_ts, admin FROM users;
|
|
|
|
DROP TABLE users;
|
|
|
|
ALTER TABLE new_users RENAME TO users;
|
|
|
|
|
|
-- Remove UNIQUE constraint from `user_ips` table
|
|
CREATE TABLE IF NOT EXISTS new_user_ips (
|
|
user_id TEXT NOT NULL,
|
|
access_token TEXT NOT NULL,
|
|
device_id TEXT,
|
|
ip TEXT NOT NULL,
|
|
user_agent TEXT NOT NULL,
|
|
last_seen BIGINT UNSIGNED NOT NULL
|
|
);
|
|
|
|
INSERT INTO new_user_ips
|
|
SELECT user, access_token, device_id, ip, user_agent, last_seen FROM user_ips;
|
|
|
|
DROP TABLE user_ips;
|
|
|
|
ALTER TABLE new_user_ips RENAME TO user_ips;
|
|
|
|
CREATE INDEX IF NOT EXISTS user_ips_user ON user_ips(user_id);
|
|
CREATE INDEX IF NOT EXISTS user_ips_user_ip ON user_ips(user_id, access_token, ip);
|
|
|