dd2ebf863a
Security hardening: CORS lockdown, rate limiting middleware con sliding window e eviction IP stale, security headers (CSP, HSTS, X-Frame-Options), session cookie hardening, filename sanitization upload. i18n completion: internazionalizzati barcode.js e csv-export.js con bridge window.BARCODE_I18N/CSV_I18N, aggiornati .po IT/EN con 27 nuove stringhe. Tablet UX: touch target 44px per dispositivi coarse pointer. Test suite: 101 test totali (76 server + 25 client), copertura completa di tutti i router API, autenticazione, ruoli, CRUD, SPC, file upload, security integration. Infrastruttura SQLite async in-memory con fixtures. Fix critici: MissingGreenlet in recipe_service (selectinload eager), route ordering tasks.py, auth_service bcrypt diretto, Measurement.id Integer per SQLite. Documentazione: API.md (riferimento completo 40+ endpoint), DEPLOYMENT.md (guida produzione con Docker/Nginx/SSL), USER_GUIDE.md (manuale utente per ruolo). Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
29 lines
868 B
Python
29 lines
868 B
Python
"""TieMeasureFlow Client Configuration."""
|
|
import os
|
|
from dotenv import load_dotenv
|
|
|
|
load_dotenv(os.path.join(os.path.dirname(__file__), '..', '.env'))
|
|
|
|
|
|
class Config:
|
|
"""Flask client configuration."""
|
|
|
|
# Flask
|
|
SECRET_KEY = os.getenv("CLIENT_SECRET_KEY", "change-this-to-another-random-secret-key")
|
|
DEBUG = os.getenv("FLASK_DEBUG", "0") == "1"
|
|
|
|
# API Server connection
|
|
API_SERVER_URL = os.getenv("API_SERVER_URL", "http://localhost:8000")
|
|
|
|
# Session
|
|
SESSION_COOKIE_HTTPONLY = True
|
|
SESSION_COOKIE_SAMESITE = "Lax"
|
|
SESSION_COOKIE_SECURE = not DEBUG # Only secure cookies in production (HTTPS)
|
|
PERMANENT_SESSION_LIFETIME = 28800 # 8 hours
|
|
WTF_CSRF_TIME_LIMIT = 3600 # 1 hour
|
|
|
|
# Babel i18n
|
|
BABEL_DEFAULT_LOCALE = "it"
|
|
BABEL_DEFAULT_TIMEZONE = "Europe/Rome"
|
|
LANGUAGES = {"it": "Italiano", "en": "English"}
|