list_db.html 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. <div class="l-center">
  2. <div class="l-sort clearfix noselect">
  3. <a href="/add/db/" class="l-sort__create-btn" title="<?=__('Add Database')?>"></a>
  4. <ul class="context-menu sort-order animated fadeIn" style="display:none;">
  5. <li entity="sort-date" sort_as_int="1"><span class="name active"><?=__('Date')?></span><span class="up"><i class="fas fa-sort-amount-up"></i></span></li>
  6. <li entity="sort-name"><span class="name"><?=__('Database')?></span><span class="up"><i class="fas fa-sort-amount-up"></i></span></li>
  7. <li entity="sort-disk" sort_as_int="1"><span class="name"><?=__('Disk')?></span><span class="up"><i class="fas fa-sort-amount-up"></i></span></li>
  8. <li entity="sort-user"><span class="name"><?=__('User')?></span><span class="up"><i class="fas fa-sort-amount-up"></i></span></li>
  9. <li entity="sort-server"><span class="name"><?=__('Host')?></span><span class="up"><i class="fas fa-sort-amount-up"></i></span></li>
  10. <li entity="sort-star" sort_as_int="1"><span class="name"><?=__('Starred')?></span><span class="up"><i class="fas fa-sort-amount-up"></i></span></li>
  11. </ul>
  12. <div class="l-sort-toolbar clearfix">
  13. <table>
  14. <tr>
  15. <?
  16. $mysql = 0;
  17. $pgsql = 0;
  18. list($http_host, $port) = explode(':', $_SERVER["HTTP_HOST"].":");
  19. foreach ($data as $key => $value) {
  20. if ($data[$key]['TYPE'] == 'mysql'){
  21. $mysql = 1;
  22. $db_myadmin_link = "http://".$http_host."/phpmyadmin/";
  23. if (!empty($_SESSION['DB_PMA_URL']))
  24. $db_myadmin_link = $_SESSION['DB_PMA_URL'];
  25. }
  26. if ($data[$key]['TYPE'] == 'pgsql'){
  27. $pgsql = 1;
  28. $db_pgadmin_link = "http://".$http_host."/phppgadmin/";
  29. if (!empty($_SESSION['DB_PGA_URL']))
  30. $db_pgadmin_link = $_SESSION['DB_PGA_URL'];
  31. }
  32. }
  33. if($mysql){
  34. echo '<td><a class="vst" href="'.$db_myadmin_link.'" target="_blank">phpMyAdmin</td>';
  35. }
  36. if($pgsql){
  37. echo '<td><a class="vst" href="'.$db_pgadmin_link.'" target="_blank">phpPgAdmin</td>';
  38. }
  39. ?>
  40. <td class="l-sort-toolbar__search-box">
  41. <form action="/search/" method="get">
  42. <input type="hidden" name="token" value="<?=$_SESSION['token']?>" />
  43. <input type="text" name="q" class="search-input" value="<? echo isset($_POST['q']) ? htmlspecialchars($_POST['q']) : '' ?>" />
  44. <button type="submit" class="l-sort-toolbar__filter-apply" onclick="return doSearch('/search/')" value=""><i class="fas fa-search"></i></button>
  45. </form>
  46. </td>
  47. <td class="toggle-all">
  48. <input id="toggle-all" type="checkbox" name="toggle-all" value="toggle-all" onChange="checkedAll('objects');">
  49. <label for="toggle-all" class="check-label toggle-all"><?=__('toggle all')?></label>
  50. </td>
  51. <td>
  52. <form action="/bulk/db/" method="post" id="objects">
  53. <input type="hidden" name="token" value="<?=$_SESSION['token']?>" />
  54. <div class="l-select">
  55. <select name="action" id="">
  56. <option value=""><?=__('apply to selected')?></option>
  57. <option value="delete"><?=__('delete')?></option>
  58. </select>
  59. </div>
  60. <button type="submit" class="l-sort-toolbar__filter-apply" value=""><i class="fas fa-arrow-right"></i></button>
  61. </td>
  62. <td class="sort-by">
  63. <?=__('sort by');?>: <span><b><?=__('Date')?> <i class="fas fa-sort-amount-down"></i></b></span>
  64. </td>
  65. </tr>
  66. </table>
  67. <!-- -->
  68. </div>
  69. </div>
  70. <!-- /.l-sort -->
  71. </div>
  72. <div class="l-separator"></div>
  73. <!-- /.l-separator -->
  74. <div class="l-center units animated fadeIn">
  75. <?
  76. list($http_host, $port) = explode(':', $_SERVER["HTTP_HOST"].":");
  77. foreach ($data as $key => $value) {
  78. ++$i;
  79. if ($data[$key]['SUSPENDED'] == 'yes') {
  80. $status = 'suspended';
  81. $spnd_action = 'unsuspend' ;
  82. $spnd_confirmation = 'UNSUSPEND_DATABASE_CONFIRMATION' ;
  83. } else {
  84. $status = 'active';
  85. $spnd_action = 'suspend' ;
  86. $spnd_confirmation = 'SUSPEND_DATABASE_CONFIRMATION' ;
  87. }
  88. if ($data[$key]['HOST'] != 'localhost' ) $http_host = $data[$key]['HOST'];
  89. if ($data[$key]['TYPE'] == 'mysql') $db_admin = "phpMyAdmin";
  90. if ($data[$key]['TYPE'] == 'mysql') $db_admin_link = "http://".$http_host."/phpmyadmin/";
  91. if (($data[$key]['TYPE'] == 'mysql') && (!empty($_SESSION['DB_PMA_URL']))) $db_admin_link = $_SESSION['DB_PMA_URL'];
  92. if ($data[$key]['TYPE'] == 'pgsql') $db_admin = "phpPgAdmin";
  93. if ($data[$key]['TYPE'] == 'pgsql') $db_admin_link = "http://".$http_host."/phppgadmin/";
  94. if (($data[$key]['TYPE'] == 'pgsql') && (!empty($_SESSION['DB_PGA_URL']))) $db_admin_link = $_SESSION['DB_PGA_URL'];
  95. ?>
  96. <div class="l-unit <? if($status == 'suspended') echo 'l-unit--suspended'; if($_SESSION['favourites']['DB'][$key] == 1) echo ' l-unit--starred'; ?>" v_unit_id="<?=$key?>" v_section="db"
  97. sort-date="<?=strtotime($data[$key]['DATE'].' '.$data[$key]['TIME'])?>" sort-name="<?=$key?>" sort-disk="<?=$data[$key]['U_DISK']?>"
  98. sort-user="<?=$data[$key]['DBUSER']?>" sort-server="<?=$data[$key]['HOST']?>" sort-star="<? if($_SESSION['favourites']['DB'][$key] == 1) echo '1'; else echo '0'; ?>">
  99. <div class="l-unit-toolbar clearfix">
  100. <div class="l-unit-toolbar__col l-unit-toolbar__col--left">
  101. <input id="check<?php echo $i ?>" class="ch-toggle" type="checkbox" name="database[]" value="<?php echo $key ?>">
  102. </div>
  103. <!-- l-unit-toolbar__col -->
  104. <div class="l-unit-toolbar__col l-unit-toolbar__col--right noselect">
  105. <div class="actions-panel clearfix">
  106. <div class="actions-panel__col actions-panel__edit shortcut-enter" key-action="href"><a href="/edit/db/?database=<?=$key?>"><?=__('edit')?> <i></i></a><span class="shortcut enter">&nbsp;&#8629;</span></div>
  107. <div class="actions-panel__col actions-panel__delete shortcut-delete" key-action="js">
  108. <a id="delete_link_<?=$i?>" class="data-controls do_delete">
  109. <?=__('delete')?> <i class="do_delete"></i>
  110. <input type="hidden" name="delete_url" value="/delete/db/?database=<?=$key?>&token=<?=$_SESSION['token']?>" />
  111. <div id="delete_dialog_<?=$i?>" class="confirmation-text-delete hidden" title="<?=__('Confirmation')?>">
  112. <p class="confirmation"><?=__('DELETE_DATABASE_CONFIRMATION',$key)?></p>
  113. </div>
  114. </a>
  115. <span class="shortcut delete">&nbsp;Del</span>
  116. </div>
  117. </div>
  118. <!-- /.actiona-panel -->
  119. </div>
  120. <!-- l-unit-toolbar__col -->
  121. </div>
  122. <!-- /.l-unit-toolbar -->
  123. <div class="l-unit__col l-unit__col--left clearfix">
  124. <div class="l-unit__date">
  125. <?=translate_date($data[$key]['DATE'])?>
  126. </div>
  127. <div class="l-unit__suspended"><?=__('suspended')?></div>
  128. <div class="text-center">
  129. <i class="l-icon-star" title="<?=__('save to favorites')?>"></i>
  130. </div>
  131. </div>
  132. <!-- /.l-unit__col -->
  133. <div class="l-unit__col l-unit__col--right">
  134. <div class="l-unit__name separate">
  135. <?=$key?>
  136. </div>
  137. <!-- /.l-unit__name -->
  138. <div class="l-unit__stats">
  139. <table>
  140. <tr>
  141. <td>
  142. <div class="l-unit__stat-cols clearfix graph">
  143. <div class="l-unit__stat-col l-unit__stat-col--left">
  144. <?=__('Disk')?>
  145. </div>
  146. <div class="l-unit__stat-col l-unit__stat-col--right text-right volume">
  147. <b><?=humanize_usage_size($data[$key]['U_DISK'])?></b> <?=humanize_usage_measure($data[$key]['U_DISK'])?>
  148. </div>
  149. </div>
  150. <div class="l-percent">
  151. <div class="l-percent__fill" style="width: <?=get_percentage($data[$key]['U_DISK'],$panel[$user]['DISK_QUOTA'])?>%"></div>
  152. </div>
  153. <!-- /.percent -->
  154. </td>
  155. <td>
  156. <div class="l-unit__stat-cols clearfix">
  157. <div class="l-unit__stat-col l-unit__stat-col--left"><?=__('User')?>:</div>
  158. <div class="l-unit__stat-col l-unit__stat-col--right">
  159. <b><?=$data[$key]['DBUSER']?></b>
  160. </div>
  161. </div>
  162. </td>
  163. <td>
  164. <div class="l-unit__stat-cols clearfix last">
  165. <div class="l-unit__stat-col l-unit__stat-col--left"><?=__('Host')?>:</div>
  166. <div class="l-unit__stat-col l-unit__stat-col--right">
  167. <b><?=$data[$key]['HOST']?></b>
  168. </div>
  169. </div>
  170. </td>
  171. </tr>
  172. <tr>
  173. <td></td>
  174. <td>
  175. <div class="l-unit__stat-cols clearfix">
  176. <div class="l-unit__stat-col l-unit__stat-col--left"><?=__('Charset')?>:</div>
  177. <div class="l-unit__stat-col l-unit__stat-col--right">
  178. <b><?=$data[$key]['CHARSET']?></b>
  179. </div>
  180. </div>
  181. </td>
  182. <td>
  183. <div class="l-unit__stat-cols clearfix last">
  184. <div class="l-unit__stat-col l-unit__stat-col--left"><?=__('Type')?>:</div>
  185. <div class="l-unit__stat-col l-unit__stat-col--right">
  186. <b><?=$data[$key]['TYPE']?></b>
  187. </div>
  188. </div>
  189. </td>
  190. </tr>
  191. </table>
  192. </div>
  193. <!-- /.l-unit__stats -->
  194. </div>
  195. <!-- /.l-unit__col -->
  196. </div>
  197. <!-- /.l-unit -->
  198. <!-- div class="l-separator"></div-->
  199. <!-- /.l-separator -->
  200. <?}?>
  201. </div>
  202. <div id="vstobjects">
  203. <div class="l-separator"></div>
  204. <div class="l-center">
  205. <div class="l-unit-ft">
  206. <table class='data'></table>
  207. <div class="data-count l-unit__col l-unit__col--right clearfix">
  208. <?php
  209. if ( $i == 1) {
  210. echo __('1 database');
  211. } else {
  212. echo __('%s databases',$i);
  213. }
  214. ?>
  215. </div>
  216. </div>
  217. </div>
  218. </div>