File: settings.py

package info (click to toggle)
python-django-pgschemas 1.0.1-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 848 kB
  • sloc: python: 3,887; makefile: 33; sh: 10; sql: 2
file content (50 lines) | stat: -rw-r--r-- 1,369 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
from importlib import import_module
from types import ModuleType
from typing import Callable

from django.conf import settings
from django.db import DEFAULT_DB_ALIAS

DEFAULT_BACKEND = "django.db.backends.postgresql"


def get_tenant_db_alias() -> str:
    return getattr(settings, "PGSCHEMAS_TENANT_DB_ALIAS", DEFAULT_DB_ALIAS)


def get_limit_set_calls() -> bool:
    return getattr(settings, "PGSCHEMAS_LIMIT_SET_CALLS", False)


def get_original_backend() -> str:
    return getattr(settings, "PGSCHEMAS_ORIGINAL_BACKEND", DEFAULT_BACKEND)


def get_extra_search_paths() -> list[str]:
    return getattr(settings, "PGSCHEMAS_EXTRA_SEARCH_PATHS", [])


def get_tenant_session_key() -> str:
    return getattr(settings, "PGSCHEMAS_TENANT_SESSION_KEY", "tenant")


def get_tenant_header() -> str:
    return getattr(settings, "PGSCHEMAS_TENANT_HEADER", "tenant")


def get_pathname_function() -> Callable | None:
    return getattr(settings, "PGSCHEMAS_PATHNAME_FUNCTION", None)


def get_base_backend_module(submodule: str | None = None) -> ModuleType:
    module = DEFAULT_BACKEND
    if submodule:
        module += f".{submodule}"
    return import_module(module)


def get_original_backend_module(submodule: str | None = None) -> ModuleType:
    module = get_original_backend()
    if submodule:
        module += f".{submodule}"
    return import_module(module)