| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184 | <?phpif (isset($_SESSION['mailcow_cc_role']) && ($_SESSION['mailcow_cc_role'] == "admin" || $_SESSION['mailcow_cc_role'] == "domainadmin")):?><div class="modal fade" id="YubiOTPModal" tabindex="-1" role="dialog" aria-labelledby="YubiOTPModalLabel">  <div class="modal-dialog" role="document">    <div class="modal-content">      <div class="modal-header"><b><?=$lang['tfa']['yubi_otp'];?></b></div>      <div class="modal-body">      <form role="form" method="post">        <div class="form-group">          <input type="text" class="form-control" name="key_id" id="key_id" placeholder="<?=$lang['tfa']['key_id'];?>" autocomplete="off" required>        </div>        <hr>        <p class="help-block"><?=$lang['tfa']['api_register'];?></p>        <div class="form-group">          <input type="text" class="form-control" name="yubico_id" id="yubico_id" placeholder="Yubico API ID" autocomplete="off" required>        </div>        <div class="form-group">          <input type="text" class="form-control" name="yubico_key" id="yubico_key" placeholder="Yubico API Key" autocomplete="off" required>        </div>        <hr>        <div class="form-group">          <input type="password" class="form-control" name="confirm_password" id="confirm_password" placeholder="<?=$lang['user']['password_now'];?>" autocomplete="off" required>        </div>        <div class="form-group">          <div class="input-group">            <span class="input-group-addon" id="yubi-addon"><img alt="Yubicon Icon" src="/img/yubi.ico"></span>            <input type="text" name="otp_token" class="form-control" placeholder="Touch Yubikey" aria-describedby="yubi-addon">            <input type="hidden" name="tfa_method" value="yubi_otp">          </div>        </div>        <button class="btn btn-sm btn-default" type="submit" name="set_tfa"><?=$lang['user']['save_changes'];?></button>      </form>      </div>    </div>  </div></div><div class="modal fade" id="U2FModal" tabindex="-1" role="dialog" aria-labelledby="U2FModalLabel">  <div class="modal-dialog" role="document">    <div class="modal-content">      <div class="modal-header"><b><?=$lang['tfa']['u2f'];?></b></div>      <div class="modal-body">        <form role="form" method="post" id="u2f_reg_form">          <div class="form-group">            <input type="text" class="form-control" name="key_id" id="key_id" placeholder="<?=$lang['tfa']['key_id'];?>" autocomplete="off" required>          </div>          <div class="form-group">            <input type="password" class="form-control" name="confirm_password" id="confirm_password" placeholder="<?=$lang['user']['password_now'];?>" autocomplete="off" required>          </div>          <hr>          <p><?=$lang['tfa']['waiting_usb_register'];?></p>          <div class="alert alert-danger" style="display:none" id="u2f_return_code"></div>          <input type="hidden" name="token" id="u2f_register_data"/>          <input type="hidden" name="tfa_method" value="u2f">          <input type="hidden" name="set_tfa"/><br/>        </form>      </div>    </div>  </div></div><div class="modal fade" id="TOTPModal" tabindex="-1" role="dialog" aria-labelledby="TOTPModalLabel">  <div class="modal-dialog" role="document">    <div class="modal-content">      <div class="modal-header"><b><?=$lang['tfa']['totp'];?></b></div>      <div class="modal-body">        <form role="form" method="post">          <div class="form-group">            <input type="text" class="form-control" name="key_id" id="key_id" placeholder="<?=$lang['tfa']['key_id_totp'];?>" autocomplete="off" required>          </div>          <div class="form-group">            <input type="password" class="form-control" name="confirm_password" id="confirm_password" placeholder="<?=$lang['user']['password_now'];?>" autocomplete="off" required>          </div>          <hr>          <?php          $totp_secret = $tfa->createSecret();          ?>          <input type="hidden" value="<?=$totp_secret;?>" name="totp_secret" id="totp_secret"/>          <input type="hidden" name="tfa_method" value="totp">          <ol>            <li>              <p><?=$lang['tfa']['scan_qr_code'];?></p>              <img src="<?=$tfa->getQRCodeImageAsDataUri($_SESSION['mailcow_cc_username'], $totp_secret);?>">              <p class="help-block"><?=$lang['tfa']['enter_qr_code'];?>:<br />              <code><?=$totp_secret;?></code>              </p>            </li>            <li>              <p><?=$lang['tfa']['confirm_totp_token'];?>:</p>              <p><input type="number" style="width:33%" class="form-control" name="totp_confirm_token" id="totp_confirm_token" autocomplete="off" required></p>              <p><button class="btn btn-default" type="submit" name="set_tfa"><?=$lang['tfa']['confirm'];?></button></p>            </li>          </ol>        </form>      </div>    </div>  </div></div><div class="modal fade" id="DisableTFAModal" tabindex="-1" role="dialog" aria-labelledby="DisableTFAModalLabel">  <div class="modal-dialog" role="document">    <div class="modal-content">      <div class="modal-header"><b><?=$lang['tfa']['delete_tfa'];?></b></div>      <div class="modal-body">        <form role="form" method="post">          <div class="input-group">            <input type="password" class="form-control" name="confirm_password" id="confirm_password" placeholder="<?=$lang['user']['password_now'];?>" autocomplete="off" required>            <span class="input-group-btn">              <input type="hidden" name="tfa_method" value="none">              <button class="btn btn-danger" type="submit" name="set_tfa"><?=$lang['tfa']['delete_tfa'];?></button>            </span>          </div>        </form>      </div>    </div>  </div></div><?phpendif;if (isset($_SESSION['pending_tfa_method'])):  $tfa_method = $_SESSION['pending_tfa_method'];?><div class="modal fade" id="ConfirmTFAModal" tabindex="-1" role="dialog" aria-labelledby="ConfirmTFAModalLabel">  <div class="modal-dialog" role="document">    <div class="modal-content">      <div class="modal-header"><button type="button" class="close" data-dismiss="modal">×</button><b><?=$lang['tfa'][$tfa_method];?></b></div>      <div class="modal-body">      <?php      switch ($tfa_method) {        case "yubi_otp":      ?>        <form role="form" method="post">          <div class="form-group">            <div class="input-group">              <span class="input-group-addon" id="yubi-addon"><img alt="Yubicon Icon" src="/img/yubi.ico"></span>              <input type="text" name="token" id="token" class="form-control" autocomplete="off" placeholder="Touch Yubikey" aria-describedby="yubi-addon">              <input type="hidden" name="tfa_method" value="yubi_otp">            </div>          </div>          <button class="btn btn-sm btn-default" type="submit" name="verify_tfa_login"><?=$lang['login']['login'];?></button>        </form>      <?php        break;        case "u2f":      ?>        <form role="form" method="post" id="u2f_auth_form">          <p><?=$lang['tfa']['waiting_usb_auth'];?></p>          <div class="alert alert-danger" style="display:none" id="u2f_return_code"></div>          <input type="hidden" name="token" id="u2f_auth_data"/>          <input type="hidden" name="tfa_method" value="u2f">          <input type="hidden" name="verify_tfa_login"/><br/>        </form>      <?php        break;        case "totp":      ?>        <form role="form" method="post">          <div class="form-group">            <div class="input-group">              <span class="input-group-addon" id="tfa-addon"><span class="glyphicon glyphicon-lock" aria-hidden="true"></span></span>              <input type="number" min="000000" max="999999" name="token" id="token" class="form-control" placeholder="123456" aria-describedby="tfa-addon">              <input type="hidden" name="tfa_method" value="totp">            </div>          </div>          <button class="btn btn-sm btn-default" type="submit" name="verify_tfa_login"><?=$lang['login']['login'];?></button>        </form>        <?php        break;        case "hotp":      ?>       <div class="empty"></div>      <?php        break;      }      ?>      </div>    </div>  </div></div><?phpendif;?>
 |