list_services.html 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. <div class="l-center">
  2. <div class="l-sort clearfix noselect">
  3. <div class="l-unit-toolbar__buttonstrip">
  4. <a href="/edit/server/" class="ui-button cancel" title="<?=__('Configure')?>"><i class="fas fa-cog status-icon-lightblue"></i> <?=__('Configure')?></a>
  5. <a href="/list/package/" class="ui-button cancel" title="<?=__('Packages')?>"><i class="fas fa-box-open status-icon-orange"></i> <?=__('Packages')?></a>
  6. <a href="/list/ip/" class="ui-button cancel" title="<?=__('IP')?>"><i class="fas fa-ethernet status-icon-blue"></i> <?=__('IP')?></a>
  7. <?php if ((isset($_SESSION['FIREWALL_SYSTEM'])) && (!empty($_SESSION['FIREWALL_SYSTEM']))) {?><a href="/list/firewall/" class="ui-button cancel" title="<?=__('Firewall')?>"><i class="fas fa-shield-alt status-icon-red"></i> <?=__('Firewall')?></a><?php }?>
  8. <a href="/list/rrd/" class="ui-button cancel" title="<?=__('Graphs')?>"><i class="fas fa-chart-area status-icon-orange"></i> <?=__('Graphs')?></a>
  9. <a href="/list/updates/" class="ui-button cancel" title="<?=__('Updates')?>"><i class="fas fa-sync status-icon-green"></i> <?=__('Updates')?></a>
  10. <a href="/list/server/?cpu" class="ui-button cancel" title="<?=__('show: CPU / MEM / NET / DISK');?>"><i class="fas fa-search status-icon-blue"></i> <?=__('show: CPU / MEM / NET / DISK');?></a>
  11. </div>
  12. <div class="l-sort-toolbar clearfix">
  13. <table>
  14. <tr>
  15. <td class="toggle-all">
  16. <input id="toggle-all" type="checkbox" name="toggle-all" value="toggle-all" onChange="checkedAll('objects');">
  17. <label for="toggle-all" class="check-label toggle-all"><?=__('toggle all')?></label>
  18. </td>
  19. <td>
  20. <form action="/bulk/service/" method="post" id="objects">
  21. <input type="hidden" name="token" value="<?=$_SESSION['token']?>" />
  22. <div class="l-select">
  23. <select class="" name="action">
  24. <option value=""><?php print __('apply to selected');?></option>
  25. <option value="stop"><?php print __('stop');?></option>
  26. <option value="start"><?php print __('start');?></option>
  27. <option value="restart"><?php print __('restart');?></option>
  28. </select>
  29. </div>
  30. <button type="submit" class="l-sort-toolbar__filter-apply" value=""><i class="fas fa-arrow-right"></i></button>
  31. </td>
  32. </tr>
  33. </table>
  34. </div>
  35. </div>
  36. <!-- /.l-sort -->
  37. </div>
  38. <div class="l-separator"></div>
  39. <!-- /.l-separator -->
  40. <div class="l-center units animated fadeIn">
  41. <div class="l-unit <? if($status == 'suspended') echo 'l-unit--suspended';?>">
  42. <div class="l-unit-toolbar clearfix">
  43. <div class="l-unit-toolbar__col l-unit-toolbar__col--left">
  44. <input id="check0" class="ch-toggle" type="checkbox" name="srv[]" value="<?php echo $sys['sysinfo']['HOSTNAME'] ?>">
  45. <label for="check0" class="check-label"></label>
  46. </div>
  47. <!-- l-unit-toolbar__col -->
  48. <div class="l-unit-toolbar__col l-unit-toolbar__col--right noselect">
  49. <div class="actions-panel clearfix">
  50. <div class="actions-panel__col actions-panel__configure shortcut-enter" key-action="href"><a href="/edit/server/"><?=__('configure')?> <i></i></a><span class="shortcut enter">&nbsp;&#8629;</span></div>
  51. <div class="actions-panel__col actions-panel__restart shortcut-r" key-action="href"><a href="/restart/system/?hostname=<?php echo $sys['sysinfo']['HOSTNAME'] ?>&token=<?=$_SESSION['token']?>"><?=__('restart')?> <i></i></a><span class="shortcut">&nbsp;R</span></div>
  52. </div>
  53. <!-- /.actions-panel -->
  54. </div>
  55. <!-- l-unit-toolbar__col -->
  56. </div>
  57. <!-- /.l-unit-toolbar -->
  58. <div class="l-unit__col l-unit__col--left clearfix">
  59. <div class="l-unit__suspended"><?__('suspended')?></div>
  60. <!-- div class="l-unit__date">
  61. </div-->
  62. </div>
  63. <!-- /.l-unit__col -->
  64. <div class="l-unit__col l-unit__col--right">
  65. <div class="l-unit__name separate">
  66. <?=$sys['sysinfo']['HOSTNAME']?>
  67. </div>
  68. <div class="l-unit__stats">
  69. <table>
  70. <tr>
  71. <td>
  72. <div class="l-unit__stat-cols clearfix">
  73. <div class="l-unit__stat-col l-unit__stat-col--left">
  74. <b><?=$sys['sysinfo']['OS']?>
  75. <?=$sys['sysinfo']['VERSION']?></b>
  76. </div>
  77. <div class="l-unit__stat-col l-unit__stat-col--right">(<?=$sys['sysinfo']['ARCH']?>)</div>
  78. </div>
  79. </td>
  80. <td>
  81. <div class="l-unit__stat-cols clearfix">
  82. <div class="l-unit__stat-col l-unit__stat-col--left"><?=__('Load Average')?>:</div>
  83. <div class="l-unit__stat-col l-unit__stat-col--right"><b><?=$sys['sysinfo']['LOADAVERAGE']?></b></div>
  84. </div>
  85. </td>
  86. <td>
  87. <div class="l-unit__stat-cols clearfix last">
  88. <div class="l-unit__stat-col l-unit__stat-col--left compact"><?=__('Uptime')?>:</div>
  89. <div class="l-unit__stat-col l-unit__stat-col--right"><b><?=humanize_time($sys['sysinfo']['UPTIME'])?></b></div>
  90. </div>
  91. </td>
  92. </tr>
  93. </table>
  94. </div>
  95. <!-- /.l-unit__stats -->
  96. </div>
  97. <!-- /.l-unit__col -->
  98. </div>
  99. <!-- /.l-unit -->
  100. <?php
  101. foreach ($data as $key => $value) {
  102. ++$i;
  103. if ($data[$key]['STATE'] == 'running') {
  104. $status = 'active';
  105. $action = 'stop';
  106. } else {
  107. $status = 'suspended';
  108. $action = 'start';
  109. }
  110. $cpu = $data[$key]['CPU'] / 10;
  111. $cpu = number_format($cpu, 1);
  112. if ($cpu == '0.0') $cpu = 0;
  113. ?>
  114. <div class="l-unit <? if($status == 'suspended') echo 'l-unit--suspended';?>">
  115. <div class="l-unit-toolbar clearfix">
  116. <div class="l-unit-toolbar__col l-unit-toolbar__col--left">
  117. <input id="check<?php echo $i ?>" class="ch-toggle" type="checkbox" name="service[]" value="<?php echo $key ?>">
  118. <label for="check<?php echo $i ?>" class="check-label"></label>
  119. </div>
  120. <!-- l-unit-toolbar__col -->
  121. <div class="l-unit-toolbar__col l-unit-toolbar__col--right noselect">
  122. <div class="actions-panel clearfix">
  123. <div class="actions-panel__col actions-panel__configure shortcut-enter" key-action="href"><a href="/edit/server/<? echo $key ?>/"><?=__('configure')?> <i></i></a><span class="shortcut enter">&nbsp;&#8629;</span></div>
  124. <div class="actions-panel__col actions-panel__<?=$action?> shortcut-s" key-action="href"><a href="/<?php echo $action ?>/service/?srv=<?=$key?>&token=<?=$_SESSION['token']?>"><?=__($action)?> <i></i></a><span class="shortcut">&nbsp;S</span></div>
  125. <div class="actions-panel__col actions-panel__restart shortcut-r" key-action="href"><a href="/restart/service/?srv=<?=$key?>&token=<?=$_SESSION['token']?>"><?=__('restart')?> <i></i></a><span class="shortcut">&nbsp;R</span></div>
  126. </div>
  127. <!-- /.actions-panel -->
  128. </div>
  129. <!-- l-unit-toolbar__col -->
  130. </div>
  131. <!-- /.l-unit-toolbar -->
  132. <div class="l-unit__col l-unit__col--left clearfix step-left">
  133. <!-- div class="l-unit__date">
  134. </div-->
  135. </div>
  136. <!-- /.l-unit__col -->
  137. <div class="l-unit__col l-unit__col--right">
  138. <div class="l-unit__name small-2">
  139. <?=$key?>
  140. </div>
  141. <div class="l-unit__stats">
  142. <table>
  143. <tr>
  144. <td>
  145. <div class="l-unit__stat-cols clearfix">
  146. <div class="l-unit__stat-col l-unit__stat-col--left"><b><?=__($data[$key]['SYSTEM'])?></b></div>
  147. <div class="l-unit__stat-col l-unit__stat-col--right"></div>
  148. </div>
  149. </td>
  150. <td>
  151. <div class="l-unit__stat-cols clearfix">
  152. <div class="l-unit__stat-col l-unit__stat-col--left"><?=__('CPU')?>: <b><?=$cpu?></b></div>
  153. <div class="l-unit__stat-col l-unit__stat-col--right"><?=__('Memory')?>: <b><?=$data[$key]['MEM']?> <?=__('mb')?></b></div>
  154. </div>
  155. </td>
  156. <td>
  157. <div class="l-unit__stat-cols clearfix last">
  158. <div class="l-unit__stat-col l-unit__stat-col--left"><?=__('Uptime')?>: <b><?=humanize_time($data[$key]['RTIME'])?></b></div>
  159. <div class="l-unit__stat-col l-unit__stat-col--right"></div>
  160. </div>
  161. </td>
  162. </tr>
  163. </table>
  164. </div>
  165. <!-- /.l-unit__stats -->
  166. </div>
  167. <!-- /.l-unit__col -->
  168. </div>
  169. <!-- /.l-unit -->
  170. <!-- div class="l-separator"></div -->
  171. <!-- /.l-separator -->
  172. <?}?>
  173. </div>
  174. <div id="vstobjects">
  175. <div class="l-separator"></div>
  176. <div class="l-center">
  177. <div class="l-unit-ft">
  178. <div class="l-unit__col l-unit__col--left clearfix"></div>
  179. <div class="data-count l-unit__col l-unit__col--right clearfix"></div>
  180. </div>
  181. </div>
  182. </div>