edit_user.html 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293
  1. <!-- Begin toolbar -->
  2. <div class="l-sort">
  3. <div class="l-sort__inner">
  4. <div class="l-unit-toolbar__buttonstrip">
  5. <a class="button button-secondary" id="btn-back" href="/list/user/"><i class="fas fa-arrow-left status-icon blue"></i><?=_('Back');?></a>
  6. <?php
  7. if (($_SESSION['userContext'] === 'admin') && (!isset($_SESSION['look'])) && ($_SESSION['user'] !== $v_username)) {
  8. $ssh_key_url = "/list/key/?user=".htmlentities($user_plain)."&token=".$_SESSION['token']."";
  9. $log_url = "/list/log/?user=".htmlentities($user_plain)."&token=".$_SESSION['token']."";
  10. $keys_url = "/list/access-key/?user=".htmlentities($user_plain)."&token=".$_SESSION['token']."";
  11. } else {
  12. $ssh_key_url = "/list/key/";
  13. $log_url = "/list/log/";
  14. $keys_url = "/list/access-key/";
  15. }
  16. ?>
  17. <a href="<?=$ssh_key_url; ?>" class="button button-secondary" id="btn-create" title="<?=_('Manage SSH keys');?>"><i class="fas fa-key status-icon orange"></i><?=_('Manage SSH keys');?></a>
  18. <?php if (($_SESSION['userContext'] == 'admin') || ($_SESSION['userContext'] !== 'admin') && ($_SESSION['POLICY_USER_VIEW_LOGS'] !== 'no')) {?>
  19. <a href="<?=$log_url; ?>" class="button button-secondary" id="btn-create" title="<?=_('Logs');?>"><i class="fas fa-clock-rotate-left status-icon maroon"></i><?=_('Logs');?></a>
  20. <?php } ?>
  21. <?php
  22. $api_status = (!empty($_SESSION['API_SYSTEM']) && is_numeric($_SESSION['API_SYSTEM'])) ? $_SESSION['API_SYSTEM'] : 0;
  23. if (($user_plain == 'admin' && $api_status > 0) || ($user_plain != 'admin' && $api_status > 1)) { ?>
  24. <a href="<?=$keys_url; ?>" class="button button-secondary" id="btn-create" title="<?=_('Access Keys');?>"><i class="fas fa-key status-icon purple"></i><?=_('Access Keys');?></a>
  25. <?php } ?>
  26. </div>
  27. <div class="l-unit-toolbar__buttonstrip">
  28. <?php if (($_SESSION['user'] == $v_username) || (isset($_SESSION['look']))) {?>
  29. <!-- Do not show delete button for currently logged in user-->
  30. <?} else {?>
  31. <a href="/login/?loginas=<?=htmlentities($v_username)?>&token=<?=$_SESSION['token']?>" class="button button-secondary" id="btn-create" title="<?=_('login as');?>"><i class="fas fa-right-to-bracket status-icon maroon"></i><?=_('login as');?></a>
  32. <a class="data-controls do_delete button button-secondary button-danger">
  33. <i class="do_delete fas fa-circle-xmark status-icon red"></i>
  34. <?=_('Delete');?>
  35. <input type="hidden" name="delete_url" value="/delete/user/?user=<?=htmlentities($v_username)?>&token=<?=$_SESSION['token']?>">
  36. <div class="dialog js-confirm-dialog-delete" title="<?=_('Confirmation');?>">
  37. <p><?=sprintf(_('DELETE_USER_CONFIRMATION'),htmlentities($v_username))?></p>
  38. </div>
  39. </a>
  40. <?php } ?>
  41. <a href="#" class="button" data-action="submit" data-id="vstobjects"><i class="fas fa-floppy-disk status-icon purple"></i> <?=_('Save');?></a>
  42. </div>
  43. </div>
  44. </div>
  45. <!-- End toolbar -->
  46. <div class="l-center animate__animated animate__fadeIn">
  47. <form id="vstobjects" method="post" name="v_edit_user" class="<?=$v_status?>">
  48. <input type="hidden" name="token" value="<?=$_SESSION['token']?>">
  49. <input type="hidden" name="save" value="save">
  50. <div class="form-container">
  51. <h1 class="form-title"><?=_('Editing User');?></h1>
  52. <?php show_alert_message($_SESSION);?>
  53. <div class="u-mb10">
  54. <label for="v_user" class="form-label"><?=_('Username');?></label>
  55. <input type="text" class="form-control" name="v_user" id="v_user" value="<?=htmlentities(trim($v_username, "'"))?>" disabled>
  56. <input type="hidden" name="v_username" value="<?=htmlentities(trim($v_username, "'"))?>">
  57. </div>
  58. <div class="u-mb10">
  59. <label for="v_name" class="form-label"><?=_('Contact');?></label>
  60. <input type="text" class="form-control" name="v_name" id="v_name" value="<?=htmlentities(trim($v_name, "'"))?>" <?php if (($_SESSION['userContext'] !=='admin' ) && ($_SESSION['POLICY_USER_EDIT_DETAILS'] !=='yes' )) { echo 'disabled' ; }?> >
  61. <?php if (($_SESSION['userContext'] !== 'admin') && ($_SESSION['POLICY_USER_EDIT_DETAILS'] !== 'yes')) {?>
  62. <input type="hidden" name="v_name" value="<?=htmlentities(trim($v_name, "'"))?>">
  63. <?php } ?>
  64. </div>
  65. <div class="u-mb10">
  66. <label for="v_email" class="form-label"><?=_('Email');?></label>
  67. <input type="email" class="form-control" name="v_email" id="v_email" value="<?=htmlentities(trim($v_email, "'"))?>" <?php if (($_SESSION['userContext'] !=='admin' ) && ($_SESSION['POLICY_USER_EDIT_DETAILS'] !=='yes' )) { echo 'disabled' ; }?>>
  68. <?php if (($_SESSION['userContext'] !== 'admin') && ($_SESSION['POLICY_USER_EDIT_DETAILS'] !== 'yes')) {?>
  69. <input type="hidden" name="v_email" value="<?=htmlentities(trim($v_email, "'"))?>">
  70. <?php } ?>
  71. </div>
  72. <div class="u-mb10">
  73. <label for="v_password" class="form-label">
  74. <?=_('Password');?>
  75. <a href="javascript:applyRandomString();" title="<?=_('generate');?>" class="u-ml5"><i class="fas fa-arrows-rotate status-icon green icon-large"></i></a>
  76. </label>
  77. <div class="u-pos-relative u-mb10">
  78. <input type="text" class="form-control js-password-input" name="v_password" id="v_password" value="<?=htmlentities(trim($v_password, "'"))?>">
  79. <meter max="4" class="password-meter"></meter>
  80. </div>
  81. </div>
  82. <div id="password-details" class="u-mb20">
  83. <p class="u-mb10"><?=_('Your password must have at least');?>:</p>
  84. <ul class="u-list-bulleted u-mb10">
  85. <li><?=_('8 characters long');?></li>
  86. <li><?=_('1 uppercase & 1 lowercase character');?></li>
  87. <li><?=_('1 number');?></li>
  88. </ul>
  89. <?php if ($_SESSION['userContext'] === 'admin') {?>
  90. <div class="form-check">
  91. <input class="form-check-input" type="checkbox" name="v_login_disabled" id="v_login_disabled" onclick="javascript:elementHideShow('password-options');elementHideShow('password-options-ip');" <?php if ($v_login_disabled === "yes") echo 'checked' ?>>
  92. <label for="v_login_disabled">
  93. <?=_('Do not allow user to log in to Control Panel');?>
  94. </label>
  95. </div>
  96. <?php } ?>
  97. <div id="password-options" style="<?php if ($v_login_disabled === 'yes') { echo 'display: none;'; } else { echo 'display: block;'; }?>">
  98. <div class="form-check u-mt15">
  99. <input class="form-check-input" type="checkbox" name="v_twofa" id="v_twofa" <?php if(!empty($v_twofa)) echo 'checked' ?>>
  100. <label for="v_twofa">
  101. <?=_('Enable 2FA');?>
  102. </label>
  103. </div>
  104. <?php if (!empty($v_twofa)) { ?>
  105. <p class="u-mb10"><?=_('2FA Reset Code:').' '.$v_twofa; ?></p>
  106. <p class="u-mb10"><?=_('Please scan the code below in your 2FA application:');?></p>
  107. <div><img class="qr-code" src="<?=htmlentities($v_qrcode); ?>" alt=""></div>
  108. <?php } ?>
  109. </div>
  110. <div id="password-options-ip" style="<?php if ($v_login_disabled === 'yes') { echo 'display: none;'; } else { echo 'display: block;'; }?>">
  111. <div class="form-check">
  112. <input class="form-check-input" type="checkbox" name="v_login_use_iplist" id="v_login_use_iplist" onclick="javascript:elementHideShow('ip-allowlist')" <?php if ($v_login_use_iplist === "yes") echo 'checked' ?>>
  113. <label for="v_login_use_iplist">
  114. <?=_('Use IP address allow list for login attempts');?>
  115. </label>
  116. </div>
  117. </div>
  118. <div id="ip-allowlist" class="u-mt10" style="<?php if ($v_login_use_iplist === 'yes') { echo 'display: block;'; } else { echo 'display: none;'; } ?>">
  119. <input type="text" class="form-control" name="v_login_allowed_ips" value="<?=htmlentities(trim($v_login_allowed_ips, "'"))?>" placeholder="<?=_('Example: 127.0.0.1,192.168.1.100');?>">
  120. </div>
  121. </div>
  122. <div class="u-mb10">
  123. <label for="v_language" class="form-label"><?=_('Language');?></label>
  124. <select class="form-select" name="v_language" id="v_language">
  125. <?php
  126. foreach ($languages as $key => $value) {
  127. echo "\n\t\t\t\t\t\t\t\t\t<option value=\"".$key."\"";
  128. $skey = "'".$key."'";
  129. if (( $key == $v_language ) || ( $skey == $v_language)){
  130. echo 'selected' ;
  131. }
  132. if (( $key == detect_user_language() ) && (empty($v_language))){
  133. echo 'selected' ;
  134. }
  135. echo ">".htmlentities($value)."</option>\n";
  136. }
  137. ?>
  138. </select>
  139. </div>
  140. <?php if ($v_username == 'admin') {?>
  141. <!-- Hide option to change 'admin' user's role-->
  142. <?php } else { ?>
  143. <?php if (($_SESSION['userContext'] === 'admin') && ($_SESSION['user'] != $v_username)) {?>
  144. <div class="u-mb10">
  145. <label for="v_role" class="form-label"><?=_('Role');?></label>
  146. <select class="form-select" name="v_role" id="v_role">
  147. <option value="user"><?=_('User');?>
  148. <option value="admin" <?php if($v_role == "admin" ){ echo "selected"; } ?>><?=_('Administrator');?>
  149. <option value="dns-cluster" <?php if($v_role == "dns-cluster" ){ echo "selected"; } ?>><?=_('DNS Sync user');?>
  150. </select>
  151. </div>
  152. <?php } ?>
  153. <?php } ?>
  154. <?php if ($_SESSION['POLICY_USER_CHANGE_THEME'] !== 'no') {?>
  155. <div class="u-mb10">
  156. <label for="v_user_theme" class="form-label"><?=_('Theme') ?></label>
  157. <select class="form-select" name="v_user_theme" id="v_user_theme">
  158. <?php
  159. foreach ($themes as $key => $value) {
  160. echo "\t\t\t\t<option value=\"".$value."\"";
  161. if ((!empty($_SESSION['userTheme'])) && ( $value == $v_user_theme )) {
  162. echo ' selected' ;
  163. }
  164. if ((empty($v_user_theme) && (!empty($_SESSION['THEME']))) && ( $value == $_SESSION['THEME'] )) {
  165. echo ' selected' ;
  166. }
  167. echo ">".$value."</option>\n";
  168. }
  169. ?>
  170. </select>
  171. </div>
  172. <?php } ?>
  173. <div class="u-mb10">
  174. <label for="v_sort_order" class="form-label"><?=_('Default list sort order');?></label>
  175. <select class="form-select" name="v_sort_order" id="v_sort_order">
  176. <option value='date' <?php if($v_sort_order === 'date') echo 'selected' ?>><?=_('Date');?></option>
  177. <option value='name' <?php if($v_sort_order === 'name') echo 'selected' ?>><?=_('Name');?></option>
  178. </select>
  179. </div>
  180. <?php if ($_SESSION['userContext'] === 'admin') {?>
  181. <div class="u-mb20">
  182. <label for="v_package" class="form-label"><?=_('Package');?></label>
  183. <select class="form-select" name="v_package" id="v_package">
  184. <?php
  185. foreach ($packages as $key => $value) {
  186. echo "\n\t\t\t\t\t\t\t\t\t<option value=\"".htmlentities($key)."\"";
  187. $skey = "'".$key."'";
  188. if (( $key == $v_package ) || ( $skey == $v_package)){
  189. echo 'selected' ;
  190. }
  191. echo ">".htmlentities($key)."</option>\n";
  192. }
  193. ?>
  194. </select>
  195. </div>
  196. <div class="u-mb20">
  197. <a href="javascript:elementHideShow('advanced-opts');" class="button button-secondary"><?=_('Advanced options');?></a>
  198. </div>
  199. <div id="advanced-opts" style="display: none;">
  200. <div class="u-mb10">
  201. <label for="v_shell" class="form-label"><?=_('SSH Access');?></label>
  202. <select class="form-select" name="v_shell" id="v_shell">
  203. <?php
  204. foreach ($shells as $key => $value) {
  205. echo "\t\t\t\t<option value=\"".htmlentities($value)."\"";
  206. $svalue = "'".$value."'";
  207. if (( $value == $v_shell ) || ($svalue == $v_shell )){
  208. echo 'selected' ;
  209. }
  210. echo ">".htmlentities($value)."</option>\n";
  211. }
  212. ?>
  213. </select>
  214. </div>
  215. <div class="u-mb10">
  216. <label for="v_phpcli" class="form-label"><?=_('PHP CLI Version');?></label>
  217. <select class="form-select" name="v_phpcli" id="v_phpcli">
  218. <?php
  219. foreach ($php_versions as $key => $value) {
  220. $php = explode('-',$value);
  221. echo "\t\t\t\t<option value=\"".$value."\"";
  222. $svalue = "'".$value."'";
  223. if ((!empty($v_phpcli)) && ( $value == $v_phpcli ) || ($svalue == $v_phpcli)){
  224. echo ' selected' ;
  225. }
  226. if ((empty($v_phpcli)) && ($value == DEFAULT_PHP_VERSION)){
  227. echo ' selected' ;
  228. }
  229. echo ">".htmlentities($value)."</option>\n";
  230. }
  231. ?>
  232. </select>
  233. </div>
  234. <?php if ((isset($_SESSION['DNS_SYSTEM'])) && (!empty($_SESSION['DNS_SYSTEM']))) {?>
  235. <p class="form-label u-mb10"><?=_('Default Name Servers');?></p>
  236. <div class="u-mb5">
  237. <input type="text" class="form-control" name="v_ns1" value="<?=htmlentities(trim($v_ns1, "'"))?>">
  238. </div>
  239. <div class="u-mb5">
  240. <input type="text" class="form-control" name="v_ns2" value="<?=htmlentities(trim($v_ns2, "'"))?>">
  241. </div>
  242. <?php
  243. if($v_ns3) {
  244. echo '<div class="u-side-by-side u-mb5">
  245. <input type="text" class="form-control" name="v_ns3" value="'.htmlentities(trim($v_ns3, "'")).'">
  246. <span class="js-remove-ns u-ml10"><i class="fas fa-trash status-icon dim red"></i></span>
  247. </div>';
  248. }
  249. if($v_ns4) {
  250. echo '<div class="u-side-by-side u-mb5">
  251. <input type="text" class="form-control" name="v_ns4" value="'.htmlentities(trim($v_ns4, "'")).'">
  252. <span class="js-remove-ns u-ml10"><i class="fas fa-trash status-icon dim red"></i></span>
  253. </div>';
  254. }
  255. if($v_ns5) {
  256. echo '<div class="u-side-by-side u-mb5">
  257. <input type="text" class="form-control" name="v_ns5" value="'.htmlentities(trim($v_ns5, "'")).'">
  258. <span class="js-remove-ns u-ml10"><i class="fas fa-trash status-icon dim red"></i></span>
  259. </div>';
  260. }
  261. if($v_ns6) {
  262. echo '<div class="u-side-by-side u-mb5">
  263. <input type="text" class="form-control" name="v_ns6" value="'.htmlentities(trim($v_ns6, "'")).'">
  264. <span class="js-remove-ns u-ml10"><i class="fas fa-trash status-icon dim red"></i></span>
  265. </div>';
  266. }
  267. if($v_ns7) {
  268. echo '<div class="u-side-by-side u-mb5">
  269. <input type="text" class="form-control" name="v_ns7" value="'.htmlentities(trim($v_ns7, "'")).'">
  270. <span class="js-remove-ns u-ml10"><i class="fas fa-trash status-icon dim red"></i></span>
  271. </div>';
  272. }
  273. if($v_ns8) {
  274. echo '<div class="u-side-by-side u-mb5">
  275. <input type="text" class="form-control" name="v_ns8" value="'.htmlentities(trim($v_ns8, "'")).'">
  276. <span class="js-remove-ns u-ml10"><i class="fas fa-trash status-icon dim red"></i></span>
  277. </div>';
  278. }
  279. ?>
  280. <div class="u-pt18 js-add-ns" <?php if ($v_ns8) echo 'style="display:none;"'; ?>>
  281. <span class="js-add-ns-button additional-control add"><?=_('Add one more Name Server');?></span>
  282. </div>
  283. <?php } ?>
  284. </div>
  285. <?php } ?>
  286. </div>
  287. </form>
  288. </div>