main.php 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. <?php
  2. // Check user session
  3. if (!isset($_SESSION['user'])) {
  4. $_SESSION['request_uri'] = $_SERVER['REQUEST_URI'];
  5. header("Location: /login/");
  6. exit;
  7. }
  8. if (isset($_SESSION['look']) && ( $_SESSION['look'] != 'admin' )) {
  9. $user = $_SESSION['look'];
  10. } else {
  11. $user = $_SESSION['user'];
  12. }
  13. define('VESTA_CMD', '/usr/bin/sudo /usr/local/vesta/bin/');
  14. $i = 0;
  15. // Define functions
  16. function check_error($return_var){
  17. if ( $return_var > 0 ) {
  18. header("Location: /error/");
  19. exit;
  20. }
  21. }
  22. function top_panel($user, $TAB) {
  23. global $panel;
  24. $command = VESTA_CMD."v_list_user '".$user."' 'json'";
  25. exec ($command, $output, $return_var);
  26. if ( $return_var > 0 ) {
  27. header("Location: /error/");
  28. }
  29. $panel = json_decode(implode('', $output), true);
  30. unset($output);
  31. if ( $user == 'admin' ) {
  32. include($_SERVER['DOCUMENT_ROOT'].'/templates/admin/panel.html');
  33. } else {
  34. include($_SERVER['DOCUMENT_ROOT'].'/templates/user/panel.html');
  35. }
  36. }
  37. function humanize_time($usage) {
  38. if ( $usage > 60 ) {
  39. $usage = $usage / 60;
  40. $usage = number_format($usage, 2);
  41. $usage = $usage." Hour.";
  42. } else {
  43. $usage = $usage." Min.";
  44. }
  45. return $usage;
  46. }
  47. function humanize_usage($usage) {
  48. if ( $usage > 1000 ) {
  49. $usage = $usage / 1000;
  50. if ( $usage > 1000 ) {
  51. $usage = $usage / 1000 ;
  52. if ( $usage > 1000 ) {
  53. $usage = $usage / 1000 ;
  54. $usage = number_format($usage, 2);
  55. $usage = $usage." pb";
  56. } else {
  57. $usage = number_format($usage, 2);
  58. $usage = $usage." tb";
  59. }
  60. } else {
  61. $usage = number_format($usage, 2);
  62. $usage = $usage." gb";
  63. }
  64. } else {
  65. $usage = $usage." mb";
  66. }
  67. return $usage;
  68. }
  69. function get_percentage($used,$total) {
  70. if (!isset($total)) $total = 0;
  71. if (!isset($used)) $used = 0;
  72. if ( $total == 0 ) {
  73. $percent = 0;
  74. } else {
  75. $percent = $used / $total;
  76. $percent = $percent * 100;
  77. $percent = number_format($percent, 0, '', '');
  78. if ( $percent > 100 ) {
  79. $percent = 100;
  80. }
  81. if ( $percent < 0 ) {
  82. $percent = 0;
  83. }
  84. }
  85. return $percent;
  86. }
  87. function send_email($to,$subject,$mailtext,$from) {
  88. $charset = "utf-8";
  89. $to = '<'.$to.'>';
  90. $boundary = '--' . md5( uniqid("myboundary") );
  91. $priorities = array( '1 (Highest)', '2 (High)', '3 (Normal)', '4 (Low)', '5 (Lowest)' );
  92. $priority = $priorities[2];
  93. $ctencoding = "8bit";
  94. $sep = chr(13) . chr(10);
  95. $disposition = "inline";
  96. $subject = "=?$charset?B?".base64_encode($subject)."?=";
  97. $header = "From: $from \nX-Priority: $priority\nCC:\n";
  98. $header .= "Mime-Version: 1.0\nContent-Type: text/plain; charset=$charset \n";
  99. $header .= "Content-Transfer-Encoding: $ctencoding\nX-Mailer: Php/libMailv1.3\n";
  100. $message = $mailtext;
  101. mail($to, $subject, $message, $header);
  102. }
  103. function display_error_block() {
  104. if (!empty($_SESSION['error_msg'])) {
  105. echo '
  106. <script type="text/javascript">
  107. $(function() {
  108. $( "#dialog:ui-dialog" ).dialog( "destroy" );
  109. $( "#dialog-message" ).dialog({
  110. modal: true,
  111. buttons: {
  112. Ok: function() {
  113. $( this ).dialog( "close" );
  114. }
  115. }
  116. });
  117. });
  118. </script>
  119. <div id="dialog-message" title="Error">
  120. <p>';
  121. echo $_SESSION['error_msg'];
  122. echo "</p>\n </div>\n";
  123. unset($_SESSION['error_msg']);
  124. }
  125. }
  126. ?>