edit_user.html 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385
  1. <div class="l-center edit">
  2. <div class="l-sort clearfix">
  3. <div class="l-unit-toolbar__buttonstrip">
  4. <a class="ui-button cancel" dir="ltr" id="btn-back" href="/list/user/"><i class="fas fa-arrow-left status-icon blue"></i><?=_('Back')?></a>
  5. <?php if (($_SESSION['userContext'] === 'admin') && (!isset($_SESSION['look'])) && ($_SESSION['user'] !== $v_username)) {
  6. $ssh_key_url = "/list/key/?user=".$user."&token=".$_SESSION['token']."";
  7. $log_url = "/list/log/?user=".$user."&token=".$_SESSION['token']."";
  8. } else {
  9. $ssh_key_url = "/list/key/";
  10. $log_url = "/list/log/";
  11. } ?>
  12. <a href="<?php echo $ssh_key_url; ?>" id="btn-create" class="ui-button cancel" dir="ltr" title="<?=_('Manage SSH keys');?>"><i class="fas fa-key status-icon orange"></i><?=_('Manage SSH keys')?></a>
  13. <a href="<?php echo $log_url; ?>" id="btn-create" class="ui-button cancel" dir="ltr" title="<?=_('Logs');?>"><i class="fas fa-history status-icon maroon"></i><?=_('Logs')?></a>
  14. </div>
  15. <div class="l-unit-toolbar__buttonstrip float-right">
  16. <? if (($_SESSION['user'] == $v_username) || (isset($_SESSION['look']))) {?>
  17. <!-- Do not show delete button for currently logged in user-->
  18. <?} else {?>
  19. <a href="/login/?loginas=<?=$v_username?>&token=<?=$_SESSION['token']?>" id="btn-create" class="ui-button cancel" dir="ltr" title="<?=_('login as')?>"><i class="fas fa-sign-in-alt status-icon maroon"></i><?=_('login as')?></a>
  20. <div class="display-inline-block" key-action="js">
  21. <a class="data-controls do_delete ui-button danger cancel">
  22. <i class="do_delete fas fa-times-circle status-icon red"></i>
  23. <?=_('Delete')?>
  24. <input type="hidden" name="delete_url" value="/delete/user/?user=<?=$v_username?>&token=<?=$_SESSION['token']?>" />
  25. <div class="confirmation-text-delete hidden" title="<?=_('Confirmation')?>">
  26. <p class="confirmation"><?=sprintf(_('DELETE_USER_CONFIRMATION'),$v_username)?></p>
  27. </div>
  28. </a>
  29. </div>
  30. <? } ?>
  31. <a href="#" class="ui-button" data-action="submit" data-id="vstobjects"><i class="fas fa-save status-icon purple"></i> <?=_('Save')?></a>
  32. </div>
  33. </div>
  34. </div>
  35. <div class="l-separator"></div>
  36. <div class="l-center animated fadeIn">
  37. <?php
  38. $back = $_SESSION['back'];
  39. if (empty($back)) {
  40. $back = "location.href='/list/user/'";
  41. } else {
  42. $back = "location.href='".$back."'";
  43. }
  44. ?>
  45. <form id="vstobjects" method="post" name="v_edit_user" class="<?=$v_status?>">
  46. <input type="hidden" name="token" value="<?=$_SESSION['token']?>" />
  47. <input type="hidden" name="save" value="save" />
  48. <table class='data'>
  49. <tr class="data-add">
  50. <td class="data-dotted">
  51. <table class="data-col1">
  52. <tr>
  53. <td>
  54. </td>
  55. </tr>
  56. </table>
  57. </td>
  58. <td class="data-dotted">
  59. <table class="data-col2">
  60. <tr>
  61. <td class="step-top">
  62. <span class="page-title"><?=_('Editing User')?></span>
  63. </td>
  64. </tr>
  65. <tr>
  66. <td>
  67. <?php
  68. if (!empty($_SESSION['error_msg'])) {
  69. echo "<span class=\"vst-error\"> <i class=\"fas fa-exclamation-circle status-icon red\"></i> ".htmlentities($_SESSION['error_msg'])."</span>";
  70. } else {
  71. if (!empty($_SESSION['ok_msg'])) {
  72. echo "<span class=\"vst-ok\"> <i class=\"fas fa-check-circle status-icon green\"></i> ".$_SESSION['ok_msg']."</span>";
  73. }
  74. }
  75. ?>
  76. </td>
  77. </tr>
  78. <tr>
  79. <td class="vst-text step-top">
  80. <?php print _('Username');?>
  81. </td>
  82. </tr>
  83. <tr>
  84. <td>
  85. <input type="text" size="20" class="vst-input" name="v_user" value="<?=htmlentities(trim($v_username, "'"))?>" disabled>
  86. <input type="hidden" name="v_username" value="<?=htmlentities(trim($v_username, "'"))?>">
  87. </td>
  88. </tr>
  89. <tr>
  90. <td class="vst-text input-label">
  91. <?php print _('Contact');?>
  92. </td>
  93. </tr>
  94. <tr>
  95. <td>
  96. <input type="text" size="20" class="vst-input" name="v_name" value="<?=htmlentities(trim($v_name, "'"))?>">
  97. </td>
  98. </tr>
  99. <tr>
  100. <td class="vst-text input-label">
  101. <?php print _('Email');?>
  102. </td>
  103. </tr>
  104. <tr>
  105. <td>
  106. <input type="text" size="20" class="vst-input" name="v_email" value="<?=htmlentities(trim($v_email, "'"))?>">
  107. </td>
  108. </tr>
  109. <tr>
  110. <td class="vst-text input-label">
  111. <?php print _('Password');?> <a href="javascript:randomString();" title="<?php print _('generate');?>"><i class="fas fa-sync status-icon green icon-large"></i></a>
  112. </td>
  113. </tr>
  114. <tr>
  115. <td>
  116. <input type="text" size="20" class="vst-input password" name="v_password" value="<?=htmlentities(trim($v_password, "'"))?>"><br />
  117. <meter max="4" id="meter"></meter>
  118. </td>
  119. </tr>
  120. <tr>
  121. <td class="vst-text">
  122. <?php print _('Your password must have at least');?>:
  123. <ul>
  124. <li><?php print _('8 characters long');?></li>
  125. <li><?php print _('1 uppercase & 1 lowercase character');?></li>
  126. <li><?php print _('1 number');?></li>
  127. </ul>
  128. </td>
  129. </tr>
  130. <tr>
  131. <td>
  132. <label><input type="checkbox" class="vst-checkbox password-option" name="v_twofa" <?php if(!empty($v_twofa)) echo "checked=yes" ?>><?php print _('Enable 2FA');?></label>
  133. <?php if (!empty($v_twofa)) { ?>
  134. <p><?php echo _('2FA Reset Code:').' '.$v_twofa; ?></br></p>
  135. <p><?php echo _('Please scan the code below in your 2FA application:'); ?></p>
  136. <div><img class="qr-code" src="<?php echo $v_qrcode; ?>"></div>
  137. <?php } ?>
  138. </td>
  139. </tr>
  140. <tr>
  141. <td class="vst-text input-label">
  142. <?php print _('Language');?>
  143. </td>
  144. </tr>
  145. <tr>
  146. <td>
  147. <select class="vst-list" name="v_language">
  148. <?php
  149. foreach ($languages as $key => $value) {
  150. echo "\n\t\t\t\t\t\t\t\t\t<option value=\"".$key."\"";
  151. $skey = "'".$key."'";
  152. if (( $key == $v_language ) || ( $skey == $v_language)){
  153. echo 'selected' ;
  154. }
  155. if (( $key == detect_user_language() ) && (empty($v_language))){
  156. echo 'selected' ;
  157. }
  158. echo ">".htmlentities($value)."</option>\n";
  159. }
  160. ?>
  161. </select>
  162. </td>
  163. </tr>
  164. <?php if ($v_username == 'admin') {?>
  165. <!-- Hide option to change 'admin' user's role-->
  166. <? } else { ?>
  167. <? if (($_SESSION['userContext'] === 'admin') && ($_SESSION['user'] != $v_username)) {?>
  168. <tr>
  169. <td class="vst-text input-label">
  170. <?php print _('Role');?>
  171. </td>
  172. </tr>
  173. <tr>
  174. <td>
  175. <select class="vst-list" name="v_role">
  176. <option value="user"><?php print _('User');?>
  177. <option value="admin" <?php if($v_role == "admin" ){ echo "selected"; } ?> ><?php print _('Administrator');?>
  178. </select>
  179. </td>
  180. </tr>
  181. <? } ?>
  182. <? } ?>
  183. <? if ($_SESSION['POLICY_USER_CHANGE_THEME'] !== 'no') {?>
  184. <tr>
  185. <td class="vst-text input-label">
  186. <?php print _('Theme') ?>
  187. </td>
  188. </tr>
  189. <tr>
  190. <td>
  191. <select class="vst-list" name="v_user_theme">
  192. <?php
  193. foreach ($themes as $key => $value) {
  194. echo "\t\t\t\t<option value=\"".$value."\"";
  195. if ((!empty($_SESSION['userTheme'])) && ( $value == $v_user_theme )) {
  196. echo ' selected' ;
  197. }
  198. if ((empty($v_user_theme) && (!empty($_SESSION['THEME']))) && ( $value == $_SESSION['THEME'] )) {
  199. echo ' selected' ;
  200. }
  201. if ((!empty($_SESSION['userTheme'])) && ( $value == $_POST['v_user_theme'])){
  202. echo ' selected' ;
  203. }
  204. echo ">".$value."</option>\n";
  205. }
  206. ?>
  207. </select>
  208. </td>
  209. </tr>
  210. <?}?>
  211. <tr>
  212. <td class="vst-text input-label">
  213. <?php print _('Default sort order');?>
  214. </td>
  215. </tr>
  216. <tr>
  217. <td>
  218. <select class="vst-list" name="v_sort_order">
  219. <option value='date' <?php if($data[$user]['PREF_UI_SORT'] === '') echo 'selected' ?>><?php print _('Date'); ?></option>
  220. <option value='name' <?php if($data[$user]['PREF_UI_SORT'] === 'name') echo 'selected' ?>><?php print _('Name'); ?></option>
  221. </select>
  222. </td>
  223. </tr>
  224. <tr>
  225. <td class="vst-text input-label">
  226. <?php print _('Package');?>
  227. </td>
  228. </tr>
  229. <tr>
  230. <td>
  231. <select class="vst-list" name="v_package">
  232. <?php
  233. foreach ($packages as $key => $value) {
  234. echo "\n\t\t\t\t\t\t\t\t\t<option value=\"".htmlentities($key)."\"";
  235. $skey = "'".$key."'";
  236. if (( $key == $v_package ) || ( $skey == $v_package)){
  237. echo 'selected' ;
  238. }
  239. echo ">".htmlentities($key)."</option>\n";
  240. }
  241. ?>
  242. </select>
  243. </td>
  244. </tr>
  245. <tr>
  246. <td class="step-top vst-text" style="/*padding: 32px 0 20px 0;*/">
  247. <a href="javascript:elementHideShow('advanced-opts');" class="vst-advanced"><?php print _('Advanced options');?></a>
  248. </td>
  249. </tr>
  250. <tr>
  251. <td class="step-top">
  252. <table id="advanced-opts" style="display: none;">
  253. <tr>
  254. <td class="vst-text input-label">
  255. <?php print _('SSH Access');?>
  256. </td>
  257. </tr>
  258. <tr>
  259. <td>
  260. <select class="vst-list" name="v_shell">
  261. <?php
  262. foreach ($shells as $key => $value) {
  263. echo "\t\t\t\t<option value=\"".htmlentities($value)."\"";
  264. $svalue = "'".$value."'";
  265. if (( $value == $v_shell ) || ($svalue == $v_shell )){
  266. echo 'selected' ;
  267. }
  268. echo ">".htmlentities($value)."</option>\n";
  269. }
  270. ?>
  271. </select>
  272. </td>
  273. </tr>
  274. <tr>
  275. <td class="vst-text input-label">
  276. <?php print _('PHP CLI Version');?>
  277. </td>
  278. </tr>
  279. <tr>
  280. <td>
  281. <select class="vst-list" name="v_phpcli">
  282. <?php
  283. foreach ($php_versions as $key => $value) {
  284. $php = explode('-',$value);
  285. echo "\t\t\t\t<option value=\"".$value."\"";
  286. $svalue = "'".$value."'";
  287. if ((!empty($v_phpcli)) && ( $value == $v_phpcli ) || ($svalue == $v_phpcli)){
  288. echo ' selected' ;
  289. }
  290. if ((empty($v_phpcli)) && ($value == DEFAULT_PHP_VERSION)){
  291. echo ' selected' ;
  292. }
  293. echo ">".htmlentities($value)."</option>\n";
  294. }
  295. ?>
  296. </select>
  297. </td>
  298. </tr>
  299. <?php if ((isset($_SESSION['DNS_SYSTEM'])) && (!empty($_SESSION['DNS_SYSTEM']))) {?>
  300. <tr>
  301. <td class="vst-text input-label">
  302. <?php print _('Default Name Servers');?>
  303. </td>
  304. </tr>
  305. <tr>
  306. <td>
  307. <input type="text" size="20" class="vst-input" name="v_ns1" value="<?=htmlentities(trim($v_ns1, "'"))?>">
  308. <span class="remove-ns additional-control delete vst-advanced button danger"><?=_('delete')?></span>
  309. </td>
  310. </tr>
  311. <tr>
  312. <td>
  313. <input type="text" size="20" class="vst-input" name="v_ns2" value="<?=htmlentities(trim($v_ns2, "'"))?>">
  314. <span class="remove-ns additional-control delete vst-advanced button danger"><?=_('delete')?></span>
  315. </td>
  316. </tr>
  317. <? if($v_ns3)
  318. echo '<tr>
  319. <td>
  320. <input type="text" size="20" class="vst-input" name="v_ns3" value="'.htmlentities(trim($v_ns3, "'")).'">
  321. <span class="remove-ns additional-control delete vst-advanced button danger">'._('delete').'</span>
  322. </td>
  323. </tr>';
  324. if($v_ns4)
  325. echo '<tr>
  326. <td>
  327. <input type="text" size="20" class="vst-input" name="v_ns4" value="'.htmlentities(trim($v_ns4, "'")).'">
  328. <span class="remove-ns additional-control delete vst-advanced button danger">'._('delete').'</span>
  329. </td>
  330. </tr>';
  331. if($v_ns5)
  332. echo '<tr>
  333. <td>
  334. <input type="text" size="20" class="vst-input" name="v_ns5" value="'.htmlentities(trim($v_ns5, "'")).'">
  335. <span class="remove-ns additional-control delete vst-advanced button danger">'._('delete').'</span>
  336. </td>
  337. </tr>';
  338. if($v_ns6)
  339. echo '<tr>
  340. <td>
  341. <input type="text" size="20" class="vst-input" name="v_ns6" value="'.htmlentities(trim($v_ns6, "'")).'">
  342. <span class="remove-ns additional-control delete vst-advanced button danger">'._('delete').'</span>
  343. </td>
  344. </tr>';
  345. if($v_ns7)
  346. echo '<tr>
  347. <td>
  348. <input type="text" size="20" class="vst-input" name="v_ns7" value="'.htmlentities(trim($v_ns7, "'")).'">
  349. <span class="remove-ns additional-control delete vst-advanced button danger">'._('delete').'</span>
  350. </td>
  351. </tr>';
  352. if($v_ns8)
  353. echo '<tr>
  354. <td>
  355. <input type="text" size="20" class="vst-input" name="v_ns8" value="'.htmlentities(trim($v_ns8, "'")).'">
  356. <span class="remove-ns additional-control delete vst-advanced button danger">'._('delete').'</span>
  357. </td>
  358. </tr>';
  359. ?>
  360. <tr class="add-ns" <? if($v_ns8) echo 'style="display:none;"'; ?> >
  361. <td class="step-top-small">
  362. <span class="add-ns-button vst-advanced button"><?=_('Add one more Name Server')?></span>
  363. </td>
  364. </tr>
  365. <?php } ?>
  366. </table>
  367. </td>
  368. </tr>
  369. </table>
  370. <table class="data-col2"></table>
  371. </td>
  372. </tr>
  373. </table>
  374. </form>
  375. </div>