<div role="tabpanel" class="tab-pane fade in active show" id="tab-user-auth" role="tabpanel" aria-labelledby="tab-user-auth"> <div class="card mb-4"> <div class="card-header d-flex fs-5"> <button class="btn d-md-none flex-grow-1 text-start" data-bs-target="#collapse-tab-user-auth" data-bs-toggle="collapse" aria-controls="collapse-tab-user-auth"> {{ lang.user.mailbox_general }} </button> <span class="d-none d-md-block">{{ lang.user.mailbox_general }} </div> <div id="collapse-tab-user-auth" class="card-body collapse" data-bs-parent="#user-content"> {% if mailboxdata.attributes.force_pw_update == '1' %} <div class="alert alert-danger">{{ lang.user.force_pw_update|raw }}</div> {% endif %} {% if not skip_sogo %} <div class="row"> <div class="hidden-xs col-md-3 col-xs-5 text-right"></div> <div class="col-md-3 col-xs-12"> {% if dual_login and allow_admin_email_login == 'n' or mailboxdata.attributes.force_pw_update == '1' %} <button disabled class="btn btn-secondary btn-block btn-xs-lg"> <i class="bi bi-inbox-fill"></i> {{ lang.user.open_webmail_sso }} </button> {% else %} <a target="_blank" href="/sogo-auth.php?login={{ mailcow_cc_username }}" role="button" class="btn btn-secondary btn-block btn-xs-lg"> <i class="bi bi-inbox-fill"></i> {{ lang.user.open_webmail_sso }} </a> {% endif %} </div> </div> <hr> <div class="row"> <div class="d-none d-sm-flex col-md-3 col-5 text-end"></div> <div class="col-md-9 col-12"> <p class="text-muted text-muted-mt-0">{{ lang.user.direct_protocol_access|raw }}</p> {% if mailboxdata.attributes.imap_access == 1 %}<div class="badge fs-6 bg-success mb-2">IMAP <i class="bi bi-check-lg"></i></div>{% else %}<div class="badge fs-6 bg-danger">IMAP <i class="bi bi-x-lg"></i></div>{% endif %} {% if mailboxdata.attributes.smtp_access == 1 %}<div class="badge fs-6 bg-success mb-2">SMTP <i class="bi bi-check-lg"></i></div>{% else %}<div class="badge fs-6 bg-danger">SMTP <i class="bi bi-x-lg"></i></div>{% endif %} {% if mailboxdata.attributes.sieve_access == 1 %}<div class="badge fs-6 bg-success mb-2">Sieve <i class="bi bi-check-lg"></i></div>{% else %}<div class="badge fs-6 bg-danger">Sieve <i class="bi bi-x-lg"></i></div>{% endif %} {% if mailboxdata.attributes.pop3_access == 1 %}<div class="badge fs-6 bg-success mb-2">POP3 <i class="bi bi-check-lg"></i></div>{% else %}<div class="badge fs-6 bg-danger">POP3 <i class="bi bi-x-lg"></i></div>{% endif %} {% if mailboxdata.attributes.sogo_access == 1 %}<div class="badge fs-6 bg-success mb-2">SOGo <i class="bi bi-check-lg"></i></div>{% else %}<div class="badge fs-6 bg-danger">SOGo <i class="bi bi-x-lg"></i></div>{% endif %} </div> </div> <hr> {% endif %} <div class="row"> <div class="col-md-3 col-12 text-sm-end text-start mb-4">{{ lang.user.in_use }}:</div> <div class="col-md-5 col-12"> <div class="progress"> <div class="progress-bar bg-{{ mailboxdata.percent_class }}" role="progressbar" aria-valuenow="{{ mailboxdata.percent_in_use }}" aria-valuemin="0" aria-valuemax="100" style="min-width:2em;width: {{ mailboxdata.percent_in_use }}%;"> {{ mailboxdata.percent_in_use }}% </div> </div> <p>{{ mailboxdata.quota_used|formatBytes(2) }} / {% if mailboxdata.quota == 0 %}∞{% else %}{{ mailboxdata.quota|formatBytes(2) }}{% endif %}<br>{{ mailboxdata.messages }} {{ lang.user.messages }}</p> <hr> <p><a href="#pwChangeModal" data-bs-toggle="modal"><i class="bi bi-pencil-fill"></i> {{ lang.user.change_password }}</a></p> </div> </div> <hr> {# TFA #} <div class="row"> <div class="col-sm-3 col-xs-5 text-right">{{ lang.tfa.tfa }}:</div> <div class="col-sm-9 col-xs-7"> <p id="tfa_pretty">{{ tfa_data.pretty }}</p> {% include 'tfa_keys.twig' %} <br> </div> </div> <div class="row"> <div class="col-sm-3 col-xs-5 text-right">{{ lang.tfa.set_tfa }}:</div> <div class="col-sm-9 col-xs-7"> <select data-style="btn btn-sm dropdown-toggle bs-placeholder btn-secondary" data-width="fit" id="selectTFA" class="selectpicker" title="{{ lang.tfa.select }}"> <option value="yubi_otp">{{ lang.tfa.yubi_otp }}</option> <option value="webauthn">{{ lang.tfa.webauthn }}</option> <option value="totp">{{ lang.tfa.totp }}</option> <option value="none">{{ lang.tfa.none }}</option> </select> </div> </div> <hr> {# FIDO2 #} <div class="row"> <div class="col-sm-3 col-12 text-sm-end text-start"> <p><i class="bi bi-shield-fill-check"></i> {{ lang.fido2.fido2_auth }}</p> </div> </div> <div class="row"> <div class="col-sm-3 col-12 text-sm-end text-start mb-4"> {{ lang.fido2.known_ids }}: </div> <div class="col-sm-9 col-12"> <div class="table-responsive"> <table class="table table-striped table-hover table-condensed" id="fido2_keys"> <tr> <th>ID</th> <th style="min-width:240px;text-align: right">{{ lang.admin.action }}</th> </tr> {% include 'fido2.twig' %} </table> </div> <br> </div> </div> <div class="row"> <div class="offset-sm-3 col-sm-9"> <div class="btn-group nowrap"> <button class="btn btn-sm btn-primary d-block d-sm-inline" id="register-fido2">{{ lang.fido2.set_fido2 }}</button> <button type="button" class="btn btn-sm btn-xs-lg btn-primary dropdown-toggle" data-bs-toggle="dropdown" aria-haspopup="true" aria-expanded="false"></button> <ul class="dropdown-menu"> <li><a class="dropdown-item" href="#" id="register-fido2-touchid"><i class="bi bi-apple"></i> {{ lang.fido2.set_fido2_touchid }}</a></li> </ul> </div> </div> </div> <br> <div class="row" id="status-fido2"> <div class="col-sm-3 col-5 text-end">{{ lang.fido2.register_status }}:</div> <div class="col-sm-9 col-7"> <div id="fido2-alerts">-</div> </div> <br> </div> <hr> <div class="row"> <div class="col-md-3 col-12 text-sm-end text-start mb-4"><i class="bi bi-file-earmark-text"></i> {{ lang.user.apple_connection_profile }}:</div> <div class="col-md-9 col-12"> <p><i class="bi bi-file-earmark-post"></i> <a href="/mobileconfig.php?only_email">{{ lang.user.email }}</a> <small>IMAP, SMTP</small></p> <p class="text-muted">{{ lang.user.apple_connection_profile_mailonly }}</p> {% if not skip_sogo %} <p><i class="bi bi-file-earmark-post"></i> <a href="/mobileconfig.php">{{ lang.user.email_and_dav }}</a> <small>IMAP, SMTP, Cal/CardDAV</small></p> <p class="text-muted">{{ lang.user.apple_connection_profile_complete }}</p> {% endif %} </div> </div> <div class="row"> <div class="col-md-3 col-12 text-sm-end text-start mb-4"><i class="bi bi-file-earmark-text"></i> {{ lang.user.apple_connection_profile }}<br />{{ lang.user.with_app_password }}:</div> <div class="col-md-9 col-12"> <p><i class="bi bi-file-earmark-post"></i> <a href="/mobileconfig.php?only_email&app_password">{{ lang.user.email }}</a> <small>IMAP, SMTP</small></p> <p class="text-muted">{{ lang.user.apple_connection_profile_mailonly }} {{ lang.user.apple_connection_profile_with_app_password }}</p> {% if not skip_sogo %} <p><i class="bi bi-file-earmark-post"></i> <a href="/mobileconfig.php?app_password">{{ lang.user.email_and_dav }}</a> <small>IMAP, SMTP, Cal/CardDAV</small></p> <p class="text-muted">{{ lang.user.apple_connection_profile_complete }} {{ lang.user.apple_connection_profile_with_app_password }}</p> {% endif %} </div> </div> <hr> <div class="row"> <div class="offset-sm-3 col-sm-9"> <p><a target="_blank" href="https://mailcow.github.io/mailcow-dockerized-docs/client/client/#{{ clientconfigstr }}">[{{ lang.user.client_configuration }}]</a></p> <p><a href="#userFilterModal" data-bs-toggle="modal">[{{ lang.user.show_sieve_filters }}]</a></p> <hr> <h4 class="recent-login-success">{{ lang.user.recent_successful_connections }}</h4> <div class="dropdown mt-2"> <button class="btn btn-secondary btn-xs btn-xs-lg dropdown-toggle" type="button" id="history_sasl_days" data-bs-toggle="dropdown">{{ lang.user.login_history }}</button> <ul class="dropdown-menu"> <li class="login-history" data-days="1"><a class="dropdown-item" href="#">1 {{ lang.user.day }}</a></li> <li class="login-history" data-days="7"><a class="dropdown-item active" href="#">1 {{ lang.user.week }}</a></li> <li class="login-history" data-days="14"><a class="dropdown-item" href="#">2 {{ lang.user.weeks }}</a></li> <li class="login-history" data-days="31"><a class="dropdown-item" href="#">1 {{ lang.user.month }}</a></li> </ul> </div> <div class="last-login mt-4"></div> <span class="clear-last-logins mt-2"> {{ lang.user.clear_recent_successful_connections }} </span> </div> </div> </div> </div> </div>