tab-config-admins.twig 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  1. <div class="tab-pane fade show active" id="tab-config-admins" role="tabpanel" aria-labelledby="tab-config-admins">
  2. <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>
  24. </div>
  25. </div>
  26. {# TFA #}
  27. <legend style="margin-top:20px">
  28. {{ lang.tfa.tfa }}
  29. </legend>
  30. <hr />
  31. <div class="row">
  32. <div class="col-sm-3 col-5 text-end">{{ lang.tfa.tfa }}:</div>
  33. <div class="col-sm-9 col-7">
  34. {% include 'tfa_keys.twig' %}
  35. <br>
  36. </div>
  37. </div>
  38. <div class="row mb-3">
  39. <div class="col-sm-3 col-5 text-end">{{ lang.tfa.set_tfa }}:</div>
  40. <div class="col-sm-9 col-7">
  41. <select data-style="btn btn-sm dropdown-toggle bs-placeholder btn-secondary" data-width="fit" id="selectTFA" class="selectpicker" title="{{ lang.tfa.select }}">
  42. <option value="yubi_otp">{{ lang.tfa.yubi_otp }}</option>
  43. <option value="webauthn">{{ lang.tfa.webauthn }}</option>
  44. <option value="totp">{{ lang.tfa.totp }}</option>
  45. <option value="none">{{ lang.tfa.none }}</option>
  46. </select>
  47. </div>
  48. </div>
  49. {# FIDO2 #}
  50. <legend style="margin-top:20px">
  51. <i class="bi bi-shield-fill-check"></i>
  52. {{ lang.fido2.fido2_auth }}</legend><hr />
  53. <div class="row mb-3">
  54. <div class="col-sm-3 col-12 text-sm-end text-start mb-4">{{ lang.fido2.known_ids }}:</div>
  55. <div class="col-sm-9 col-12">
  56. <div class="table-responsive">
  57. <table class="table table-striped table-hover table-condensed" id="fido2_keys">
  58. <tr>
  59. <th>ID</th>
  60. <th style="min-width:240px;text-align: right">{{ lang.admin.action }}</th>
  61. </tr>
  62. {% include 'fido2.twig' %}
  63. </table>
  64. </div>
  65. </div>
  66. <br>
  67. </div>
  68. <div class="row">
  69. <div class="offset-sm-3 col-sm-9">
  70. <div class="btn-group nowrap mass-actions-admin">
  71. <button class="btn btn-sm btn-primary d-block d-sm-inline" id="register-fido2">{{ lang.fido2.set_fido2 }}</button>
  72. <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>
  73. <ul class="dropdown-menu">
  74. <li><a class="dropdown-item" href="#" id="register-fido2-touchid"><i class="bi bi-apple"></i> {{ lang.fido2.set_fido2_touchid }}</a></li>
  75. </ul>
  76. </div>
  77. </div>
  78. </div>
  79. <div class="row mb-3" id="status-fido2">
  80. <div class="col-sm-3 col-5 text-end">{{ lang.fido2.register_status }}:</div>
  81. <div class="col-sm-9 col-7">
  82. <div id="fido2-alerts">-</div>
  83. </div>
  84. <br>
  85. </div>
  86. <legend style="cursor:pointer;margin-top:20px" data-bs-target="#admin_api" unselectable="on" data-bs-toggle="collapse">
  87. <i style="font-size:10pt;" class="bi bi-plus-square"></i> API
  88. </legend>
  89. <hr />
  90. <div id="admin_api" class="collapse">
  91. <div class="row">
  92. <div class="col-lg-12">
  93. <p class="text-muted">{{ lang.admin.api_info|raw }}</p>
  94. </div>
  95. <div class="col-lg-12">
  96. <div class="card mb-3">
  97. <div class="card-header">
  98. <h4 class="card-title"><i class="bi bi-file-earmark-arrow-down"></i> {{ lang.admin.cors_settings }}</h4>
  99. </div>
  100. <div class="card-body">
  101. <form class="form-horizontal" autocapitalize="none" autocorrect="off" role="form" data-id="editcors" method="post">
  102. <div class="row mb-4">
  103. <label class="control-label col-sm-2 mb-4" for="allowed_origins">{{ lang.admin.allowed_origins }}</label>
  104. <div class="col-sm-9 mb-4">
  105. <textarea class="form-control textarea-code" rows="7" name="allowed_origins" id="allowed_origins">{{ cors_settings.allowed_origins }}</textarea>
  106. </div>
  107. </div>
  108. <div class="row mb-4">
  109. <label class="control-label col-sm-2" for="allowed_methods">{{ lang.admin.allowed_methods }}</label>
  110. <div class="col-sm-9">
  111. <select name="allowed_methods" id="allowed_methods" multiple class="form-control">
  112. <option value="POST"{% if "POST" in cors_settings.allowed_methods %} selected{% endif %}>POST</option>
  113. <option value="GET"{% if "GET" in cors_settings.allowed_methods %} selected{% endif %}>GET</option>
  114. <option value="DELETE"{% if "DELETE" in cors_settings.allowed_methods %} selected{% endif %}>DELETE</option>
  115. <option value="PUT"{% if "PUT" in cors_settings.allowed_methods %} selected{% endif %}>PUT</option>
  116. </select>
  117. </div>
  118. </div>
  119. <div class="row mb-4">
  120. <div class="offset-sm-2 col-sm-9 d-grid d-sm-block">
  121. <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>
  122. </div>
  123. </div>
  124. </form>
  125. </div>
  126. </div>
  127. </div>
  128. <div class="col-lg-6">
  129. <div class="card mb-3">
  130. <div class="card-header">
  131. <h4 class="card-title"><i class="bi bi-file-earmark-arrow-down"></i> {{ lang.admin.api_read_only }}</h4>
  132. </div>
  133. <div class="card-body">
  134. <form class="form-horizontal" autocapitalize="none" autocorrect="off" role="form" method="post">
  135. <div class="row mb-4">
  136. <label class="control-label col-sm-3" for="allow_from_ro">{{ lang.admin.api_allow_from }}:</label>
  137. <div class="col-sm-9">
  138. <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>
  139. </div>
  140. </div>
  141. <div class="row mb-2">
  142. <div class="offset-sm-3 col-sm-9">
  143. <label>
  144. <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 }}
  145. </label>
  146. </div>
  147. </div>
  148. <div class="row mb-4">
  149. <label class="control-label col-sm-3">{{ lang.admin.api_key }}:</label>
  150. <div class="col-sm-9">
  151. <input type="text" class="form-control" value="{{ api.ro.api_key|default('-') }}" readonly />
  152. </div>
  153. </div>
  154. <div class="row mb-2">
  155. <div class="offset-sm-3 col-sm-9">
  156. <label>
  157. <input type="checkbox" class="form-check-input" name="active" {% if api.ro.active %}checked{% endif %}> {{ lang.admin.activate_api }}
  158. </label>
  159. </div>
  160. </div>
  161. <div class="row mb-2">
  162. <div class="offset-sm-3 col-sm-9">
  163. <div class="btn-group">
  164. <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>
  165. <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>
  166. </div>
  167. </div>
  168. </div>
  169. </form>
  170. </div>
  171. </div>
  172. </div>
  173. <div class="col-lg-6">
  174. <div class="card mb-3">
  175. <div class="card-header">
  176. <h4 class="card-title"><i class="bi bi-file-earmark-diff"></i> {{ lang.admin.api_read_write }}</h4>
  177. </div>
  178. <div class="card-body">
  179. <form class="form-horizontal" autocapitalize="none" autocorrect="off" role="form" method="post">
  180. <div class="row mb-4">
  181. <label class="control-label col-sm-3" for="allow_from_rw">{{ lang.admin.api_allow_from }}:</label>
  182. <div class="col-sm-9">
  183. <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>
  184. </div>
  185. </div>
  186. <div class="row mb-2">
  187. <div class="offset-sm-3 col-sm-9">
  188. <label>
  189. <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 }}
  190. </label>
  191. </div>
  192. </div>
  193. <div class="row mb-4">
  194. <label class="control-label col-sm-3" for="admin_api_key">{{ lang.admin.api_key }}:</label>
  195. <div class="col-sm-9">
  196. <input type="text" class="form-control" value="{{ api.rw.api_key|default('-') }}" readonly />
  197. </div>
  198. </div>
  199. <div class="row mb-2">
  200. <div class="offset-sm-3 col-sm-9">
  201. <label>
  202. <input type="checkbox" class="form-check-input" name="active" {% if api.rw.active %}checked{% endif %}> {{ lang.admin.activate_api }}
  203. </label>
  204. </div>
  205. </div>
  206. <div class="row mb-2">
  207. <div class="offset-sm-3 col-sm-9">
  208. <div class="btn-group">
  209. <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>
  210. <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>
  211. </div>
  212. </div>
  213. </div>
  214. </form>
  215. </div>
  216. </div>
  217. </div>
  218. </div>
  219. </div>
  220. </div>
  221. </div>
  222. <div class="card mb-4">
  223. <div class="card-header d-flex fs-5">
  224. <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">
  225. {{ lang.admin.domain_admins }}
  226. </button>
  227. <span class="d-none d-md-block">{{ lang.admin.domain_admins }}</span>
  228. </div>
  229. <div id="collapse-tab-config-dadmins" class="card-body collapse" data-bs-parent="#admin-content">
  230. <table id="domainadminstable" class="table table-striped dt-responsive w-100"></table>
  231. <div class="mass-actions-admin">
  232. <div class="btn-group">
  233. <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>
  234. <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>
  235. <ul class="dropdown-menu">
  236. <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>
  237. <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>
  238. <li><hr class="dropdown-divider"></li>
  239. <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>
  240. <li><hr class="dropdown-divider"></li>
  241. <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>
  242. </ul>
  243. <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>
  244. </div>
  245. </div>
  246. </div>
  247. </div>
  248. </div>