| <!-- change fido2 fn --> |
| <div class="modal fade" id="fido2ChangeFn" tabindex="-1" role="dialog" aria-hidden="true"> |
| <div class="modal-dialog modal-lg"> |
| <div class="modal-content"> |
| <div class="modal-header"> |
| <h3 class="modal-title">{{ lang.fido2.set_fn }}</h3> |
| <p class="text-muted" style="word-break:break-all" id="fido2_subject_desc" data-fido2-subject=""></p> |
| <button type="button" class="btn-close" data-bs-dismiss="modal"></button> |
| </div> |
| <div class="modal-body"> |
| <form class="form-horizontal" data-cached-form="false" data-id="fido2ChangeFn" role="form" method="post" autocomplete="off"> |
| <input type="hidden" class="form-control" name="fido2_cid" id="fido2_cid"> |
| <div class="row mb-4"> |
| <label class="control-label col-sm-4 text-end" for="fido2_fn">{{ lang.fido2.fn }}:</label> |
| <div class="col-sm-8"> |
| <input type="text" class="form-control" name="fido2_fn"> |
| </div> |
| </div> |
| <div class="row"> |
| <div class="offset-sm-4 col-sm-8"> |
| <button class="btn btn-xs-lg d-block d-sm-inline btn-success" data-action="edit_selected" data-id="fido2ChangeFn" data-item="null" data-api-url='edit/fido2-fn' data-api-attr='{}' href="#">{{ lang.admin.save }}</button> |
| </div> |
| </div> |
| </form> |
| </div> |
| </div> |
| </div> |
| </div><!-- add domain admin modal --> |
| <!-- add sync job modal --> |
| <div class="modal fade" id="addSyncJobModal" tabindex="-1" role="dialog" aria-hidden="true"> |
| <div class="modal-dialog modal-xl"> |
| <div class="modal-content"> |
| <div class="modal-header"> |
| <h3 class="modal-title">{{ lang.add.syncjob }}</h3> |
| <button type="button" class="btn-close" data-bs-dismiss="modal"></button> |
| </div> |
| <div class="modal-body"> |
| <p>{{ lang.add.syncjob_hint }}</p> |
| <form class="form-horizontal" data-cached-form="true" role="form" data-id="add_syncjob"> |
| <div class="row mb-2"> |
| <label class="control-label col-sm-2" for="host1">{{ lang.add.hostname }}</label> |
| <div class="col-sm-10"> |
| <input type="text" class="form-control" name="host1" required> |
| </div> |
| </div> |
| <div class="row mb-4"> |
| <label class="control-label col-sm-2" for="port1">{{ lang.add.port }}</label> |
| <div class="col-sm-10"> |
| <input type="number" class="form-control" name="port1" min="1" max="65535" value="143" required> |
| <small class="text-muted">1-65535</small> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <label class="control-label col-sm-2" for="user1">{{ lang.add.username }}</label> |
| <div class="col-sm-10"> |
| <input type="text" class="form-control" name="user1" required> |
| </div> |
| </div> |
| <div class="row mb-4"> |
| <label class="control-label col-sm-2" for="password1">{{ lang.add.password }}</label> |
| <div class="col-sm-10"> |
| <input type="password" class="form-control" name="password1" data-hibp="true" required> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <label class="control-label col-sm-2" for="enc1">{{ lang.add.enc_method }}</label> |
| <div class="col-sm-10"> |
| <select name="enc1" title="{{ lang.add.select }}" required> |
| <option value="SSL" selected>SSL</option> |
| <option value="TLS">STARTTLS</option> |
| <option value="PLAIN">PLAIN</option> |
| </select> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <label class="control-label col-sm-2" for="mins_interval">{{ lang.add.mins_interval }}</label> |
| <div class="col-sm-10"> |
| <input type="number" class="form-control" name="mins_interval" min="1" max="43800" value="20" required> |
| <small class="text-muted">1-43800</small> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <label class="control-label col-sm-2" for="subfolder2">{{ lang.edit.subfolder2|raw }}</label> |
| <div class="col-sm-10"> |
| <input type="text" class="form-control" name="subfolder2" value=""> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <label class="control-label col-sm-2" for="maxage">{{ lang.edit.maxage|raw }}</label> |
| <div class="col-sm-10"> |
| <input type="number" class="form-control" name="maxage" min="0" max="32000" value="0"> |
| <small class="text-muted">0-32000</small> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <label class="control-label col-sm-2" for="maxbytespersecond">{{ lang.edit.maxbytespersecond|raw }}</label> |
| <div class="col-sm-10"> |
| <input type="number" class="form-control" name="maxbytespersecond" min="0" max="125000000" value="0"> |
| <small class="text-muted">0-125000000</small> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <label class="control-label col-sm-2" for="timeout1">{{ lang.edit.timeout1 }}</label> |
| <div class="col-sm-10"> |
| <input type="number" class="form-control" name="timeout1" min="1" max="32000" value="600"> |
| <small class="text-muted">1-32000</small> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <label class="control-label col-sm-2" for="timeout2">{{ lang.edit.timeout2 }}</label> |
| <div class="col-sm-10"> |
| <input type="number" class="form-control" name="timeout2" min="1" max="32000" value="600"> |
| <small class="text-muted">1-32000</small> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <label class="control-label col-sm-2" for="exclude">{{ lang.add.exclude }}</label> |
| <div class="col-sm-10"> |
| <input type="text" class="form-control" name="exclude" value="(?i)spam|(?i)junk"> |
| </div> |
| </div> |
| <div class="row mb-4"> |
| <label class="control-label col-sm-2" for="custom_params">{{ lang.add.custom_params }}</label> |
| <div class="col-sm-10"> |
| <input type="text" class="form-control" name="custom_params" placeholder="--delete2folders --otheroption"> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <div class="offset-sm-2 col-sm-10"> |
| <div class="form-check"> |
| <label><input type="checkbox" class="form-check-input" value="1" name="delete2duplicates" checked> {{ lang.add.delete2duplicates }} (--delete2duplicates)</label> |
| </div> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <div class="offset-sm-2 col-sm-10"> |
| <div class="form-check"> |
| <label><input type="checkbox" class="form-check-input" value="1" name="delete1"> {{ lang.add.delete1 }} (--delete1)</label> |
| </div> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <div class="offset-sm-2 col-sm-10"> |
| <div class="form-check"> |
| <label><input type="checkbox" class="form-check-input" value="1" name="delete2"> {{ lang.add.delete2 }} (--delete2)</label> |
| </div> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <div class="offset-sm-2 col-sm-10"> |
| <div class="form-check"> |
| <label><input type="checkbox" class="form-check-input" value="1" name="automap" checked> {{ lang.add.automap }} (--automap)</label> |
| </div> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <div class="offset-sm-2 col-sm-10"> |
| <div class="form-check"> |
| <label><input type="checkbox" class="form-check-input" value="1" name="skipcrossduplicates"> {{ lang.add.skipcrossduplicates }} (--skipcrossduplicates)</label> |
| </div> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <div class="offset-sm-2 col-sm-10"> |
| <div class="form-check"> |
| <label><input type="checkbox" class="form-check-input" value="1" name="subscribeall" checked> {{ lang.add.subscribeall }} (--subscribeall)</label> |
| </div> |
| </div> |
| </div> |
| <div class="row mb-4"> |
| <div class="offset-sm-2 col-sm-10"> |
| <div class="form-check"> |
| <label><input type="checkbox" class="form-check-input" value="1" name="active" checked> {{ lang.add.active }}</label> |
| </div> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <div class="offset-sm-2 col-sm-10"> |
| <button class="btn btn-xs-lg d-block d-sm-inline btn-success" data-action="add_item" data-id="add_syncjob" data-api-url='add/syncjob' data-api-attr='{}' href="#">{{ lang.admin.add }}</button> |
| </div> |
| </div> |
| </form> |
| </div> |
| </div> |
| </div> |
| </div><!-- add sync job modal --> |
| <!-- app passwd modal --> |
| <div class="modal fade" id="addAppPasswdModal" tabindex="-1" role="dialog" aria-hidden="true"> |
| <div class="modal-dialog modal-lg"> |
| <div class="modal-content"> |
| <div class="modal-header"> |
| <h3 class="modal-title">{{ lang.add.app_password }}</h3> |
| <button type="button" class="btn-close" data-bs-dismiss="modal"></button> |
| </div> |
| <div class="modal-body"> |
| <form class="form-horizontal" data-cached-form="true" role="form" data-pwgen-length="32" data-id="add_apppasswd"> |
| <div class="row mb-2"> |
| <label class="control-label col-sm-2" for="app_name">{{ lang.add.app_name }}</label> |
| <div class="col-sm-10"> |
| <input type="text" class="form-control" name="app_name" required> |
| </div> |
| </div> |
| <div class="row mb-4"> |
| <label class="control-label col-sm-2" for="app_passwd">{{ lang.user.password }} (<a href="#" class="generate_password">{{ lang.user.generate }}</a>)</label> |
| <div class="col-sm-10"> |
| <input type="password" data-pwgen-field="true" data-hibp="true" class="form-control" name="app_passwd" autocomplete="new-password" required> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <label class="control-label col-sm-2" for="app_passwd2">{{ lang.user.password_repeat }}</label> |
| <div class="col-sm-10"> |
| <input type="password" data-pwgen-field="true" class="form-control" name="app_passwd2" autocomplete="new-password" required> |
| <p class="text-muted">{{ lang.user.new_password_description }}</p> |
| </div> |
| </div> |
| <div class="row mb-4"> |
| <label class="control-label col-sm-2" for="protocols">{{ lang.add.app_passwd_protocols }}</label> |
| <div class="col-sm-10"> |
| <select class="full-width-select" data-live-search="true" id="protocols" name="protocols" multiple> |
| <option value="imap_access" selected>IMAP</option> |
| <option value="smtp_access" selected>SMTP</option> |
| <option value="eas_access" selected>EAS/ActiveSync</option> |
| <option value="dav_access" selected>CardDAV/CalDAV</option> |
| <option value="pop3_access" selected>POP3</option> |
| <option value="sieve_access" selected>Sieve</option> |
| </select> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <div class="offset-sm-2 col-sm-10"> |
| <div class="form-check"> |
| <label><input type="checkbox" class="form-check-input" value="1" name="active" checked> {{ lang.add.active }}</label> |
| </div> |
| </div> |
| </div> |
| <div class="row mb-2"> |
| <div class="offset-sm-2 col-sm-10"> |
| <button class="btn btn-xs-lg d-block d-sm-inline btn-success" data-action="add_item" data-id="add_apppasswd" data-api-url='add/app-passwd' data-api-attr='{}' href="#">{{ lang.admin.add }}</button> |
| </div> |
| </div> |
| </form> |
| </div> |
| </div> |
| </div> |
| </div><!-- add app passwd modal --> |
| <!-- log modal --> |
| <div class="modal fade" id="syncjobLogModal" tabindex="-1" role="dialog" aria-labelledby="syncjobLogModalLabel"> |
| <div class="modal-dialog modal-xl" role="document"> |
| <div class="modal-content"> |
| <div class="modal-header"> |
| <h3 class="modal-title">Log</h3> |
| <button type="button" class="btn-close" data-bs-dismiss="modal"></button> |
| </div> |
| <div class="modal-body"> |
| <textarea class="form-control textarea-code" rows="20" id="logText" spellcheck="false"></textarea> |
| </div> |
| </div> |
| </div> |
| </div><!-- log modal --> |
| <!-- pw change modal --> |
| <div class="modal fade" id="pwChangeModal" tabindex="-1" role="dialog" aria-labelledby="pwChangeModalLabel"> |
| <div class="modal-dialog modal-lg" role="document"> |
| <div class="modal-content"> |
| <div class="modal-header"> |
| <h3 class="modal-title">{{ lang.user.change_password }}</h3> |
| <button type="button" class="btn-close" data-bs-dismiss="modal"></button> |
| </div> |
| <div class="modal-body"> |
| <form class="form-horizontal" data-cached-form="false" data-id="pwchange" role="form" method="post" autocomplete="off"> |
| <div class="row"> |
| <label class="control-label col-sm-3" for="user_new_pass">{{ lang.user.new_password }} (<a href="#" class="generate_password">{{ lang.user.generate }}</a>)</label> |
| <div class="col-sm-9"> |
| <input type="password" data-pwgen-field="true" data-hibp="true" class="form-control" name="user_new_pass" autocomplete="new-password" required> |
| </div> |
| </div> |
| <div class="row"> |
| <label class="control-label col-sm-3" for="user_new_pass2">{{ lang.user.new_password_repeat }}</label> |
| <div class="col-sm-9"> |
| <input type="password" data-pwgen-field="true" class="form-control" name="user_new_pass2" autocomplete="new-password" required> |
| <p class="text-muted">{{ lang.user.new_password_description }}</p> |
| </div> |
| </div> |
| <hr> |
| <div class="row mb-4"> |
| <label class="control-label col-sm-3" for="user_old_pass">{{ lang.user.password_now }}</label> |
| <div class="col-sm-9"> |
| <input type="password" class="form-control" name="user_old_pass" autocomplete="off" required> |
| {% if number_of_app_passwords > 0 %} |
| <div class="invalid-feedback d-block"> |
| {{ lang.user.change_password_hint_app_passwords|format(number_of_app_passwords) }} |
| </div> |
| {% endif %} |
| </div> |
| </div> |
| <div class="row"> |
| <div class="offset-sm-3 col-sm-9"> |
| <button class="btn btn-xs-lg d-block d-sm-inline btn-success" data-action="edit_selected" data-id="pwchange" data-item="null" data-api-url='edit/self' data-api-attr='{}' href="#">{{ lang.user.change_password }}</button> |
| </div> |
| </div> |
| </form> |
| </div> |
| </div> |
| </div> |
| </div><!-- pw change modal --> |
| <!-- temp alias modal --> |
| <div class="modal fade" id="tempAliasModal" tabindex="-1" role="dialog" aria-labelledby="tempAliasModalLabel"> |
| <div class="modal-dialog modal-lg" role="document"> |
| <div class="modal-content"> |
| <div class="modal-body"> |
| <form class="form-horizontal" data-cached-form="false" data-id="pwchange" role="form" method="post" autocomplete="off"> |
| <div class="row"> |
| <label class="control-label col-sm-3" for="user_new_pass">{{ lang.user.new_password }} (<a href="#" class="generate_password">{{ lang.user.generate }}</a>)</label> |
| <div class="col-sm-5"> |
| <input type="password" data-pwgen-field="true" data-hibp="true" class="form-control" name="user_new_pass" autocomplete="new-password" required> |
| </div> |
| </div> |
| <div class="row"> |
| <label class="control-label col-sm-3" for="user_new_pass2">{{ lang.user.new_password_repeat }}</label> |
| <div class="col-sm-5"> |
| <input type="password" data-pwgen-field="true" class="form-control" name="user_new_pass2" autocomplete="new-password" required> |
| <p class="text-muted">{{ lang.user.new_password_description }}</p> |
| </div> |
| </div> |
| <hr> |
| <div class="row"> |
| <label class="control-label col-sm-3" for="user_old_pass">{{ lang.user.password_now }}</label> |
| <div class="col-sm-5"> |
| <input type="password" class="form-control" name="user_old_pass" autocomplete="off" required> |
| </div> |
| </div> |
| <div class="row"> |
| <div class="offset-sm-3 col-sm-9"> |
| <button class="btn btn-xs-lg d-block d-sm-inline btn-success" data-action="edit_selected" data-id="pwchange" data-item="null" data-api-url='edit/self' data-api-attr='{}' href="#">{{ lang.user.change_password }}</button> |
| </div> |
| </div> |
| </form> |
| </div> |
| </div> |
| </div> |
| </div><!-- temp alias modal --> |
| <!-- sieve filter modal --> |
| <div class="modal fade" id="userFilterModal" tabindex="-1" role="dialog"> |
| <div class="modal-dialog modal-lg" role="document"> |
| <div class="modal-content"> |
| <div class="modal-header"> |
| <h3 class="modal-title">{{ lang.user.active_sieve }}</h3> |
| <button type="button" class="btn-close" data-bs-dismiss="modal"></button> |
| </div> |
| <div class="modal-body"> |
| <pre id="user_sieve_filter"></pre> |
| </div> |
| </div> |
| </div> |
| </div><!-- sieve filter modal --> |