prerequisites.inc.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. <?php
  2. //ini_set("session.cookie_secure", 1);
  3. //ini_set("session.cookie_httponly", 1);
  4. session_start();
  5. if (isset($_POST["logout"])) {
  6. if (isset($_SESSION["dual-login"])) {
  7. $_SESSION["mailcow_cc_username"] = $_SESSION["dual-login"]["username"];
  8. $_SESSION["mailcow_cc_role"] = $_SESSION["dual-login"]["role"];
  9. unset($_SESSION["dual-login"]);
  10. }
  11. else {
  12. session_unset();
  13. session_destroy();
  14. session_write_close();
  15. setcookie(session_name(),'',0,'/');
  16. }
  17. }
  18. require_once 'inc/vars.inc.php';
  19. if (file_exists('./inc/vars.local.inc.php')) {
  20. include_once 'inc/vars.local.inc.php';
  21. }
  22. // Yubi OTP API
  23. if (!empty($YUBI_API['ID']) && !empty($YUBI_API['KEY'])) {
  24. require_once 'inc/lib/Yubico.php';
  25. $yubi = new Auth_Yubico($YUBI_API['ID'], $YUBI_API['KEY']);
  26. }
  27. // U2F API
  28. require_once 'inc/lib/U2F.php';
  29. $scheme = isset($_SERVER['HTTPS']) ? "https://" : "http://";
  30. $u2f = new u2flib_server\U2F($scheme . $_SERVER['HTTP_HOST']);
  31. // PDO
  32. $dsn = "$database_type:host=$database_host;dbname=$database_name";
  33. $opt = [
  34. PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
  35. PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
  36. PDO::ATTR_EMULATE_PREPARES => false,
  37. ];
  38. try {
  39. $pdo = new PDO($dsn, $database_user, $database_pass, $opt);
  40. }
  41. catch (PDOException $e) {
  42. ?>
  43. <center style='font-family: "Lucida Sans Unicode", "Lucida Grande", Verdana, Arial, Helvetica, sans-serif;'>🐮 Connection failed, database may be in warm-up state, please try again later.<br /><br />The following error was reported:<br/> <?=$e->getMessage();?></center>
  44. <?php
  45. }
  46. $_SESSION['mailcow_locale'] = strtolower(trim($DEFAULT_LANG));
  47. setcookie('language', $DEFAULT_LANG);
  48. if (isset($_COOKIE['language'])) {
  49. switch ($_COOKIE['language']) {
  50. case "de":
  51. $_SESSION['mailcow_locale'] = 'de';
  52. setcookie('language', 'de');
  53. break;
  54. case "en":
  55. $_SESSION['mailcow_locale'] = 'en';
  56. setcookie('language', 'en');
  57. break;
  58. case "nl":
  59. $_SESSION['mailcow_locale'] = 'nl';
  60. setcookie('language', 'nl');
  61. break;
  62. case "pt":
  63. $_SESSION['mailcow_locale'] = 'pt';
  64. setcookie('language', 'pt');
  65. break;
  66. }
  67. }
  68. if (isset($_GET['lang'])) {
  69. switch ($_GET['lang']) {
  70. case "de":
  71. $_SESSION['mailcow_locale'] = 'de';
  72. setcookie('language', 'de');
  73. break;
  74. case "en":
  75. $_SESSION['mailcow_locale'] = 'en';
  76. setcookie('language', 'en');
  77. break;
  78. case "nl":
  79. $_SESSION['mailcow_locale'] = 'nl';
  80. setcookie('language', 'nl');
  81. break;
  82. case "pt":
  83. $_SESSION['mailcow_locale'] = 'pt';
  84. setcookie('language', 'pt');
  85. break;
  86. }
  87. }
  88. require_once 'lang/lang.en.php';
  89. include 'lang/lang.'.$_SESSION['mailcow_locale'].'.php';
  90. require_once 'inc/functions.inc.php';
  91. require_once 'inc/triggers.inc.php';
  92. (!isset($_SESSION['mailcow_cc_username'])) ? init_db_schema() : null;