DB.class.php 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201
  1. <?php
  2. /**
  3. * DB
  4. *
  5. * @author vesta, http://vestacp.com/
  6. * @author Dmitry Malishev <dima.malishev@gmail.com>
  7. * @author Dmitry Naumov-Socolov <naumov.socolov@gmail.com>
  8. * @copyright vesta 2010-2011
  9. */
  10. class DB extends AjaxHandler
  11. {
  12. /**
  13. * Get DB entries
  14. *
  15. * @param Request $request
  16. * @return string - Ajax Reply
  17. */
  18. public function getListExecute(Request $request)
  19. {
  20. $user = $this->getLoggedUser();
  21. $reply = array();
  22. $result = Vesta::execute(Vesta::V_LIST_DB_BASES, array($user['uid'], Config::get('response_type')));
  23. foreach ($result['data'] as $db => $record) {
  24. $type = $record['TYPE'];
  25. if (!isset($reply[$type])) {
  26. $reply[$type] = array();
  27. }
  28. $reply[$type][] = array(
  29. 'DB' => $db,
  30. 'OWNER' => $record['USER'],
  31. 'USER' => $record['USER'],
  32. 'USERS' => (array)$record['USER'],
  33. 'HOST' => $record['HOST'],
  34. 'TYPE' => $record['TYPE'],
  35. 'U_DISK' => $record['U_DISK'],
  36. 'DISK' => 2024,
  37. 'CHARSET' => strtolower($record['CHARSET']),
  38. 'SUSPEND' => $record['SUSPEND'],
  39. 'DATE' => $record['DATE']// date(Config::get('ui_date_format', strtotime($record['DATE'])))
  40. );
  41. }
  42. if (!$result['status']) {
  43. $this->errors[] = array($result['error_code'] => $result['error_message']);
  44. }
  45. return $this->reply($result['status'], $reply);
  46. }
  47. /**
  48. * Add DB entry
  49. *
  50. * @param Request $request
  51. * @return string - Ajax Reply
  52. */
  53. public function addExecute(Request $request)
  54. {
  55. $user = $this->getLoggedUser();
  56. $_s = $request->getParameter('spell');
  57. $params = array(
  58. 'USER' => $user['uid'],
  59. 'DB' => $_s['DB'],
  60. 'DB_USER' => $_s['USER'],
  61. 'DB_PASSWORD' => $_s['PASSWORD'],
  62. 'TYPE' => $_s['TYPE'],
  63. 'HOST' => $_s['HOST'],
  64. 'CHARSET' => $_s['CHARSET']
  65. );
  66. $result = Vesta::execute(Vesta::V_ADD_DB_BASE, $params);
  67. if (!$result['status']) {
  68. $this->errors[] = array($result['error_code'] => $result['error_message']);
  69. }
  70. if (Utils::getCheckboxBooleanValue($_s['SUSPEND'])) {
  71. if($result['status']){
  72. $result = array();
  73. $result = Vesta::execute(Vesta::V_SUSPEND_DB_BASE, array('USER' => $user['uid'], 'JOB' => $_s['DB']));
  74. if (!$result['status']) {
  75. $this->status = FALSE;
  76. $this->errors['SUSPEND'] = array($result['error_code'] => $result['error_message']);
  77. }
  78. }
  79. }
  80. return $this->reply($result['status'], $result['data']);
  81. }
  82. /**
  83. * Delete DB entry
  84. *
  85. * @param Request $request
  86. * @return string - Ajax Reply
  87. */
  88. public function deleteExecute(Request $request)
  89. {
  90. $_s = $request->getParameter('spell');
  91. $user = $this->getLoggedUser();
  92. $params = array(
  93. 'USER' => $user['uid'],
  94. 'DB' => $_s['DB']
  95. );
  96. $result = Vesta::execute(Vesta::V_DEL_DB_BASE, $params);
  97. if (!$result['status']) {
  98. $this->errors[] = array($result['error_code'] => $result['error_message']);
  99. }
  100. return $this->reply($result['status'], $result['data']);
  101. }
  102. /**
  103. * Change Password
  104. *
  105. * @param Request $request
  106. * @return string - Ajax Reply
  107. */
  108. public function changeExecute(Request $request)
  109. {
  110. $_s = $request->getParameter('spell');
  111. $_old = $request->getParameter('old');
  112. $_new = $request->getParameter('new');
  113. $user = $this->getLoggedUser();
  114. $result = array();
  115. $result = array();
  116. if(@Utils::getCheckboxBooleanValue($_new['SUSPEND'])){
  117. $result = Vesta::execute(Vesta::V_SUSPEND_DB_BASE, array('USER' => $user['uid'], 'DB' => $_new['DB']));
  118. return $this->reply($result['status'], $result['error_message']);
  119. }
  120. elseif(@Utils::getCheckboxBooleanValue($_old['SUSPEND'])){
  121. $result = Vesta::execute(Vesta::V_UNSUSPEND_DB_BASE, array('USER' => $user['uid'], 'DB' => $_new['DB']));
  122. if (!$result['status']) {
  123. $this->status = FALSE;
  124. $this->errors['UNSUSPEND'] = array($result['error_code'] => $result['error_message']);
  125. return $this->reply($result['status'], $result['error_message']);
  126. }
  127. }
  128. if ($_new['PASSWORD'] != Vesta::SAME_PASSWORD && $_new['PASSWORD'] != $_old['PASSWORD']) {
  129. $params = array(
  130. 'USER' => $user['uid'],
  131. 'DB' => $_new['DB'],
  132. 'PASSWORD' => $_new['PASSWORD']
  133. );
  134. $result = Vesta::execute(Vesta::V_CHANGE_DB_PASSWORD, $params);
  135. if (!$result['status']) {
  136. $this->errors[] = array($result['error_code'] => $result['error_message']);
  137. }
  138. }
  139. return $this->reply($result['status'], $result['data']);
  140. }
  141. public function massiveSuspendExecute(Request $request)
  142. {
  143. $user = $this->getLoggedUser();
  144. $_entities = $request->getParameter('entities');
  145. foreach($_entities as $entity){
  146. $result = Vesta::execute(Vesta::V_SUSPEND_DB_BASE, array('USER' => $user['uid'], $entity['DB']));
  147. }
  148. return $this->reply($result['status'], $result['data']);
  149. }
  150. public function massiveUnsuspendExecute(Request $request)
  151. {
  152. $user = $this->getLoggedUser();
  153. $_entities = $request->getParameter('entities');
  154. foreach($_entities as $entity){
  155. $result = Vesta::execute(Vesta::V_UNSUSPEND_DB_BASE, array('USER' => $user['uid'], $entity['DB']));
  156. }
  157. return $this->reply($result['status'], $result['data']);
  158. }
  159. public function massiveDeleteExecute(Request $request)
  160. {
  161. $user = $this->getLoggedUser();
  162. $_entities = $request->getParameter('entities');
  163. foreach($_entities as $entity){
  164. $result = Vesta::execute(Vesta::V_DEL_DB_BASE, array('USER' => $user['uid'], $entity['DB']));
  165. }
  166. return $this->reply($result['status'], $result['data']);
  167. }
  168. }