Files
blackroad-operating-system/backend/app/config.py
Claude a180873b7d Fix frontend errors and pydantic config for local development
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)
2025-11-20 01:38:56 +00:00

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()