2016-01-06 21:26:29 -07:00
|
|
|
# Copyright 2015, 2016 OpenMarket Ltd
|
2015-04-01 07:12:33 -06:00
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
2022-06-07 10:33:55 -06:00
|
|
|
from typing import Any, Mapping, NoReturn
|
2015-04-02 03:06:22 -06:00
|
|
|
|
2020-02-27 04:53:40 -07:00
|
|
|
from ._base import BaseDatabaseEngine, IncorrectDatabaseSetup
|
2022-06-07 10:33:55 -06:00
|
|
|
|
|
|
|
# The classes `PostgresEngine` and `Sqlite3Engine` must always be importable, because
|
|
|
|
# we use `isinstance(engine, PostgresEngine)` to write different queries for postgres
|
|
|
|
# and sqlite. But the database driver modules are both optional: they may not be
|
|
|
|
# installed. To account for this, create dummy classes on import failure so we can
|
|
|
|
# still run `isinstance()` checks.
|
|
|
|
try:
|
|
|
|
from .postgres import PostgresEngine
|
|
|
|
except ImportError:
|
|
|
|
|
|
|
|
class PostgresEngine(BaseDatabaseEngine): # type: ignore[no-redef]
|
|
|
|
def __new__(cls, *args: object, **kwargs: object) -> NoReturn: # type: ignore[misc]
|
|
|
|
raise RuntimeError(
|
|
|
|
f"Cannot create {cls.__name__} -- psycopg2 module is not installed"
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
from .sqlite import Sqlite3Engine
|
|
|
|
except ImportError:
|
|
|
|
|
|
|
|
class Sqlite3Engine(BaseDatabaseEngine): # type: ignore[no-redef]
|
|
|
|
def __new__(cls, *args: object, **kwargs: object) -> NoReturn: # type: ignore[misc]
|
|
|
|
raise RuntimeError(
|
|
|
|
f"Cannot create {cls.__name__} -- sqlite3 module is not installed"
|
|
|
|
)
|
2015-04-01 07:12:33 -06:00
|
|
|
|
|
|
|
|
2022-05-16 17:34:38 -06:00
|
|
|
def create_engine(database_config: Mapping[str, Any]) -> BaseDatabaseEngine:
|
2016-04-06 07:08:18 -06:00
|
|
|
name = database_config["name"]
|
2015-04-01 07:12:33 -06:00
|
|
|
|
2020-02-27 04:53:40 -07:00
|
|
|
if name == "sqlite3":
|
2022-05-16 17:34:38 -06:00
|
|
|
return Sqlite3Engine(database_config)
|
2020-02-27 04:53:40 -07:00
|
|
|
|
|
|
|
if name == "psycopg2":
|
2022-05-16 17:34:38 -06:00
|
|
|
return PostgresEngine(database_config)
|
2015-04-01 07:12:33 -06:00
|
|
|
|
2019-04-03 03:07:29 -06:00
|
|
|
raise RuntimeError("Unsupported database engine '%s'" % (name,))
|
2015-04-29 04:56:38 -06:00
|
|
|
|
|
|
|
|
2022-06-07 10:33:55 -06:00
|
|
|
__all__ = [
|
|
|
|
"create_engine",
|
|
|
|
"BaseDatabaseEngine",
|
|
|
|
"PostgresEngine",
|
|
|
|
"Sqlite3Engine",
|
|
|
|
"IncorrectDatabaseSetup",
|
|
|
|
]
|