config.sample.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. <?php
  2. // Configuration for the PSA order system.
  3. // Site settings
  4. define('SITE_NAME', 'Stadt Freising');
  5. define('SITE_SERVICE_NAME', 'Bestellservice');
  6. define('SITE_SERVICE_HEADER', 'Amt 32 - Öffentliche Sicherheit und Ordnung');
  7. define('SITE_DEPARTMENT_NAME', 'Amt 32 - Öffentliche Sicherheit und Ordnung');
  8. define('SITE_ADDRESS_LINE', 'Dr.-von-Daller-Straße 7, 85354 Freising');
  9. define('SITE_IMPRINT_URL', 'https://www.freising.de/impressum/');
  10. define('SITE_PRIVACY_URL', 'https://www.freising.de/datenschutz');
  11. define('SITE_FULL_NAME', SITE_NAME . ' - ' . SITE_SERVICE_HEADER);
  12. define('SITE_URL', '/shop'); // Leave empty for root, or use absolute URL
  13. // Optional: scheme + host only (no path) for absolute links in e-mails when HTTP_HOST is wrong behind proxies.
  14. // define('SITE_CANONICAL_ORIGIN', 'https://www.example.org');
  15. // Optional: file-based rate limits (see includes/functions.php). Defaults apply if omitted.
  16. // define('ADMIN_LOGIN_RATE_LIMIT_MAX', 10);
  17. // define('ADMIN_LOGIN_RATE_LIMIT_WINDOW', 900);
  18. // define('CHECKOUT_RATE_LIMIT_MAX', 30);
  19. // define('CHECKOUT_RATE_LIMIT_WINDOW', 3600);
  20. define('DISCLAIMER_LINES', [
  21. 'Dieses System dient der internen Bestellung persönlicher Schutzausrüstung der Stadt Freising.',
  22. 'Die Bearbeitung erfolgt durch Amt 32 - Öffentliche Sicherheit und Ordnung.',
  23. ]);
  24. // Admin settings
  25. // Runtime source of truth for admin logins is data/admins.json.
  26. // Order settings
  27. define('ORDER_PREFIX', 'FWFS');
  28. define('ORDER_RECIPIENT_EMAIL', 'psa@feuerwehr-freising.de');
  29. define('ORDER_CONFIRMATION_REQUIRED', true);
  30. define('ORDER_CONFIRMATION_EXPIRY_DAYS', 7);
  31. define('ATTACH_ORDER_PDF_TO_ADMIN_EMAIL', true);
  32. // Email settings
  33. define('ADMIN_EMAIL', 'psa@feuerwehr-freising.de'); // Fallback for admin profile email defaults
  34. define('FROM_EMAIL', 'shop@example.org');
  35. define('FROM_NAME', SITE_FULL_NAME);
  36. // Data file paths
  37. define('DATA_DIR', __DIR__ . '/data/');
  38. define('UPLOADS_DIR', DATA_DIR . 'uploads/');
  39. define('PRODUCTS_FILE', DATA_DIR . 'products.json');
  40. define('ORDERS_FILE', DATA_DIR . 'orders.json');
  41. define('ORGANIZATIONS_FILE', DATA_DIR . 'organizations.json');
  42. define('SETTINGS_FILE', DATA_DIR . 'settings.json');
  43. define('ADMINS_FILE', DATA_DIR . 'admins.json');
  44. define('CATEGORIES_FILE', DATA_DIR . 'categories.json');
  45. define('FAQ_FILE', DATA_DIR . 'faq.json');
  46. define('UPLOADS_URL', SITE_URL . '/data/uploads');
  47. // Session settings
  48. if (session_status() === PHP_SESSION_NONE) {
  49. $isHttps =
  50. (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== "off") ||
  51. (isset($_SERVER['SERVER_PORT']) &&
  52. (int) $_SERVER['SERVER_PORT'] === 443);
  53. ini_set("session.use_strict_mode", "1");
  54. ini_set("session.cookie_httponly", "1");
  55. ini_set("session.cookie_secure", $isHttps ? "1" : "0");
  56. ini_set("session.cookie_samesite", "Lax");
  57. session_start();
  58. }