diff options
author | Richard van der Hoff <1389908+richvdh@users.noreply.github.com> | 2020-01-10 12:17:22 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-01-10 12:17:22 +0000 |
commit | 1d16f5ea0e1329b7613336a8c15b245513579bbd (patch) | |
tree | a263385a214bed54afb99d803e6d262fa9a40009 /scripts | |
parent | Merge branch 'master' of github.com:matrix-org/synapse into develop (diff) | |
parent | update install notes for CentOS (diff) | |
download | synapse-1d16f5ea0e1329b7613336a8c15b245513579bbd.tar.xz |
Merge pull request #6675 from matrix-org/rav/die_sqlite37_die_die_die
Refuse to start if sqlite is older than 3.11.0
Diffstat (limited to 'scripts')
-rwxr-xr-x | scripts/synapse_port_db | 39 |
1 files changed, 18 insertions, 21 deletions
diff --git a/scripts/synapse_port_db b/scripts/synapse_port_db index cb77314f1e..f135c8bc54 100755 --- a/scripts/synapse_port_db +++ b/scripts/synapse_port_db @@ -447,20 +447,15 @@ class Porter(object): else: return - def setup_db(self, db_config: DatabaseConnectionConfig, engine): - db_conn = make_conn(db_config, engine) - prepare_database(db_conn, engine, config=None) - - db_conn.commit() - - return db_conn - - @defer.inlineCallbacks - def build_db_store(self, db_config: DatabaseConnectionConfig): + def build_db_store( + self, db_config: DatabaseConnectionConfig, allow_outdated_version: bool = False, + ): """Builds and returns a database store using the provided configuration. Args: - config: The database configuration + db_config: The database configuration + allow_outdated_version: True to suppress errors about the database server + version being too old to run a complete synapse Returns: The built Store object. @@ -468,16 +463,16 @@ class Porter(object): self.progress.set_state("Preparing %s" % db_config.config["name"]) engine = create_engine(db_config.config) - conn = self.setup_db(db_config, engine) hs = MockHomeserver(self.hs_config) - store = Store(Database(hs, db_config, engine), conn, hs) - - yield store.db.runInteraction( - "%s_engine.check_database" % db_config.config["name"], - engine.check_database, - ) + with make_conn(db_config, engine) as db_conn: + engine.check_database( + db_conn, allow_outdated_version=allow_outdated_version + ) + prepare_database(db_conn, engine, config=None) + store = Store(Database(hs, db_config, engine), db_conn, hs) + db_conn.commit() return store @@ -502,8 +497,10 @@ class Porter(object): @defer.inlineCallbacks def run(self): try: - self.sqlite_store = yield self.build_db_store( - DatabaseConnectionConfig("master-sqlite", self.sqlite_config) + # we allow people to port away from outdated versions of sqlite. + self.sqlite_store = self.build_db_store( + DatabaseConnectionConfig("master-sqlite", self.sqlite_config), + allow_outdated_version=True, ) # Check if all background updates are done, abort if not. @@ -518,7 +515,7 @@ class Porter(object): ) defer.returnValue(None) - self.postgres_store = yield self.build_db_store( + self.postgres_store = self.build_db_store( self.hs_config.get_single_database() ) |