DB.class.php 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  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. 'SUSPEND' => $record['SUSPEND'],
  38. 'DATE' => date(Config::get('ui_date_format', strtotime($record['DATE'])))
  39. );
  40. }
  41. if (!$result['status']) {
  42. $this->errors[] = array($result['error_code'] => $result['error_message']);
  43. }
  44. return $this->reply($result['status'], $reply);
  45. }
  46. /**
  47. * Add DB entry
  48. *
  49. * @param Request $request
  50. * @return string - Ajax Reply
  51. */
  52. public function addExecute(Request $request)
  53. {
  54. $user = $this->getLoggedUser();
  55. $_s = $request->getParameter('spell');
  56. $params = array(
  57. 'USER' => $user['uid'],
  58. 'DB' => $_s['DB'],
  59. 'DB_USER' => $_s['USER'],
  60. 'DB_PASSWORD' => $_s['PASSWORD'],
  61. 'TYPE' => $_s['TYPE']
  62. );
  63. // TODO: do not user it. Will be used in later releases
  64. /*if ($_s['HOST']) {
  65. $params['HOST'] = $_s['HOST'];
  66. }*/
  67. $result = Vesta::execute(Vesta::V_ADD_DB_BASE, $params);
  68. if (!$result['status']) {
  69. $this->errors[] = array($result['error_code'] => $result['error_message']);
  70. }
  71. return $this->reply($result['status'], $result['data']);
  72. }
  73. /**
  74. * Delete DB entry
  75. *
  76. * @param Request $request
  77. * @return string - Ajax Reply
  78. */
  79. public function deleteExecute(Request $request)
  80. {
  81. $_s = $request->getParameter('spell');
  82. $user = $this->getLoggedUser();
  83. $params = array(
  84. 'USER' => $user['uid'],
  85. 'DB' => $_s['DB']
  86. );
  87. $result = Vesta::execute(Vesta::V_DEL_DB_BASE, $params);
  88. if (!$result['status']) {
  89. $this->errors[] = array($result['error_code'] => $result['error_message']);
  90. }
  91. return $this->reply($result['status'], $result['data']);
  92. }
  93. /**
  94. * Change Password
  95. *
  96. * @param Request $request
  97. * @return string - Ajax Reply
  98. */
  99. public function changeExecute(Request $request)
  100. {
  101. $_s = $request->getParameter('new');
  102. $user = $this->getLoggedUser();
  103. $result = array();
  104. $params = array(
  105. 'USER' => $user['uid'],
  106. 'DB' => $_s['DB'],
  107. 'PASSWORD' => $_s['PASSWORD']
  108. );
  109. $result = Vesta::execute(Vesta::V_CHANGE_DB_PASSWORD, $params);
  110. if (!$result['status']) {
  111. $this->errors[] = array($result['error_code'] => $result['error_message']);
  112. }
  113. return $this->reply($result['status'], $result['data']);
  114. }
  115. }