diff options
author | Kegsay <kegsay@gmail.com> | 2015-03-02 14:56:32 +0000 |
---|---|---|
committer | Kegsay <kegsay@gmail.com> | 2015-03-02 14:56:32 +0000 |
commit | 8ad024ea80ab8f9747472df3e96154b51c04ae13 (patch) | |
tree | cfc962d742805c866885aae7b4ec41dd4400e94e /scripts/upgrade_appservice_db.py | |
parent | Merge pull request #88 from matrix-org/batched_get_pdu (diff) | |
parent | Wording tweaks (diff) | |
download | synapse-8ad024ea80ab8f9747472df3e96154b51c04ae13.tar.xz |
Merge pull request #93 from matrix-org/application-services-exclusive
Application services exclusive flag support
Diffstat (limited to 'scripts/upgrade_appservice_db.py')
-rw-r--r-- | scripts/upgrade_appservice_db.py | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/scripts/upgrade_appservice_db.py b/scripts/upgrade_appservice_db.py new file mode 100644 index 0000000000..ae1b91c64f --- /dev/null +++ b/scripts/upgrade_appservice_db.py @@ -0,0 +1,54 @@ +from synapse.storage import read_schema +import argparse +import json +import sqlite3 + + +def do_other_deltas(cursor): + cursor.execute("PRAGMA user_version") + row = cursor.fetchone() + + if row and row[0]: + user_version = row[0] + # Run every version since after the current version. + for v in range(user_version + 1, 10): + print "Running delta: %d" % (v,) + sql_script = read_schema("delta/v%d" % (v,)) + cursor.executescript(sql_script) + + +def update_app_service_table(cur): + cur.execute("SELECT id, regex FROM application_services_regex") + for row in cur.fetchall(): + try: + print "checking %s..." % row[0] + json.loads(row[1]) + except ValueError: + # row isn't in json, make it so. + string_regex = row[1] + new_regex = json.dumps({ + "regex": string_regex, + "exclusive": True + }) + cur.execute( + "UPDATE application_services_regex SET regex=? WHERE id=?", + (new_regex, row[0]) + ) + + +def main(dbname): + con = sqlite3.connect(dbname) + cur = con.cursor() + do_other_deltas(cur) + update_app_service_table(cur) + cur.execute("PRAGMA user_version = 14") + cur.close() + con.commit() + + +if __name__ == "__main__": + parser = argparse.ArgumentParser() + parser.add_argument("database") + args = parser.parse_args() + + main(args.database) |