list_db.html 12 KB

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