sessions.inc.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. <?php
  2. // Start session
  3. ini_set("session.cookie_httponly", 1);
  4. ini_set('session.gc_maxlifetime', $SESSION_LIFETIME);
  5. if (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) &&
  6. strtolower($_SERVER['HTTP_X_FORWARDED_PROTO']) == "https") {
  7. ini_set("session.cookie_secure", 1);
  8. $IS_HTTPS = true;
  9. }
  10. elseif (isset($_SERVER['HTTPS'])) {
  11. ini_set("session.cookie_secure", 1);
  12. $IS_HTTPS = true;
  13. }
  14. else {
  15. $IS_HTTPS = false;
  16. }
  17. // session_set_cookie_params($SESSION_LIFETIME, '/', '', $IS_HTTPS, true);
  18. session_start();
  19. if (!isset($_SESSION['CSRF']['TOKEN'])) {
  20. $_SESSION['CSRF']['TOKEN'] = bin2hex(random_bytes(32));
  21. }
  22. // Set session UA
  23. if (!isset($_SESSION['SESS_REMOTE_UA'])) {
  24. $_SESSION['SESS_REMOTE_UA'] = $_SERVER['HTTP_USER_AGENT'];
  25. }
  26. // API
  27. if (!empty($_SERVER['HTTP_X_API_KEY'])) {
  28. $stmt = $pdo->prepare("SELECT `username`, `allow_from` FROM `api` WHERE `api_key` = :api_key AND `active` = '1';");
  29. $stmt->execute(array(
  30. ':api_key' => preg_replace('/[^A-Z0-9-]/', '', $_SERVER['HTTP_X_API_KEY'])
  31. ));
  32. $api_return = $stmt->fetch(PDO::FETCH_ASSOC);
  33. if (!empty($api_return['username'])) {
  34. if (in_array($_SERVER['REMOTE_ADDR'], explode(',', $api_return['allow_from']))) {
  35. $_SESSION['mailcow_cc_username'] = $api_return['username'];
  36. $_SESSION['mailcow_cc_role'] = 'admin';
  37. $_SESSION['mailcow_cc_api'] = true;
  38. }
  39. }
  40. }
  41. // Update session cookie
  42. // setcookie(session_name() ,session_id(), time() + $SESSION_LIFETIME);
  43. // Check session
  44. function session_check() {
  45. if ($_SESSION['mailcow_cc_api'] === true) {
  46. return true;
  47. }
  48. if (!isset($_SESSION['SESS_REMOTE_UA'])) {
  49. return false;
  50. }
  51. if ($_SESSION['SESS_REMOTE_UA'] != $_SERVER['HTTP_USER_AGENT']) {
  52. return false;
  53. }
  54. if (!empty($_POST)) {
  55. if ($_SESSION['CSRF']['TOKEN'] != $_POST['csrf_token']) {
  56. return false;
  57. }
  58. $_SESSION['CSRF']['TOKEN'] = bin2hex(random_bytes(32));
  59. $_SESSION['CSRF']['TIME'] = time();
  60. }
  61. return true;
  62. }
  63. if (isset($_SESSION['mailcow_cc_role']) && session_check() === false) {
  64. $_SESSION['return'] = array(
  65. 'type' => 'warning',
  66. 'msg' => 'Form token invalid or timed out'
  67. );
  68. $_POST = array();
  69. $_FILES = array();
  70. }
  71. // Handle logouts
  72. if (isset($_POST["logout"])) {
  73. if (isset($_SESSION["dual-login"])) {
  74. $_SESSION["mailcow_cc_username"] = $_SESSION["dual-login"]["username"];
  75. $_SESSION["mailcow_cc_role"] = $_SESSION["dual-login"]["role"];
  76. unset($_SESSION["dual-login"]);
  77. header("Location: /mailbox.php");
  78. exit();
  79. }
  80. else {
  81. session_regenerate_id(true);
  82. session_unset();
  83. session_destroy();
  84. session_write_close();
  85. header("Location: /");
  86. }
  87. }