index.php 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  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'=>'5.2.4', '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.2', 'thumbnail'=>'/images/webapps/opencart-thumb.png' ],
  32. [ 'name'=>'Prestashop', 'group'=>'ecommerce', 'enabled'=>true, 'version'=>'1.7.6.1', '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'=>'6.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. try {
  41. $hestia = new \Hestia\System\HestiaApp();
  42. $app_installer_class = '\Hestia\WebApp\Installers\\' . $app . 'Setup';
  43. $app_installer = new $app_installer_class($v_domain, $hestia);
  44. $installer = new \Hestia\WebApp\AppWizard($app_installer, $v_domain, $hestia);
  45. } catch (Exception $e) {
  46. $_SESSION['error_msg'] = $e->getMessage();
  47. header('Location: /add/webapp/?domain=' . $v_domain);
  48. exit();
  49. }
  50. $GLOBALS['WebappInstaller'] = $installer;
  51. }
  52. // Check POST request
  53. if (!empty($_POST['ok']) && !empty($app) ) {
  54. // Check token
  55. if ((!isset($_POST['token'])) || ($_SESSION['token'] != $_POST['token'])) {
  56. header('location: /login/');
  57. exit();
  58. }
  59. if ($installer) {
  60. try{
  61. if (!$installer->execute($_POST)){
  62. $result = $installer->getStatus();
  63. if(!empty($result))
  64. $_SESSION['error_msg'] = implode(PHP_EOL, $result);
  65. } else {
  66. $_SESSION['ok_msg'] = htmlspecialchars($app) . " App was installed succesfully !";
  67. header('Location: /add/webapp/?domain=' . $v_domain);
  68. exit();
  69. }
  70. } catch (Exception $e) {
  71. $_SESSION['error_msg'] = $e->getMessage();
  72. header('Location: /add/webapp/?app='.rawurlencode($app).'&domain=' . $v_domain);
  73. exit();
  74. }
  75. }
  76. }
  77. if(!empty($installer)) {
  78. render_page($user, $TAB, 'setup_webapp');
  79. } else {
  80. render_page($user, $TAB, 'add_webapp');
  81. }
  82. // Flush session messages
  83. unset($_SESSION['error_msg']);
  84. unset($_SESSION['ok_msg']);