mirror of
https://github.com/blackboxprogramming/BlackRoad-Operating-System.git
synced 2026-03-17 06:57:17 -05:00
Frontend fixes: - Copy missing JS files from blackroad-os/ to backend/static/js/ - os.js (core OS functionality) - components.js (UI components) - registry.js (app registry) - app.js, config.js, theme.js, mock_data.js (supporting files) - Fixes 3 ERROR findings from Cece audit - System health: 0 ERRORS → 94 SUCCESSES (from 91) Backend config fix: - Add `extra = "ignore"` to Settings.Config in backend/app/config.py - Allows .env.example to have more vars than Settings class defines - Fixes Pydantic v2 validation errors on startup - Enables local development without removing env template vars Cece audit results after fixes: 🔴 CRITICAL: 0 🟠 ERROR: 0 (was 3) 🟡 WARNING: 6 🟢 SUCCESS: 94 (was 91)
70 lines
2.0 KiB
Python
70 lines
2.0 KiB
Python
"""Application configuration"""
|
|
from pydantic_settings import BaseSettings
|
|
from typing import List
|
|
|
|
|
|
class Settings(BaseSettings):
|
|
"""Application settings"""
|
|
|
|
# Application
|
|
APP_NAME: str = "BlackRoad Operating System"
|
|
APP_VERSION: str = "1.0.0"
|
|
DEBUG: bool = True
|
|
ENVIRONMENT: str = "development"
|
|
|
|
# Database
|
|
# Provide sensible defaults so local development and tests can run
|
|
# without requiring environment configuration.
|
|
DATABASE_URL: str = "sqlite:///./test.db"
|
|
DATABASE_ASYNC_URL: str = "sqlite+aiosqlite:///./test.db"
|
|
|
|
# Redis
|
|
REDIS_URL: str = "redis://localhost:6379/0"
|
|
|
|
# Security
|
|
SECRET_KEY: str = "local-dev-secret-key"
|
|
ALGORITHM: str = "HS256"
|
|
ACCESS_TOKEN_EXPIRE_MINUTES: int = 30
|
|
REFRESH_TOKEN_EXPIRE_DAYS: int = 7
|
|
WALLET_MASTER_KEY: str = "local-wallet-master-key-32chars-0000"
|
|
|
|
# CORS
|
|
# Include production domains by default to ensure Railway deployments work
|
|
ALLOWED_ORIGINS: str = "https://blackroad.systems,https://www.blackroad.systems,https://os.blackroad.systems,https://blackroad-operating-system-production.up.railway.app,http://localhost:3000,http://localhost:8000"
|
|
|
|
@property
|
|
def allowed_origins_list(self) -> List[str]:
|
|
return [origin.strip() for origin in self.ALLOWED_ORIGINS.split(",")]
|
|
|
|
# AWS S3
|
|
AWS_ACCESS_KEY_ID: str = ""
|
|
AWS_SECRET_ACCESS_KEY: str = ""
|
|
AWS_REGION: str = "us-east-1"
|
|
S3_BUCKET_NAME: str = "blackroad-files"
|
|
|
|
# Email
|
|
SMTP_HOST: str = "smtp.gmail.com"
|
|
SMTP_PORT: int = 587
|
|
SMTP_USER: str = ""
|
|
SMTP_PASSWORD: str = ""
|
|
EMAIL_FROM: str = "noreply@blackroad.com"
|
|
|
|
# OpenAI
|
|
OPENAI_API_KEY: str = ""
|
|
|
|
# Blockchain
|
|
BLOCKCHAIN_DIFFICULTY: int = 4
|
|
MINING_REWARD: float = 50.0
|
|
|
|
# GitHub Automation (Phase Q)
|
|
GITHUB_TOKEN: str = ""
|
|
GITHUB_WEBHOOK_SECRET: str = ""
|
|
|
|
class Config:
|
|
env_file = ".env"
|
|
case_sensitive = True
|
|
extra = "ignore" # Allow extra env vars in .env file
|
|
|
|
|
|
settings = Settings()
|