-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathconfig.py
More file actions
103 lines (77 loc) · 3 KB
/
Copy pathconfig.py
File metadata and controls
103 lines (77 loc) · 3 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
"""
Configurazione dell'applicazione ErrorEngine
"""
import os
from datetime import timedelta
class Config:
"""Configurazione base."""
# Flask
SECRET_KEY = os.environ.get('SECRET_KEY') or 'chiave-segreta-da-cambiare-in-produzione'
# SQLite Database (DB di appoggio)
SQLALCHEMY_DATABASE_URI = os.environ.get('DATABASE_URL') or 'sqlite:///errorengine.db'
SQLALCHEMY_TRACK_MODIFICATIONS = False
# Configurazione Email (Exchange/SMTP)
MAIL_SERVER = os.environ.get('MAIL_SERVER') or 'smtp.office365.com'
MAIL_PORT = int(os.environ.get('MAIL_PORT') or 587)
MAIL_USE_TLS = os.environ.get('MAIL_USE_TLS', 'true').lower() == 'true'
MAIL_USERNAME = os.environ.get('MAIL_USERNAME', '')
MAIL_PASSWORD = os.environ.get('MAIL_PASSWORD', '')
MAIL_DEFAULT_SENDER = os.environ.get('MAIL_DEFAULT_SENDER', '')
# Scheduler
SCHEDULER_API_ENABLED = True
# HTTP/API timeout per sorgenti esterne
HTTP_TIMEOUT_SECONDS = int(os.environ.get('HTTP_TIMEOUT_SECONDS') or 30)
# Logging
LOG_LEVEL = os.environ.get('LOG_LEVEL') or 'INFO'
# Log retention (giorni)
LOG_RETENTION_DAYS = int(os.environ.get('LOG_RETENTION_DAYS') or 30)
# Email retention (giorni)
EMAIL_LOG_RETENTION_DAYS = int(os.environ.get('EMAIL_LOG_RETENTION_DAYS') or 90)
# Resolved errors retention (giorni) - errori risolti vengono eliminati dopo questo periodo
RESOLVED_ERRORS_RETENTION_DAYS = int(os.environ.get('RESOLVED_ERRORS_RETENTION_DAYS') or 60)
# Timezone per visualizzazione date (default: UTC)
TIMEZONE = os.environ.get('TIMEZONE', 'UTC')
# Babel i18n
BABEL_DEFAULT_LOCALE = 'en'
BABEL_SUPPORTED_LOCALES = ['en', 'it']
BABEL_TRANSLATION_DIRECTORIES = 'translations'
class DevelopmentConfig(Config):
"""Configurazione per sviluppo."""
DEBUG = True
LOG_LEVEL = 'DEBUG'
class ProductionConfig(Config):
"""Configurazione per produzione."""
DEBUG = False
LOG_LEVEL = 'WARNING'
# In produzione la SECRET_KEY deve essere impostata via env
@property
def SECRET_KEY(self):
key = os.environ.get('SECRET_KEY')
if not key:
raise ValueError("SECRET_KEY deve essere impostata in produzione")
return key
class TestingConfig(Config):
"""Configurazione per testing."""
TESTING = True
DEBUG = True
# Database in memoria per test veloci
SQLALCHEMY_DATABASE_URI = 'sqlite:///:memory:'
# Disabilita scheduler durante i test
SCHEDULER_API_ENABLED = False
# Email mock
MAIL_SERVER = 'localhost'
MAIL_PORT = 25
MAIL_USE_TLS = False
MAIL_USERNAME = 'test@test.com'
MAIL_PASSWORD = 'test'
MAIL_DEFAULT_SENDER = 'test@test.com'
# Retention breve per test
LOG_RETENTION_DAYS = 1
EMAIL_LOG_RETENTION_DAYS = 1
RESOLVED_ERRORS_RETENTION_DAYS = 1
config = {
'development': DevelopmentConfig,
'production': ProductionConfig,
'testing': TestingConfig,
'default': DevelopmentConfig
}