tab-config-admins.twig 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  1. <div role="tabpanel" 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">
  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. <p id="tfa_pretty">{{ tfa_data.pretty }}</p>
  35. {% include 'tfa_keys.twig' %}
  36. <br>
  37. </div>
  38. </div>
  39. <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. {# FIDO2 #}
  51. <legend style="margin-top:20px">
  52. <i class="bi bi-shield-fill-check"></i>
  53. {{ lang.fido2.fido2_auth }}</legend><hr />
  54. <div class="row mb-3">
  55. <div class="col-sm-3 col-12 text-sm-end text-start mb-4">{{ lang.fido2.known_ids }}:</div>
  56. <div class="col-sm-9 col-12">
  57. <div class="table-responsive">
  58. <table class="table table-striped table-hover table-condensed" id="fido2_keys">
  59. <tr>
  60. <th>ID</th>
  61. <th style="min-width:240px;text-align: right">{{ lang.admin.action }}</th>
  62. </tr>
  63. {% include 'fido2.twig' %}
  64. </table>
  65. </div>
  66. </div>
  67. <br>
  68. </div>
  69. <div class="row">
  70. <div class="offset-sm-3 col-sm-9">
  71. <div class="btn-group nowrap mass-actions-admin">
  72. <button class="btn btn-sm btn-primary d-block d-sm-inline" id="register-fido2">{{ lang.fido2.set_fido2 }}</button>
  73. <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>
  74. <ul class="dropdown-menu">
  75. <li><a class="dropdown-item" href="#" id="register-fido2-touchid"><i class="bi bi-apple"></i> {{ lang.fido2.set_fido2_touchid }}</a></li>
  76. </ul>
  77. </div>
  78. </div>
  79. </div>
  80. <div class="row mb-3" id="status-fido2">
  81. <div class="col-sm-3 col-5 text-end">{{ lang.fido2.register_status }}:</div>
  82. <div class="col-sm-9 col-7">
  83. <div id="fido2-alerts">-</div>
  84. </div>
  85. <br>
  86. </div>
  87. <legend style="cursor:pointer;margin-top:40px" data-bs-target="#license" unselectable="on" data-bs-toggle="collapse">
  88. <i style="font-size:10pt;" class="bi bi-plus-square"></i> {{ lang.admin.guid_and_license }}
  89. </legend>
  90. <hr />
  91. <div id="license" class="collapse">
  92. <form class="form-horizontal" autocapitalize="none" autocorrect="off" role="form" method="post">
  93. <div class="row">
  94. <label class="control-label col-sm-3" for="guid">{{ lang.admin.guid }}:</label>
  95. <div class="col-sm-9">
  96. <div class="input-group">
  97. <span class="input-group-text">
  98. <i class="bi bi-suit-heart{% if gal.valid == true %}-fill text-danger{% endif %}"></i>
  99. </span>
  100. <input type="text" id="guid" class="form-control" value="{{ license_guid }}" readonly>
  101. </div>
  102. <p class="text-muted">
  103. {{ lang.admin.customer_id }}: {{ gal.c|default('?')|raw }} -
  104. {{ lang.admin.service_id }}: {{ gal.s|default('?')|raw }} -
  105. {{ lang.admin.sal_level }}: {{ gal.m|default('?')|raw }}
  106. </p>
  107. </div>
  108. </div>
  109. <div class="row">
  110. <div class="offset-sm-3 col-sm-9">
  111. <p class="text-muted">{{ lang.admin.license_info|raw }}</p>
  112. <div class="btn-group">
  113. <button class="btn btn-sm d-block d-sm-inline btn-success" name="license_validate_now" type="submit" href="#">{{ lang.admin.validate_license_now }}</button>
  114. </div>
  115. </div>
  116. </div>
  117. </form>
  118. </div>
  119. <legend style="cursor:pointer;margin-top:20px" data-bs-target="#admin_api" unselectable="on" data-bs-toggle="collapse">
  120. <i style="font-size:10pt;" class="bi bi-plus-square"></i> API
  121. </legend>
  122. <hr />
  123. <div id="admin_api" class="collapse">
  124. <div class="row">
  125. <div class="col-lg-12">
  126. <p class="text-muted">{{ lang.admin.api_info|raw }}</p>
  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" 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" 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-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-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" 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" 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">
  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="ollapse-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>