triggers.domainadmin.inc.php 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  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($_POST["verify_fido2_login"])) {
  29. fido2(array(
  30. "action" => "verify",
  31. "token" => $_POST["token"],
  32. "user" => "domainadmin"
  33. ));
  34. exit;
  35. }
  36. if (isset($_GET["cancel_tfa_login"])) {
  37. unset($_SESSION['pending_pw_reset_token']);
  38. unset($_SESSION['pending_pw_new_password']);
  39. unset($_SESSION['pending_mailcow_cc_username']);
  40. unset($_SESSION['pending_mailcow_cc_role']);
  41. unset($_SESSION['pending_tfa_methods']);
  42. header("Location: /domainadmin");
  43. }
  44. if (isset($_POST["login_user"]) && isset($_POST["pass_user"])) {
  45. $login_user = strtolower(trim($_POST["login_user"]));
  46. $as = check_login($login_user, $_POST["pass_user"], false, array("role" => "domain_admin"));
  47. if ($as == "domainadmin") {
  48. session_regenerate_id(true);
  49. $_SESSION['mailcow_cc_username'] = $login_user;
  50. $_SESSION['mailcow_cc_role'] = "domainadmin";
  51. header("Location: /domainadmin/mailbox");
  52. die();
  53. }
  54. elseif ($as != "pending") {
  55. unset($_SESSION['pending_mailcow_cc_username']);
  56. unset($_SESSION['pending_mailcow_cc_role']);
  57. unset($_SESSION['pending_tfa_methods']);
  58. unset($_SESSION['mailcow_cc_username']);
  59. unset($_SESSION['mailcow_cc_role']);
  60. }
  61. }
  62. ?>