blob: 44342af4d6edf0d1f4e8ac27010efd09183dde56 [file] [log] [blame]
Matthias Andreas Benkardd1f5b682023-11-18 13:18:30 +01001<div class="tab-pane fade show active" id="tab-config-admins" role="tabpanel" aria-labelledby="tab-config-admins">
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +01002 <div class="card mb-4">
3 <div class="card-header bg-danger text-white d-flex fs-5">
4 <button class="btn d-md-none text-white flex-grow-1 text-start" data-bs-target="#collapse-tab-config-admins" data-bs-toggle="collapse" aria-controls="collapse-tab-config-admins">
5 {{ lang.admin.admin_details }}
6 </button>
7 <span class="d-none d-md-block">{{ lang.admin.admin_details }}</span>
8 </div>
9 <div id="collapse-tab-config-admins" class="card-body collapse show" data-bs-parent="#admin-content">
10 <table id="adminstable" class="table table-striped dt-responsive w-100"></table>
11 <div class="mass-actions-admin mb-4">
12 <div class="btn-group">
13 <a class="btn btn-sm btn-xs-half d-block d-sm-inline btn-secondary" id="toggle_multi_select_all" data-id="admins" href="#"><i class="bi bi-check-all"></i> {{ lang.mailbox.toggle_all }}</a>
14 <a class="btn btn-sm btn-xs-half d-block d-sm-inline btn-secondary dropdown-toggle" data-bs-toggle="dropdown" href="#">{{ lang.mailbox.quick_actions }}</a>
15 <ul class="dropdown-menu">
16 <li><a class="dropdown-item" data-action="edit_selected" data-id="admins" data-api-url='edit/admin' data-api-attr='{"active":"1"}' href="#">{{ lang.mailbox.activate }}</a></li>
17 <li><a class="dropdown-item" data-action="edit_selected" data-id="admins" data-api-url='edit/admin' data-api-attr='{"active":"0"}' href="#">{{ lang.mailbox.deactivate }}</a></li>
18 <li><hr class="dropdown-divider"></li>
19 <li><a class="dropdown-item" data-action="edit_selected" data-id="admins" data-api-url='edit/admin' data-api-attr='{"disable_tfa":"1"}' href="#">{{ lang.tfa.disable_tfa }}</a></li>
20 <li><hr class="dropdown-divider"></li>
21 <li><a class="dropdown-item" data-action="delete_selected" data-id="admins" data-api-url='delete/admin' href="#">{{ lang.mailbox.remove }}</a></li>
22 </ul>
23 <a class="btn btn-sm d-block d-sm-inline btn-success" data-id="add_admin" data-bs-toggle="modal" data-bs-target="#addAdminModal" href="#"><i class="bi bi-person-plus-fill"></i> {{ lang.admin.add_admin }}</a>
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +010024 </div>
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +010025 </div>
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +010026
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +010027 {# TFA #}
28 <legend style="margin-top:20px">
29 {{ lang.tfa.tfa }}
30 </legend>
31 <hr />
32 <div class="row">
33 <div class="col-sm-3 col-5 text-end">{{ lang.tfa.tfa }}:</div>
34 <div class="col-sm-9 col-7">
35 {% include 'tfa_keys.twig' %}
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +010036 <br>
37 </div>
38 </div>
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +010039 <div class="row mb-3">
40 <div class="col-sm-3 col-5 text-end">{{ lang.tfa.set_tfa }}:</div>
41 <div class="col-sm-9 col-7">
42 <select data-style="btn btn-sm dropdown-toggle bs-placeholder btn-secondary" data-width="fit" id="selectTFA" class="selectpicker" title="{{ lang.tfa.select }}">
43 <option value="yubi_otp">{{ lang.tfa.yubi_otp }}</option>
44 <option value="webauthn">{{ lang.tfa.webauthn }}</option>
45 <option value="totp">{{ lang.tfa.totp }}</option>
46 <option value="none">{{ lang.tfa.none }}</option>
47 </select>
48 </div>
49 </div>
50
51 {# FIDO2 #}
52 <legend style="margin-top:20px">
53 <i class="bi bi-shield-fill-check"></i>
54 {{ lang.fido2.fido2_auth }}</legend><hr />
55 <div class="row mb-3">
56 <div class="col-sm-3 col-12 text-sm-end text-start mb-4">{{ lang.fido2.known_ids }}:</div>
57 <div class="col-sm-9 col-12">
58 <div class="table-responsive">
59 <table class="table table-striped table-hover table-condensed" id="fido2_keys">
60 <tr>
61 <th>ID</th>
62 <th style="min-width:240px;text-align: right">{{ lang.admin.action }}</th>
63 </tr>
64 {% include 'fido2.twig' %}
65 </table>
66 </div>
67 </div>
68 <br>
69 </div>
70
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +010071 <div class="row">
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +010072 <div class="offset-sm-3 col-sm-9">
73 <div class="btn-group nowrap mass-actions-admin">
74 <button class="btn btn-sm btn-primary d-block d-sm-inline" id="register-fido2">{{ lang.fido2.set_fido2 }}</button>
75 <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>
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +010076 <ul class="dropdown-menu">
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +010077 <li><a class="dropdown-item" href="#" id="register-fido2-touchid"><i class="bi bi-apple"></i> {{ lang.fido2.set_fido2_touchid }}</a></li>
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +010078 </ul>
79 </div>
80 </div>
81 </div>
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +010082
83 <div class="row mb-3" id="status-fido2">
84 <div class="col-sm-3 col-5 text-end">{{ lang.fido2.register_status }}:</div>
85 <div class="col-sm-9 col-7">
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +010086 <div id="fido2-alerts">-</div>
87 </div>
88 <br>
89 </div>
90
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +010091 <legend style="cursor:pointer;margin-top:20px" data-bs-target="#admin_api" unselectable="on" data-bs-toggle="collapse">
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +010092 <i style="font-size:10pt;" class="bi bi-plus-square"></i> API
93 </legend>
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +010094 <hr />
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +010095 <div id="admin_api" class="collapse">
96 <div class="row">
97 <div class="col-lg-12">
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +010098 <p class="text-muted">{{ lang.admin.api_info|raw }}</p>
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +010099 </div>
Matthias Andreas Benkardd1f5b682023-11-18 13:18:30 +0100100 <div class="col-lg-12">
101 <div class="card mb-3">
102 <div class="card-header">
103 <h4 class="card-title"><i class="bi bi-file-earmark-arrow-down"></i> {{ lang.admin.cors_settings }}</h4>
104 </div>
105 <div class="card-body">
106 <form class="form-horizontal" autocapitalize="none" autocorrect="off" role="form" data-id="editcors" method="post">
107 <div class="row mb-4">
108 <label class="control-label col-sm-2 mb-4" for="allowed_origins">{{ lang.admin.allowed_origins }}</label>
109 <div class="col-sm-9 mb-4">
110 <textarea class="form-control textarea-code" rows="7" name="allowed_origins" id="allowed_origins">{{ cors_settings.allowed_origins }}</textarea>
111 </div>
112 </div>
113 <div class="row mb-4">
114 <label class="control-label col-sm-2" for="allowed_methods">{{ lang.admin.allowed_methods }}</label>
115 <div class="col-sm-9">
116 <select name="allowed_methods" id="allowed_methods" multiple class="form-control">
117 <option value="POST"{% if "POST" in cors_settings.allowed_methods %} selected{% endif %}>POST</option>
118 <option value="GET"{% if "GET" in cors_settings.allowed_methods %} selected{% endif %}>GET</option>
119 <option value="DELETE"{% if "DELETE" in cors_settings.allowed_methods %} selected{% endif %}>DELETE</option>
120 <option value="PUT"{% if "PUT" in cors_settings.allowed_methods %} selected{% endif %}>PUT</option>
121 </select>
122 </div>
123 </div>
124 <div class="row mb-4">
125 <div class="offset-sm-2 col-sm-9 d-grid d-sm-block">
126 <button class="btn btn-sm btn-xs-lg btn-success" data-item="cors" data-api-url="edit/cors" data-id="editcors" data-action="edit_selected" href="#"><i class="bi bi-check-lg"></i> {{ lang.admin.save }}</button>
127 </div>
128 </div>
129 </form>
130 </div>
131 </div>
132 </div>
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100133 <div class="col-lg-6">
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100134 <div class="card mb-3">
135 <div class="card-header">
136 <h4 class="card-title"><i class="bi bi-file-earmark-arrow-down"></i> {{ lang.admin.api_read_only }}</h4>
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100137 </div>
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100138 <div class="card-body">
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100139 <form class="form-horizontal" autocapitalize="none" autocorrect="off" role="form" method="post">
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100140 <div class="row mb-4">
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100141 <label class="control-label col-sm-3" for="allow_from_ro">{{ lang.admin.api_allow_from }}:</label>
142 <div class="col-sm-9">
143 <textarea class="form-control textarea-code" rows="7" name="allow_from" id="allow_from_ro" {% if api.ro.skip_ip_check %}disabled{% endif %} required>{{ api.ro.allow_from }}</textarea>
144 </div>
145 </div>
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100146 <div class="row mb-2">
147 <div class="offset-sm-3 col-sm-9">
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100148 <label>
Matthias Andreas Benkardd1f5b682023-11-18 13:18:30 +0100149 <input type="checkbox" class="form-check-input" name="skip_ip_check" id="skip_ip_check_ro" {% if api.ro.skip_ip_check %}checked{% endif %}> {{ lang.admin.api_skip_ip_check }}
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100150 </label>
151 </div>
152 </div>
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100153 <div class="row mb-4">
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100154 <label class="control-label col-sm-3">{{ lang.admin.api_key }}:</label>
155 <div class="col-sm-9">
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100156 <input type="text" class="form-control" value="{{ api.ro.api_key|default('-') }}" readonly />
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100157 </div>
158 </div>
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100159 <div class="row mb-2">
160 <div class="offset-sm-3 col-sm-9">
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100161 <label>
Matthias Andreas Benkardd1f5b682023-11-18 13:18:30 +0100162 <input type="checkbox" class="form-check-input" name="active" {% if api.ro.active %}checked{% endif %}> {{ lang.admin.activate_api }}
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100163 </label>
164 </div>
165 </div>
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100166 <div class="row mb-2">
167 <div class="offset-sm-3 col-sm-9">
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100168 <div class="btn-group">
Matthias Andreas Benkardd1f5b682023-11-18 13:18:30 +0100169 <button class="btn btn-sm btn-xs-lg btn-xs-half d-block d-sm-inline btn-success" name="admin_api[ro]" type="submit" href="#"><i class="bi bi-check-lg"></i> {{ lang.admin.save }}</button>
170 <button class="btn btn-sm btn-xs-lg btn-xs-half d-block d-sm-inline btn-secondary admin-ays-dialog" name="admin_api_regen_key[ro]" type="submit" href="#" {% if not api.ro.api_key %}disabled{% endif %}>{{ lang.admin.regen_api_key }}</button>
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100171 </div>
172 </div>
173 </div>
174 </form>
175 </div>
176 </div>
177 </div>
178 <div class="col-lg-6">
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100179 <div class="card mb-3">
180 <div class="card-header">
181 <h4 class="card-title"><i class="bi bi-file-earmark-diff"></i> {{ lang.admin.api_read_write }}</h4>
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100182 </div>
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100183 <div class="card-body">
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100184 <form class="form-horizontal" autocapitalize="none" autocorrect="off" role="form" method="post">
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100185 <div class="row mb-4">
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100186 <label class="control-label col-sm-3" for="allow_from_rw">{{ lang.admin.api_allow_from }}:</label>
187 <div class="col-sm-9">
188 <textarea class="form-control textarea-code" rows="7" name="allow_from" id="allow_from_rw" {% if api.rw.skip_ip_check %}disabled{% endif %} required>{{ api.rw.allow_from }}</textarea>
189 </div>
190 </div>
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100191 <div class="row mb-2">
192 <div class="offset-sm-3 col-sm-9">
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100193 <label>
Matthias Andreas Benkardd1f5b682023-11-18 13:18:30 +0100194 <input type="checkbox" class="form-check-input" name="skip_ip_check" id="skip_ip_check_rw" {% if api.rw.skip_ip_check %}checked{% endif %}> {{ lang.admin.api_skip_ip_check }}
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100195 </label>
196 </div>
197 </div>
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100198 <div class="row mb-4">
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100199 <label class="control-label col-sm-3" for="admin_api_key">{{ lang.admin.api_key }}:</label>
200 <div class="col-sm-9">
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100201 <input type="text" class="form-control" value="{{ api.rw.api_key|default('-') }}" readonly />
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100202 </div>
203 </div>
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100204 <div class="row mb-2">
205 <div class="offset-sm-3 col-sm-9">
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100206 <label>
Matthias Andreas Benkardd1f5b682023-11-18 13:18:30 +0100207 <input type="checkbox" class="form-check-input" name="active" {% if api.rw.active %}checked{% endif %}> {{ lang.admin.activate_api }}
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100208 </label>
209 </div>
210 </div>
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100211 <div class="row mb-2">
212 <div class="offset-sm-3 col-sm-9">
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100213 <div class="btn-group">
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100214 <button class="btn btn-sm btn-xs-half d-block d-sm-inline btn-success" name="admin_api[rw]" type="submit" href="#"><i class="bi bi-check-lg"></i> {{ lang.admin.save }}</button>
215 <button class="btn btn-sm btn-xs-half d-block d-sm-inline btn-secondary admin-ays-dialog" name="admin_api_regen_key[rw]" type="submit" {% if not api.rw.api_key %}disabled{% endif %} href="#">{{ lang.admin.regen_api_key }}</button>
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100216 </div>
217 </div>
218 </div>
219 </form>
220 </div>
221 </div>
222 </div>
223 </div>
224 </div>
225 </div>
226 </div>
227
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100228 <div class="card mb-4">
229 <div class="card-header d-flex fs-5">
Matthias Andreas Benkardd1f5b682023-11-18 13:18:30 +0100230 <button class="btn d-md-none flex-grow-1 text-start" data-bs-target="#collapse-tab-config-dadmins" data-bs-toggle="collapse" aria-controls="collapse-tab-config-dadmins">
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100231 {{ lang.admin.domain_admins }}
232 </button>
233 <span class="d-none d-md-block">{{ lang.admin.domain_admins }}</span>
234 </div>
235 <div id="collapse-tab-config-dadmins" class="card-body collapse" data-bs-parent="#admin-content">
236 <table id="domainadminstable" class="table table-striped dt-responsive w-100"></table>
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100237 <div class="mass-actions-admin">
238 <div class="btn-group">
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100239 <a class="btn btn-sm btn-xs-half d-block d-sm-inline btn-secondary" id="toggle_multi_select_all" data-id="domain_admins" href="#"><i class="bi bi-check-all"></i> {{ lang.mailbox.toggle_all }}</a>
240 <a class="btn btn-sm btn-xs-half d-block d-sm-inline btn-secondary dropdown-toggle" data-bs-toggle="dropdown" href="#">{{ lang.mailbox.quick_actions }}</a>
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100241 <ul class="dropdown-menu">
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100242 <li><a class="dropdown-item" data-action="edit_selected" data-id="domain_admins" data-api-url='edit/domain-admin' data-api-attr='{"active":"1"}' href="#">{{ lang.mailbox.activate }}</a></li>
243 <li><a class="dropdown-item" data-action="edit_selected" data-id="domain_admins" data-api-url='edit/domain-admin' data-api-attr='{"active":"0"}' href="#">{{ lang.mailbox.deactivate }}</a></li>
244 <li><hr class="dropdown-divider"></li>
245 <li><a class="dropdown-item" data-action="edit_selected" data-id="domain_admins" data-api-url='edit/domain-admin' data-api-attr='{"disable_tfa":"1"}' href="#">{{ lang.tfa.disable_tfa }}</a></li>
246 <li><hr class="dropdown-divider"></li>
247 <li><a class="dropdown-item" data-action="delete_selected" data-id="domain_admins" data-api-url='delete/domain-admin' href="#">{{ lang.mailbox.remove }}</a></li>
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100248 </ul>
Matthias Andreas Benkard1ba53812022-12-27 17:32:58 +0100249 <a class="btn btn-sm d-block d-sm-inline btn-success" data-id="add_domain_admin" data-bs-toggle="modal" data-bs-target="#addDomainAdminModal" href="#"><i class="bi bi-person-plus-fill"></i> {{ lang.admin.add_domain_admin }}</a>
Matthias Andreas Benkard12a57352021-12-28 18:02:04 +0100250 </div>
251 </div>
252 </div>
253 </div>
254</div>