index.php 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. <?php
  2. ob_start();
  3. $TAB = 'WEB';
  4. // Main include
  5. include($_SERVER['DOCUMENT_ROOT']."/inc/main.php");
  6. require_once $_SERVER['DOCUMENT_ROOT']."/src/init.php";
  7. // Check domain argument
  8. if (empty($_GET['domain'])) {
  9. header("Location: /list/web/");
  10. exit;
  11. }
  12. // Edit as someone else?
  13. if (($_SESSION['user'] == 'admin') && (!empty($_GET['user']))) {
  14. $user=escapeshellarg($_GET['user']);
  15. }
  16. // Get all user domains
  17. exec (HESTIA_CMD."v-list-web-domains ".escapeshellarg($user)." json", $output, $return_var);
  18. $user_domains = json_decode(implode('', $output), true);
  19. $user_domains = array_keys($user_domains);
  20. unset($output);
  21. // List domain
  22. $v_domain = $_GET['domain'];
  23. if(!in_array($v_domain, $user_domains)) {
  24. header("Location: /list/web/");
  25. exit;
  26. }
  27. $v_web_apps = [
  28. [ 'name'=>'Wordpress', 'group'=>'cms', 'enabled'=>true, 'version'=>'latest', 'thumbnail'=>'/images/webapps/wp-thumb.png' ],
  29. [ 'name'=>'Drupal', 'group'=>'cms', 'enabled'=>false,'version'=>'latest', 'thumbnail'=>'/images/webapps/drupal-thumb.png' ],
  30. [ 'name'=>'Joomla', 'group'=>'cms', 'enabled'=>false,'version'=>'latest', 'thumbnail'=>'/images/webapps/joomla-thumb.png' ],
  31. [ 'name'=>'Opencart', 'group'=>'ecommerce', 'enabled'=>true, 'version'=>'3.0.3.3', 'thumbnail'=>'/images/webapps/opencart-thumb.png' ],
  32. [ 'name'=>'Prestashop', 'group'=>'ecommerce', 'enabled'=>true, 'version'=>'1.7.6.5', 'thumbnail'=>'/images/webapps/prestashop-thumb.png' ],
  33. [ 'name'=>'Magento', 'group'=>'ecommerce', 'enabled'=>false, 'version'=>'latest', 'thumbnail'=>'/images/webapps/magento-thumb.png' ],
  34. [ 'name'=>'Laravel', 'group'=>'starter', 'enabled'=>true, 'version'=>'7.x', 'thumbnail'=>'/images/webapps/laravel-thumb.png' ],
  35. [ 'name'=>'Symfony', 'group'=>'starter', 'enabled'=>true, 'version'=>'4.3.x', 'thumbnail'=>'/images/webapps/symfony-thumb.png' ],
  36. ];
  37. // Check GET request
  38. if (!empty($_GET['app'])) {
  39. $app = basename($_GET['app']);
  40. $hestia = new \Hestia\System\HestiaApp();
  41. $app_installer_class = '\Hestia\WebApp\Installers\\' . $app . 'Setup';
  42. if(class_exists($app_installer_class)) {
  43. try {
  44. $app_installer = new $app_installer_class($v_domain, $hestia);
  45. $installer = new \Hestia\WebApp\AppWizard($app_installer, $v_domain, $hestia);
  46. $GLOBALS['WebappInstaller'] = $installer;
  47. } catch (Exception $e) {
  48. $_SESSION['error_msg'] = $e->getMessage();
  49. header('Location: /add/webapp/?domain=' . $v_domain);
  50. exit();
  51. }
  52. } else {
  53. $_SESSION['error_msg'] = "${app} installer missing";
  54. }
  55. }
  56. // Check POST request
  57. if (!empty($_POST['ok']) && !empty($app) ) {
  58. // Check token
  59. if ((!isset($_POST['token'])) || ($_SESSION['token'] != $_POST['token'])) {
  60. header('location: /login/');
  61. exit();
  62. }
  63. if ($installer) {
  64. try{
  65. if (!$installer->execute($_POST)){
  66. $result = $installer->getStatus();
  67. if(!empty($result))
  68. $_SESSION['error_msg'] = implode(PHP_EOL, $result);
  69. } else {
  70. $_SESSION['ok_msg'] = htmlspecialchars($app) . " App was installed succesfully !";
  71. header('Location: /add/webapp/?domain=' . $v_domain);
  72. exit();
  73. }
  74. } catch (Exception $e) {
  75. $_SESSION['error_msg'] = $e->getMessage();
  76. header('Location: /add/webapp/?app='.rawurlencode($app).'&domain=' . $v_domain);
  77. exit();
  78. }
  79. }
  80. }
  81. if(!empty($installer)) {
  82. render_page($user, $TAB, 'setup_webapp');
  83. } else {
  84. render_page($user, $TAB, 'list_webapps');
  85. }
  86. // Flush session messages
  87. unset($_SESSION['error_msg']);
  88. unset($_SESSION['ok_msg']);