mirror of
https://mau.dev/maunium/synapse.git
synced 2024-09-18 15:25:41 +00:00
6efa674004
Cleans-up the schema delta files: * Removes no-op functions. * Adds missing type hints to function parameters. * Fixes any issues with type hints. This also renames one (very old) schema delta to avoid a conflict that mypy complains about.
49 lines
1.6 KiB
Python
49 lines
1.6 KiB
Python
import logging
|
|
from io import StringIO
|
|
|
|
from synapse.storage.database import LoggingTransaction
|
|
from synapse.storage.engines import BaseDatabaseEngine, PostgresEngine
|
|
from synapse.storage.prepare_database import execute_statements_from_stream
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
"""
|
|
This migration updates the user_filters table as follows:
|
|
|
|
- drops any (user_id, filter_id) duplicates
|
|
- makes the columns NON-NULLable
|
|
- turns the index into a UNIQUE index
|
|
"""
|
|
|
|
|
|
def run_create(cur: LoggingTransaction, database_engine: BaseDatabaseEngine) -> None:
|
|
if isinstance(database_engine, PostgresEngine):
|
|
select_clause = """
|
|
SELECT DISTINCT ON (user_id, filter_id) user_id, filter_id, filter_json
|
|
FROM user_filters
|
|
"""
|
|
else:
|
|
select_clause = """
|
|
SELECT * FROM user_filters GROUP BY user_id, filter_id
|
|
"""
|
|
sql = """
|
|
DROP TABLE IF EXISTS user_filters_migration;
|
|
DROP INDEX IF EXISTS user_filters_unique;
|
|
CREATE TABLE user_filters_migration (
|
|
user_id TEXT NOT NULL,
|
|
filter_id BIGINT NOT NULL,
|
|
filter_json BYTEA NOT NULL
|
|
);
|
|
INSERT INTO user_filters_migration (user_id, filter_id, filter_json)
|
|
%s;
|
|
CREATE UNIQUE INDEX user_filters_unique ON user_filters_migration
|
|
(user_id, filter_id);
|
|
DROP TABLE user_filters;
|
|
ALTER TABLE user_filters_migration RENAME TO user_filters;
|
|
""" % (
|
|
select_clause,
|
|
)
|
|
|
|
execute_statements_from_stream(cur, StringIO(sql))
|