edit_user.html 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369
  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($_SESSION['userTheme'])) && ( $value == $_POST['v_user_theme'])){
  199. echo ' selected' ;
  200. }
  201. echo ">".$value."</option>\n";
  202. }
  203. ?>
  204. </select>
  205. </td>
  206. </tr>
  207. <?}?>
  208. <tr>
  209. <td class="vst-text input-label">
  210. <?php print _('Package');?>
  211. </td>
  212. </tr>
  213. <tr>
  214. <td>
  215. <select class="vst-list" name="v_package">
  216. <?php
  217. foreach ($packages as $key => $value) {
  218. echo "\n\t\t\t\t\t\t\t\t\t<option value=\"".htmlentities($key)."\"";
  219. $skey = "'".$key."'";
  220. if (( $key == $v_package ) || ( $skey == $v_package)){
  221. echo 'selected' ;
  222. }
  223. echo ">".htmlentities($key)."</option>\n";
  224. }
  225. ?>
  226. </select>
  227. </td>
  228. </tr>
  229. <tr>
  230. <td class="step-top vst-text" style="/*padding: 32px 0 20px 0;*/">
  231. <a href="javascript:elementHideShow('advanced-opts');" class="vst-advanced"><?php print _('Advanced options');?></a>
  232. </td>
  233. </tr>
  234. <tr>
  235. <td class="step-top">
  236. <table id="advanced-opts" style="display: none;">
  237. <tr>
  238. <td class="vst-text input-label">
  239. <?php print _('SSH Access');?>
  240. </td>
  241. </tr>
  242. <tr>
  243. <td>
  244. <select class="vst-list" name="v_shell">
  245. <?php
  246. foreach ($shells as $key => $value) {
  247. echo "\t\t\t\t<option value=\"".htmlentities($value)."\"";
  248. $svalue = "'".$value."'";
  249. if (( $value == $v_shell ) || ($svalue == $v_shell )){
  250. echo 'selected' ;
  251. }
  252. echo ">".htmlentities($value)."</option>\n";
  253. }
  254. ?>
  255. </select>
  256. </td>
  257. </tr>
  258. <tr>
  259. <td class="vst-text input-label">
  260. <?php print _('PHP CLI Version');?>
  261. </td>
  262. </tr>
  263. <tr>
  264. <td>
  265. <select class="vst-list" name="v_phpcli">
  266. <?php
  267. foreach ($php_versions as $key => $value) {
  268. $php = explode('-',$value);
  269. echo "\t\t\t\t<option value=\"".$value."\"";
  270. $svalue = "'".$value."'";
  271. if ((!empty($v_phpcli)) && ( $value == $v_phpcli ) || ($svalue == $v_phpcli)){
  272. echo ' selected' ;
  273. }
  274. if ((empty($v_phpcli)) && ($value == DEFAULT_PHP_VERSION)){
  275. echo ' selected' ;
  276. }
  277. echo ">".htmlentities($value)."</option>\n";
  278. }
  279. ?>
  280. </select>
  281. </td>
  282. </tr>
  283. <?php if ((isset($_SESSION['DNS_SYSTEM'])) && (!empty($_SESSION['DNS_SYSTEM']))) {?>
  284. <tr>
  285. <td class="vst-text input-label">
  286. <?php print _('Default Name Servers');?>
  287. </td>
  288. </tr>
  289. <tr>
  290. <td>
  291. <input type="text" size="20" class="vst-input" name="v_ns1" value="<?=htmlentities(trim($v_ns1, "'"))?>">
  292. <span class="remove-ns additional-control delete vst-advanced button danger"><?=_('delete')?></span>
  293. </td>
  294. </tr>
  295. <tr>
  296. <td>
  297. <input type="text" size="20" class="vst-input" name="v_ns2" value="<?=htmlentities(trim($v_ns2, "'"))?>">
  298. <span class="remove-ns additional-control delete vst-advanced button danger"><?=_('delete')?></span>
  299. </td>
  300. </tr>
  301. <? if($v_ns3)
  302. echo '<tr>
  303. <td>
  304. <input type="text" size="20" class="vst-input" name="v_ns3" value="'.htmlentities(trim($v_ns3, "'")).'">
  305. <span class="remove-ns additional-control delete vst-advanced button danger">'._('delete').'</span>
  306. </td>
  307. </tr>';
  308. if($v_ns4)
  309. echo '<tr>
  310. <td>
  311. <input type="text" size="20" class="vst-input" name="v_ns4" value="'.htmlentities(trim($v_ns4, "'")).'">
  312. <span class="remove-ns additional-control delete vst-advanced button danger">'._('delete').'</span>
  313. </td>
  314. </tr>';
  315. if($v_ns5)
  316. echo '<tr>
  317. <td>
  318. <input type="text" size="20" class="vst-input" name="v_ns5" value="'.htmlentities(trim($v_ns5, "'")).'">
  319. <span class="remove-ns additional-control delete vst-advanced button danger">'._('delete').'</span>
  320. </td>
  321. </tr>';
  322. if($v_ns6)
  323. echo '<tr>
  324. <td>
  325. <input type="text" size="20" class="vst-input" name="v_ns6" value="'.htmlentities(trim($v_ns6, "'")).'">
  326. <span class="remove-ns additional-control delete vst-advanced button danger">'._('delete').'</span>
  327. </td>
  328. </tr>';
  329. if($v_ns7)
  330. echo '<tr>
  331. <td>
  332. <input type="text" size="20" class="vst-input" name="v_ns7" value="'.htmlentities(trim($v_ns7, "'")).'">
  333. <span class="remove-ns additional-control delete vst-advanced button danger">'._('delete').'</span>
  334. </td>
  335. </tr>';
  336. if($v_ns8)
  337. echo '<tr>
  338. <td>
  339. <input type="text" size="20" class="vst-input" name="v_ns8" value="'.htmlentities(trim($v_ns8, "'")).'">
  340. <span class="remove-ns additional-control delete vst-advanced button danger">'._('delete').'</span>
  341. </td>
  342. </tr>';
  343. ?>
  344. <tr class="add-ns" <? if($v_ns8) echo 'style="display:none;"'; ?> >
  345. <td class="step-top-small">
  346. <span class="add-ns-button vst-advanced button"><?=_('Add one more Name Server')?></span>
  347. </td>
  348. </tr>
  349. <?php } ?>
  350. </table>
  351. </td>
  352. </tr>
  353. </table>
  354. <table class="data-col2"></table>
  355. </td>
  356. </tr>
  357. </table>
  358. </form>
  359. </div>