1
0

settings.php 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. <?php
  2. declare(strict_types=1);
  3. use App\Domain\Auth\Role;
  4. use Monolog\Level;
  5. $appEnv = getenv('APP_ENV') ?: 'production';
  6. if ($appEnv === 'development' && file_exists(__DIR__ . '/../.env')) {
  7. $dotenv = Dotenv\Dotenv::createImmutable(__DIR__ . '/..');
  8. $dotenv->safeLoad();
  9. }
  10. $logLevelName = strtoupper((string) (getenv('LOG_LEVEL') ?: 'info'));
  11. $logLevel = match ($logLevelName) {
  12. 'DEBUG' => Level::Debug,
  13. 'NOTICE' => Level::Notice,
  14. 'WARNING' => Level::Warning,
  15. 'ERROR' => Level::Error,
  16. 'CRITICAL' => Level::Critical,
  17. 'ALERT' => Level::Alert,
  18. 'EMERGENCY' => Level::Emergency,
  19. default => Level::Info,
  20. };
  21. $oidcDefaultRoleName = strtolower((string) (getenv('OIDC_DEFAULT_ROLE') ?: 'viewer'));
  22. $oidcDefaultRole = $oidcDefaultRoleName === 'none'
  23. ? null
  24. : (Role::tryFrom($oidcDefaultRoleName) ?? Role::Viewer);
  25. return [
  26. 'app_env' => $appEnv,
  27. 'log_level' => $logLevel,
  28. 'app_secret' => getenv('APP_SECRET') ?: '',
  29. 'db' => [
  30. 'driver' => getenv('DB_DRIVER') ?: 'sqlite',
  31. 'sqlite_path' => getenv('DB_SQLITE_PATH') ?: '/data/irdb.sqlite',
  32. 'mysql_host' => getenv('DB_MYSQL_HOST') ?: '',
  33. 'mysql_port' => (int) (getenv('DB_MYSQL_PORT') ?: 3306),
  34. 'mysql_database' => getenv('DB_MYSQL_DATABASE') ?: '',
  35. 'mysql_username' => getenv('DB_MYSQL_USERNAME') ?: '',
  36. 'mysql_password' => getenv('DB_MYSQL_PASSWORD') ?: '',
  37. ],
  38. 'ui_service_token' => getenv('UI_SERVICE_TOKEN') ?: '',
  39. 'internal_job_token' => getenv('INTERNAL_JOB_TOKEN') ?: '',
  40. 'internal_cidr_allowlist' => (string) (getenv('INTERNAL_CIDR_ALLOWLIST') ?: ''),
  41. 'ui_origin' => getenv('UI_ORIGIN') ?: 'http://localhost:8080',
  42. 'oidc_default_role' => $oidcDefaultRole,
  43. 'score_hard_cutoff_days' => (int) (getenv('SCORE_REPORT_HARD_CUTOFF_DAYS') ?: 365),
  44. 'rate_limit_per_second' => (int) (getenv('API_RATE_LIMIT_PER_SECOND') ?: 60),
  45. 'job_recompute_max_runtime_seconds' => (int) (getenv('JOB_RECOMPUTE_MAX_RUNTIME_SECONDS') ?: 240),
  46. 'job_recompute_max_rows_per_tick' => (int) (getenv('JOB_RECOMPUTE_MAX_ROWS_PER_TICK') ?: 5000),
  47. 'job_audit_retention_days' => (int) (getenv('JOB_AUDIT_RETENTION_DAYS') ?: 180),
  48. 'cidr_evaluator_ttl_seconds' => (int) (getenv('CIDR_EVALUATOR_TTL_SECONDS') ?: 60),
  49. 'blocklist_cache_ttl_seconds' => (int) (getenv('BLOCKLIST_CACHE_TTL_SECONDS') ?: 30),
  50. 'geoip' => [
  51. 'enabled' => filter_var(getenv('GEOIP_ENABLED') ?: 'true', FILTER_VALIDATE_BOOL),
  52. 'provider' => strtolower((string) (getenv('GEOIP_PROVIDER') ?: 'dbip')),
  53. 'country_db' => getenv('GEOIP_COUNTRY_DB') ?: '/data/geoip/country.mmdb',
  54. 'asn_db' => getenv('GEOIP_ASN_DB') ?: '/data/geoip/asn.mmdb',
  55. 'maxmind_license_key' => getenv('MAXMIND_LICENSE_KEY') ?: '',
  56. 'ipinfo_token' => getenv('IPINFO_TOKEN') ?: '',
  57. 'refresh_interval_days' => (int) (getenv('JOB_GEOIP_REFRESH_INTERVAL_DAYS') ?: 7),
  58. ],
  59. ];