C-6: ConnectorRuntime enforces capability_mask per operation.
READ-only ACs cannot invoke MUTATE operations (wipe, lock, retire).
C-7: AC validated against database (exists, active, not expired)
before connector invocation.
C-9: Delegated AC capability bounded by delegator's capability.
C-10: Command counter uses atomic SQL increment with limit check.
M-23: expire_stale() uses same atomic SQL pattern.
H-1: Sensitive credential fields hidden from repr/logs via repr=False.
H-2: Stub backend requires ALLOW_STUB_CREDENTIALS=true to activate.
H-3: Kerberos backend raises CredentialResolutionError instead of
returning stub ticket.
H-4: Chronicle INTENT emitted before execution, RESULT after.
H-5: device_id validated as UUID before Graph API URL interpolation.
H-8: ConnectorRuntime enforces governance for all connector invocations.
Signed-off-by: Tyler King <tking@guildhouse.dev>
62 lines
1.8 KiB
Python
62 lines
1.8 KiB
Python
# dialects/__init__.py
|
|
# Copyright (C) 2005-2026 the SQLAlchemy authors and contributors
|
|
# <see AUTHORS file>
|
|
#
|
|
# This module is part of SQLAlchemy and is released under
|
|
# the MIT License: https://www.opensource.org/licenses/mit-license.php
|
|
|
|
from __future__ import annotations
|
|
|
|
from typing import Any
|
|
from typing import Callable
|
|
from typing import Optional
|
|
from typing import Type
|
|
from typing import TYPE_CHECKING
|
|
|
|
from .. import util
|
|
|
|
if TYPE_CHECKING:
|
|
from ..engine.interfaces import Dialect
|
|
|
|
__all__ = ("mssql", "mysql", "oracle", "postgresql", "sqlite")
|
|
|
|
|
|
def _auto_fn(name: str) -> Optional[Callable[[], Type[Dialect]]]:
|
|
"""default dialect importer.
|
|
|
|
plugs into the :class:`.PluginLoader`
|
|
as a first-hit system.
|
|
|
|
"""
|
|
if "." in name:
|
|
dialect, driver = name.split(".")
|
|
else:
|
|
dialect = name
|
|
driver = "base"
|
|
|
|
try:
|
|
if dialect == "mariadb":
|
|
# it's "OK" for us to hardcode here since _auto_fn is already
|
|
# hardcoded. if mysql / mariadb etc were third party dialects
|
|
# they would just publish all the entrypoints, which would actually
|
|
# look much nicer.
|
|
module: Any = __import__(
|
|
"sqlalchemy.dialects.mysql.mariadb"
|
|
).dialects.mysql.mariadb
|
|
return module.loader(driver) # type: ignore
|
|
else:
|
|
module = __import__("sqlalchemy.dialects.%s" % (dialect,)).dialects
|
|
module = getattr(module, dialect)
|
|
except ImportError:
|
|
return None
|
|
|
|
if hasattr(module, driver):
|
|
module = getattr(module, driver)
|
|
return lambda: module.dialect
|
|
else:
|
|
return None
|
|
|
|
|
|
registry = util.PluginLoader("sqlalchemy.dialects", auto_fn=_auto_fn)
|
|
|
|
plugins = util.PluginLoader("sqlalchemy.plugins")
|