Vesta.class.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263
  1. <?php
  2. /**
  3. * Api Main class
  4. * Calls / Executes native vesta methods
  5. *
  6. * @author vesta, http://vestacp.com/
  7. * @author Dmitry Malishev <[email protected]>
  8. * @author Dmitry Naumov-Socolov <[email protected]>
  9. * @copyright vesta 2010-2011
  10. */
  11. class Vesta
  12. {
  13. const SAME_PASSWORD = '********';
  14. const ADMIN = 1;
  15. const USER = 0;
  16. const PARAM_DELIMETER = ' ';
  17. // commands
  18. const V_LIST_SYS_CONFIG = 'v_list_sys_config';
  19. // USER
  20. const V_GET_SYS_USER_VALUE = 'v_get_user_value';
  21. const V_LIST_SYS_USERS = 'v_list_users';
  22. const V_LIST_SYS_USER = 'v_list_user';
  23. const V_LIST_USER_PACKAGES = 'v_list_user_packages';
  24. const V_ADD_SYS_USER = 'v_add_user';
  25. const V_CHANGE_SYS_USER_CONTACT = 'v_change_user_contact';
  26. const V_CHANGE_SYS_USER_NS = 'v_change_user_ns';
  27. const V_CHANGE_SYS_USER_PACKAGE = 'v_change_user_package';
  28. const V_CHANGE_SYS_USER_PASSWORD = 'v_change_user_password';
  29. const V_CHANGE_SYS_USER_SHELL = 'v_change_user_shell';
  30. const V_CHANGE_SYS_USER_ROLE = 'v_change_sys_user_role';
  31. const V_CHANGE_SYS_USER_NAME = 'v_change_user_name';
  32. const V_SUSPEND_SYS_USER = 'v_suspend_user';
  33. const V_UNSUSPEND_SYS_USER = 'v_unsuspend_user';
  34. const V_DEL_SYS_USER = 'v_delete_user';
  35. // WEB_DOMAIN
  36. const V_LIST_WEB_DOMAINS = 'v_list_web_domains';
  37. const V_LIST_WEB_DOMAINS_ALIAS = 'v_list_web_domains_alias';
  38. const V_LIST_WEB_DOMAINS_ELOG = 'v_list_web_domains_elog';
  39. const V_LIST_WEB_DOMAINS_PROXY = 'v_list_web_domains_proxy';
  40. const V_LIST_WEB_DOMAINS_SSL = 'v_list_web_domains_ssl';
  41. const V_LIST_WEB_DOMAINS_STATS = 'v_list_web_domains_stats';
  42. const V_LIST_WEB_TEMPLATES = 'v_list_web_templates';
  43. const V_ADD_WEB_DOMAIN = 'v_add_web_domain';
  44. const V_ADD_WEB_DOMAIN_ALIAS = 'v_add_web_domain_alias';
  45. const V_ADD_WEB_DOMAIN_STAT = 'v_add_web_domain_stat';
  46. const V_ADD_WEB_DOMAIN_STAT_AUTH = 'v_add_web_domain_stat_auth';
  47. const V_ADD_WEB_DOMAIN_SSL = 'v_add_web_domain_ssl';
  48. const V_ADD_WEB_DOMAIN_ELOG = 'v_add_web_domain_elog';
  49. const V_ADD_WEB_DOMAIN_CGI = 'v_add_web_domain_cgi';
  50. const V_CHANGE_WEB_DOMAIN_IP = 'v_change_web_domain_ip';
  51. const V_CHANGE_WEB_DOMAIN_SSLCERT = 'v_change_web_domain_sslcert';
  52. const V_CHANGE_WEB_DOMAIN_SSLHOME = 'v_change_web_domain_sslhome';
  53. const V_CHANGE_WEB_DOMAIN_TPL = 'v_change_web_domain_tpl';
  54. const V_DEL_WEB_DOMAIN_CGI = 'v_delete_web_domain_cgi';
  55. const V_DEL_WEB_DOMAIN_ELOG = 'v_delete_web_domain_elog';
  56. const V_DEL_WEB_DOMAIN_SSL = 'v_delete_web_domain_ssl';
  57. const V_DEL_WEB_DOMAIN_STAT = 'v_delete_web_domain_stat';
  58. const V_DEL_WEB_DOMAIN_STAT_AUTH = 'v_delete_web_domain_stat_auth';
  59. const V_DEL_WEB_DOMAIN_ALIAS = 'v_delete_web_domain_alias';
  60. const V_UPD_WEB_DOMAIN_DISK = 'v_update_web_domain_disk';
  61. const V_UPD_WEB_DOMAINS_DISK = 'v_update_web_domains_disk';
  62. const V_UPD_WEB_DOMAIN_TRAFF = 'v_update_web_domain_traff';
  63. const V_UPD_WEB_DOMAINS_TRAFF = 'v_update_web_domains_traff';
  64. const V_SUSPEND_WEB_DOMAIN = 'v_suspend_web_domain';
  65. const V_SUSPEND_WEB_DOMAINS = 'v_suspend_web_domains';
  66. const V_UNSUSPEND_WEB_DOMAIN = 'v_unsuspend_web_domain';
  67. const V_UNSUSPEND_WEB_DOMAINS = 'v_unsuspend_web_domains';
  68. const V_DEL_WEB_DOMAIN = 'v_delete_web_domain';
  69. // BACKUP
  70. const V_LIST_SYS_USER_BACKUPS = 'v_list_user_backups';
  71. // IP
  72. const V_LIST_SYS_IPS = 'v_list_sys_ips';
  73. const V_LIST_USER_IPS = 'v_list_user_ips';
  74. const V_LIST_SYS_USER_IPS = 'v_list_sys_user_ips';
  75. const V_ADD_SYS_IP = 'v_add_sys_ip';
  76. const V_ADD_SYS_USER_IP = 'v_add_user_ip';
  77. const V_CHANGE_SYS_IP_OWNER = 'v_change_sys_ip_owner';
  78. const V_CHANGE_SYS_IP_NAME = 'v_change_sys_ip_name';
  79. const V_CHANGE_SYS_IP_STATUS = 'v_change_sys_ip_status';
  80. const V_DEL_SYS_IP = 'v_delete_sys_ip';
  81. const V_UPD_SYS_IP = 'v_update_sys_ip';
  82. const V_LIST_SYS_INTERFACES = 'v_list_sys_interfaces';
  83. // DNS
  84. const V_LIST_DNS_DOMAINS = 'v_list_dns_domains';
  85. const V_LIST_DNS_DOMAIN_RECORDS = 'v_list_dns_domain';
  86. const V_LIST_DNS_TEMPLATES = 'v_list_dns_templates';
  87. const V_ADD_DNS_DOMAIN = 'v_add_dns_domain';
  88. const V_ADD_DNS_DOMAIN_RECORD = 'v_add_dns_domain_record';
  89. const V_CHANGE_DNS_DOMAIN_IP = 'v_change_dns_domain_ip';
  90. const V_CHANGE_DNS_DOMAIN_SOA = 'v_change_dns_domain_soa';
  91. const V_CHANGE_DNS_DOMAIN_TPL = 'v_change_dns_domain_tpl';
  92. const V_CHANGE_DNS_DOMAIN_TTL = 'v_change_dns_domain_ttl';
  93. const V_CHANGE_DNS_DOMAIN_EXP = 'v_change_dns_domain_exp';
  94. const V_CHANGE_DNS_DOMAIN_RECORD = 'v_change_dns_domain_record';
  95. const V_SUSPEND_DNS_DOMAIN = 'v_suspend_dns_domain';
  96. const V_UNSUSPEND_DNS_DOMAIN = 'v_unsuspend_dns_domain';
  97. const V_DEL_DNS_DOMAIN = 'v_delete_dns_domain';
  98. const V_DEL_DNS_DOMAIN_RECORD = 'v_delete_dns_domain_record';
  99. // DB
  100. const V_LIST_DB_BASES = 'v_list_db_bases';
  101. const V_LIST_DB_HOSTS = 'v_list_db_hosts';
  102. const V_LIST_WEB_DOMAIN_ALIAS = 'v_list_web_domain_alias';
  103. const V_ADD_DB_BASE = 'v_add_db_base';
  104. const V_ADD_DB_HOST = 'v_add_db_host';
  105. const V_CHANGE_DB_PASSWORD = 'v_change_db_password';
  106. const V_UPD_DB_BASE_DISK = 'v_update_db_base_disk';
  107. const V_UPD_DB_BASES_DISK = 'v_update_db_bases_disk';
  108. const V_SUSPEND_DB_BASE = 'v_suspend_db_base';
  109. const V_SUSPEND_DB_BASES = 'v_suspend_db_bases';
  110. const V_UNSUSPEND_DB_BASE = 'v_unsuspend_db_base';
  111. const V_UNSUSPEND_DB_BASES = 'v_unsuspend_db_bases';
  112. const V_DEL_DB_BASE = 'v_delete_db_base';
  113. const V_DEL_DB_HOST = 'v_delete_db_host';
  114. // CRON
  115. const V_LIST_CRON_JOBS = 'v_list_cron_jobs';
  116. const V_ADD_CRON_JOB = 'v_add_cron_job';
  117. const V_ADD_SYS_USER_REPORTS = 'v_add_user_reports';
  118. const V_CHANGE_CRON_JOB = 'v_change_cron_job';
  119. const V_SUSPEND_CRON_JOB = 'v_suspend_cron_job';
  120. const V_SUSPEND_CRON_JOBS = 'v_suspend_cron_jobs';
  121. const V_UNSUSPEND_CRON_JOB = 'v_unsuspend_cron_job';
  122. const V_UNSUSPEND_CRON_JOBS = 'v_unsuspend_cron_jobs';
  123. const V_DEL_CRON_JOB = 'v_delete_cron_job';
  124. const V_DEL_SYS_USER_REPORTS = 'v_delete_user_reports';
  125. // STATS
  126. const V_LIST_SYS_RRD = 'v_list_sys_rrd json';
  127. const V_UPDATE_SYS_RRD = 'v_update_sys_rrd';
  128. /**
  129. * Execute vesta command
  130. *
  131. * @param string $cms_command
  132. * @param array $parameters
  133. * @return string
  134. */
  135. static function execute($cmd_command, $parameters = array(), $reply = '')
  136. {
  137. $r = new Request();
  138. $_DEBUG = $r->getParameter("debug", FALSE);
  139. if (!isset($cmd_command)) {
  140. throw new ProtectionException('No function name passed into Vesta::execute'); // TODO: move msg to Messages::
  141. }
  142. if(!self::hasRights((int)VestaSession::getInstance()->getUserRole(), $cmd_command)){
  143. return array('status' => 'TRUE');
  144. }
  145. $reply_type = $reply;
  146. if ($reply != AjaxHandler::JSON) {
  147. $reply = '';
  148. }
  149. $params = array(
  150. 'sudo' => Config::get('sudo_path'),
  151. 'functions' => Config::get('vesta_functions_path'),
  152. 'parameters' => is_array($parameters) ? "'".implode("' '", $parameters)."'" : $parameters,
  153. 'reply' => $reply
  154. );
  155. // e.g.: /usr/bin/sudo /usr/local/vesta/bin/v_list_users vesta json
  156. $cmd = "{$params['sudo']} {$params['functions']}{$cmd_command} {$params['parameters']} {$params['reply']}";
  157. exec($cmd, $output, $return);
  158. $result = 0;
  159. $result = array(
  160. 'status' => TRUE,
  161. 'data' => '',
  162. 'error_code' => '',
  163. 'error_message' => ''
  164. );
  165. // TODO: please remove this later :)
  166. if ($_DEBUG) {
  167. $result['debug'] = array(
  168. "cmd" => $cmd,
  169. "output" => $output,
  170. "return" => $return
  171. );
  172. if ($_DEBUG == 2) {
  173. echo '<p>'.$cmd;
  174. echo '<br> output: '; print_r($output);
  175. echo '<br> return: '.$return;
  176. echo '</p>';
  177. }
  178. }
  179. if (!!(int)$return) {
  180. $result['status'] = FALSE;
  181. $result['error_code'] = (int)$return;
  182. $result['error_message'] = implode('', $output);
  183. return $result;
  184. }
  185. if ($reply_type == 'text') {
  186. $result['data'] = implode('', $output);
  187. }
  188. else {
  189. $result['data'] = json_decode(implode('', $output), true);
  190. }
  191. return $result;
  192. }
  193. /**
  194. * User Rights management
  195. *
  196. * @params array $commands
  197. * @params int $role
  198. * @return BOOL
  199. */
  200. public function hasRights($role, $command)
  201. {
  202. // return TRUE;
  203. // echo 'role - '.$role;
  204. // exit();
  205. $rights = array(
  206. self::ADMIN => array(),
  207. self::USER => array(
  208. // sys
  209. self::V_LIST_SYS_CONFIG,
  210. // user
  211. self::V_GET_SYS_USER_VALUE, self::V_LIST_SYS_USERS, self::V_ADD_SYS_USER, self::V_CHANGE_SYS_USER_CONTACT, self::V_CHANGE_SYS_USER_NS, self::V_CHANGE_SYS_USER_PACKAGE, self::V_CHANGE_SYS_USER_PASSWORD, self::V_CHANGE_SYS_USER_SHELL, self::V_CHANGE_SYS_USER_ROLE, self::V_CHANGE_SYS_USER_NAME, self::V_SUSPEND_SYS_USER, self::V_UNSUSPEND_SYS_USER, self::V_DEL_SYS_USER,
  212. 'login_as',
  213. // ip
  214. self::V_LIST_SYS_IPS, self::V_ADD_SYS_IP, self::V_ADD_SYS_USER_IP, self::V_DEL_SYS_IP, self::V_UPD_SYS_IP, self::V_CHANGE_SYS_IP_OWNER, self::V_CHANGE_SYS_IP_NAME, self::V_CHANGE_SYS_IP_STATUS, self::V_UPD_SYS_IP, self::V_LIST_SYS_INTERFACES,
  215. // web domain
  216. self::V_UPD_WEB_DOMAIN_DISK, self::V_UPD_WEB_DOMAINS_DISK, self::V_UPD_WEB_DOMAIN_TRAFF, self::V_UPD_WEB_DOMAINS_TRAFF, self::V_SUSPEND_WEB_DOMAIN, self::V_SUSPEND_WEB_DOMAINS, self::V_UNSUSPEND_WEB_DOMAIN, self::V_UNSUSPEND_WEB_DOMAINS,
  217. // dns
  218. self::V_SUSPEND_DNS_DOMAIN, self::V_UNSUSPEND_DNS_DOMAIN,
  219. // db
  220. self::V_ADD_DB_HOST, self::V_DEL_DB_HOST, self::V_UPD_DB_BASE_DISK, self::V_UPD_DB_BASES_DISK, self::V_SUSPEND_DB_BASE, self::V_SUSPEND_DB_BASES, self::V_UNSUSPEND_DB_BASE, self::V_UNSUSPEND_DB_BASES,
  221. // cron
  222. self::V_ADD_SYS_USER_REPORTS, self::V_DEL_SYS_USER_REPORTS, self::V_SUSPEND_CRON_JOB, self::V_SUSPEND_CRON_JOBS, self::V_UNSUSPEND_CRON_JOB, self::V_UNSUSPEND_CRON_JOBS,
  223. // backups
  224. self::V_LIST_SYS_USER_BACKUPS
  225. )
  226. );
  227. if(in_array($command, $rights[$role])){
  228. return FALSE;
  229. }
  230. return TRUE;
  231. }
  232. }