triggers.domainadmin.inc.php 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. <?php
  2. // SSO Domain Admin
  3. if (!empty($_GET['sso_token'])) {
  4. $username = domain_admin_sso('check', $_GET['sso_token']);
  5. if ($username !== false) {
  6. session_regenerate_id(true);
  7. $_SESSION['mailcow_cc_username'] = $username;
  8. $_SESSION['mailcow_cc_role'] = 'domainadmin';
  9. header('Location: /domainadmin/mailbox');
  10. }
  11. }
  12. if (isset($_POST["verify_tfa_login"])) {
  13. if (verify_tfa_login($_SESSION['pending_mailcow_cc_username'], $_POST)) {
  14. if ($_SESSION['pending_mailcow_cc_role'] == "domainadmin") {
  15. $_SESSION['mailcow_cc_username'] = $_SESSION['pending_mailcow_cc_username'];
  16. $_SESSION['mailcow_cc_role'] = "domainadmin";
  17. unset($_SESSION['pending_mailcow_cc_username']);
  18. unset($_SESSION['pending_mailcow_cc_role']);
  19. unset($_SESSION['pending_tfa_methods']);
  20. header("Location: /domainadmin/mailbox");
  21. die();
  22. }
  23. }
  24. unset($_SESSION['pending_mailcow_cc_username']);
  25. unset($_SESSION['pending_mailcow_cc_role']);
  26. unset($_SESSION['pending_tfa_methods']);
  27. }
  28. if (isset($_GET["cancel_tfa_login"])) {
  29. unset($_SESSION['pending_pw_reset_token']);
  30. unset($_SESSION['pending_pw_new_password']);
  31. unset($_SESSION['pending_mailcow_cc_username']);
  32. unset($_SESSION['pending_mailcow_cc_role']);
  33. unset($_SESSION['pending_tfa_methods']);
  34. header("Location: /domainadmin");
  35. }
  36. if (isset($_POST["login_user"]) && isset($_POST["pass_user"])) {
  37. $login_user = strtolower(trim($_POST["login_user"]));
  38. $as = check_login($login_user, $_POST["pass_user"], false, array("role" => "domain_admin"));
  39. if ($as == "domainadmin") {
  40. session_regenerate_id(true);
  41. $_SESSION['mailcow_cc_username'] = $login_user;
  42. $_SESSION['mailcow_cc_role'] = "domainadmin";
  43. header("Location: /domainadmin/mailbox");
  44. die();
  45. }
  46. elseif ($as != "pending") {
  47. unset($_SESSION['pending_mailcow_cc_username']);
  48. unset($_SESSION['pending_mailcow_cc_role']);
  49. unset($_SESSION['pending_tfa_methods']);
  50. unset($_SESSION['mailcow_cc_username']);
  51. unset($_SESSION['mailcow_cc_role']);
  52. }
  53. }
  54. ?>