settings.php 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  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. 'ui_origin' => getenv('UI_ORIGIN') ?: 'http://localhost:8080',
  41. 'oidc_default_role' => $oidcDefaultRole,
  42. ];