Initial commit: Crumbforest Architecture Refinement v1 (Clean)

This commit is contained in:
2025-12-07 01:26:46 +01:00
commit 6c38ed680b
633 changed files with 61797 additions and 0 deletions

View File

@@ -0,0 +1,52 @@
import json
import os
from typing import Dict, Any, Optional
CONFIG_PATH = "crumbforest_config.json"
class ConfigLoader:
_config: Optional[Dict[str, Any]] = None
@classmethod
def load_config(cls, force_reload: bool = False) -> Dict[str, Any]:
if cls._config is None or force_reload:
try:
# Try to find config in root or app root
paths_to_try = [CONFIG_PATH, os.path.join("..", CONFIG_PATH), os.path.join(os.getcwd(), CONFIG_PATH)]
found = False
for path in paths_to_try:
if os.path.exists(path):
with open(path, 'r', encoding='utf-8') as f:
cls._config = json.load(f)
found = True
break
if not found:
print(f"Warning: {CONFIG_PATH} not found in {paths_to_try}")
cls._config = {"roles": {}, "groups": {}, "theme_variants": {}}
except Exception as e:
print(f"Error loading config: {e}")
cls._config = {"roles": {}, "groups": {}, "theme_variants": {}}
return cls._config
@classmethod
def get_role(cls, role_id: str) -> Optional[Dict[str, Any]]:
config = cls.load_config()
return config.get('roles', {}).get(role_id)
@classmethod
def get_group(cls, group_id: str) -> Optional[Dict[str, Any]]:
config = cls.load_config()
return config.get('groups', {}).get(group_id)
@classmethod
def get_theme(cls, theme_id: str) -> Optional[Dict[str, Any]]:
config = cls.load_config()
return config.get('theme_variants', {}).get(theme_id)
@classmethod
def get_all_roles(cls) -> Dict[str, Any]:
config = cls.load_config()
return config.get('roles', {})