- Systeme de themes adaptatifs : Peps (light chaud), Zen (light calme), Chagrine (dark violet), Grave (dark ambre) avec CSS custom properties - Dashboard d'accueil orienté onboarding avec cartes-portes et teaser boite a outils - SectionLayout reutilisable : liste + sidebar toolbox + status pills cliquables (En prepa / En vote / En vigueur / Clos) - ToolboxVignette : vignettes Contexte / Tutos / Choisir / Demarrer - Seed : Acte engagement certification + forgeron, Runtime Upgrade (decision on-chain), 3 modalites de vote (majoritaire, quadratique, permanent) - Backend adapte SQLite (Uuid portable, 204 fix, pool conditionnel) - Correction noms composants (pathPrefix: false), pinia/nuxt ^0.11 Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
51 lines
1.4 KiB
Python
51 lines
1.4 KiB
Python
from pydantic_settings import BaseSettings
|
|
from pathlib import Path
|
|
|
|
|
|
class Settings(BaseSettings):
|
|
APP_NAME: str = "Glibredecision"
|
|
DEBUG: bool = True
|
|
|
|
# Environment
|
|
ENVIRONMENT: str = "development" # development, staging, production
|
|
LOG_LEVEL: str = "INFO"
|
|
|
|
# Database — SQLite by default for local dev, PostgreSQL for Docker/prod
|
|
DATABASE_URL: str = "sqlite+aiosqlite:///./glibredecision.db"
|
|
DATABASE_POOL_SIZE: int = 20
|
|
DATABASE_MAX_OVERFLOW: int = 10
|
|
|
|
# Auth
|
|
SECRET_KEY: str = "change-me-in-production-with-a-real-secret-key"
|
|
CHALLENGE_EXPIRE_SECONDS: int = 300
|
|
TOKEN_EXPIRE_HOURS: int = 24
|
|
SESSION_TTL_HOURS: int = 24
|
|
|
|
# Duniter V2 RPC
|
|
DUNITER_RPC_URL: str = "wss://gdev.p2p.legal/ws"
|
|
DUNITER_RPC_TIMEOUT_SECONDS: int = 10
|
|
|
|
# IPFS
|
|
IPFS_API_URL: str = "http://localhost:5001"
|
|
IPFS_GATEWAY_URL: str = "http://localhost:8080"
|
|
IPFS_TIMEOUT_SECONDS: int = 30
|
|
|
|
# CORS
|
|
CORS_ORIGINS: list[str] = ["http://localhost:3002"]
|
|
|
|
# Rate limiting (requests per minute)
|
|
RATE_LIMIT_DEFAULT: int = 60
|
|
RATE_LIMIT_AUTH: int = 10
|
|
RATE_LIMIT_VOTE: int = 30
|
|
|
|
# Blockchain cache
|
|
BLOCKCHAIN_CACHE_TTL_SECONDS: int = 3600
|
|
|
|
# Paths
|
|
BASE_DIR: Path = Path(__file__).resolve().parent.parent
|
|
|
|
model_config = {"env_file": ".env", "env_file_encoding": "utf-8"}
|
|
|
|
|
|
settings = Settings()
|