mirror of
https://github.com/bunny-lab-io/Borealis.git
synced 2025-10-26 17:41:58 -06:00
fix: relocate server runtime secrets
This commit is contained in:
78
Data/Server/Modules/runtime.py
Normal file
78
Data/Server/Modules/runtime.py
Normal file
@@ -0,0 +1,78 @@
|
||||
"""Utility helpers for locating runtime storage paths.
|
||||
|
||||
The Borealis repository keeps the authoritative source code under ``Data/``
|
||||
so that the bootstrap scripts can copy those assets into sibling ``Server/``
|
||||
and ``Agent/`` directories for execution. Runtime artefacts such as TLS
|
||||
certificates or signing keys must therefore live outside ``Data`` to avoid
|
||||
polluting the template tree. This module centralises the path selection so
|
||||
other modules can rely on a consistent location regardless of whether they
|
||||
are executed from the copied runtime directory or directly from ``Data``
|
||||
during development.
|
||||
"""
|
||||
|
||||
from __future__ import annotations
|
||||
|
||||
import os
|
||||
from functools import lru_cache
|
||||
from pathlib import Path
|
||||
from typing import Optional
|
||||
|
||||
|
||||
def _env_path(name: str) -> Optional[Path]:
|
||||
"""Return a resolved ``Path`` for the given environment variable."""
|
||||
|
||||
value = os.environ.get(name)
|
||||
if not value:
|
||||
return None
|
||||
try:
|
||||
return Path(value).expanduser().resolve()
|
||||
except Exception:
|
||||
return None
|
||||
|
||||
|
||||
@lru_cache(maxsize=None)
|
||||
def project_root() -> Path:
|
||||
"""Best-effort detection of the repository root."""
|
||||
|
||||
env = _env_path("BOREALIS_PROJECT_ROOT")
|
||||
if env:
|
||||
return env
|
||||
|
||||
current = Path(__file__).resolve()
|
||||
for parent in current.parents:
|
||||
if (parent / "Borealis.ps1").exists() or (parent / ".git").is_dir():
|
||||
return parent
|
||||
|
||||
# Fallback to the ancestor that corresponds to ``<repo>/`` when the module
|
||||
# lives under ``Data/Server/Modules``.
|
||||
try:
|
||||
return current.parents[4]
|
||||
except IndexError:
|
||||
return current.parent
|
||||
|
||||
|
||||
@lru_cache(maxsize=None)
|
||||
def server_runtime_root() -> Path:
|
||||
"""Location where the running server stores mutable artefacts."""
|
||||
|
||||
env = _env_path("BOREALIS_SERVER_ROOT")
|
||||
if env:
|
||||
return env
|
||||
|
||||
root = project_root()
|
||||
runtime = root / "Server" / "Borealis"
|
||||
return runtime
|
||||
|
||||
|
||||
def runtime_path(*parts: str) -> Path:
|
||||
"""Return a path relative to the server runtime root."""
|
||||
|
||||
return server_runtime_root().joinpath(*parts)
|
||||
|
||||
|
||||
def ensure_runtime_dir(*parts: str) -> Path:
|
||||
"""Create (if required) and return a runtime directory."""
|
||||
|
||||
path = runtime_path(*parts)
|
||||
path.mkdir(parents=True, exist_ok=True)
|
||||
return path
|
||||
Reference in New Issue
Block a user