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>
38 lines
1 KiB
Python
38 lines
1 KiB
Python
__all__ = 'compiled', 'VERSION', 'version_info'
|
|
|
|
VERSION = '1.10.21'
|
|
|
|
try:
|
|
import cython # type: ignore
|
|
except ImportError:
|
|
compiled: bool = False
|
|
else: # pragma: no cover
|
|
try:
|
|
compiled = cython.compiled
|
|
except AttributeError:
|
|
compiled = False
|
|
|
|
|
|
def version_info() -> str:
|
|
import platform
|
|
import sys
|
|
from importlib import import_module
|
|
from pathlib import Path
|
|
|
|
optional_deps = []
|
|
for p in ('devtools', 'dotenv', 'email-validator', 'typing-extensions'):
|
|
try:
|
|
import_module(p.replace('-', '_'))
|
|
except ImportError:
|
|
continue
|
|
optional_deps.append(p)
|
|
|
|
info = {
|
|
'pydantic version': VERSION,
|
|
'pydantic compiled': compiled,
|
|
'install path': Path(__file__).resolve().parent,
|
|
'python version': sys.version,
|
|
'platform': platform.platform(),
|
|
'optional deps. installed': optional_deps,
|
|
}
|
|
return '\n'.join('{:>30} {}'.format(k + ':', str(v).replace('\n', ' ')) for k, v in info.items())
|