index.php 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. <?php
  2. error_reporting(NULL);
  3. ob_start();
  4. $TAB = 'WEB';
  5. // Main include
  6. include($_SERVER['DOCUMENT_ROOT']."/inc/main.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.2', 'thumbnail'=>'/images/webapps/wp-thumb.png' ],
  29. [ 'name'=>'Drupal', 'group'=>'cms', 'enabled'=>false,'version'=>'1.2.3', 'thumbnail'=>'/images/webapps/drupal-thumb.png' ],
  30. [ 'name'=>'Joomla', 'group'=>'cms', 'enabled'=>false,'version'=>'1.2.3', '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.0', 'thumbnail'=>'/images/webapps/prestashop-thumb.png' ],
  33. [ 'name'=>'Magento', 'group'=>'ecommerce', 'enabled'=>false, 'version'=>'1.2.3', '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. require 'installer.php';
  40. try {
  41. $hestia = new HestiaApp();
  42. $installer = new AppInstaller($_GET['app'], $v_domain, $hestia);
  43. } catch (Exception $e) {
  44. $_SESSION['error_msg'] = $e->getMessage();
  45. header('Location: /add/webapp/?domain=' . $v_domain);
  46. exit();
  47. }
  48. $GLOBALS['WebappInstaller'] = $installer;
  49. }
  50. // Check POST request
  51. if (!empty($_POST['ok']) && !empty($_GET['app']) ) {
  52. // Check token
  53. if ((!isset($_POST['token'])) || ($_SESSION['token'] != $_POST['token'])) {
  54. header('location: /login/');
  55. exit();
  56. }
  57. if ($installer) {
  58. try{
  59. if (!$installer->execute($_POST)){
  60. $result = $installer->getStatus();
  61. $_SESSION['error_msg'] = implode(PHP_EOL, $result);
  62. } else {
  63. $_SESSION['ok_msg'] = htmlspecialchars($_GET['app']) . " App was installed succesfully !";
  64. header('Location: /add/webapp/?domain=' . $v_domain);
  65. exit();
  66. }
  67. } catch (Exception $e) {
  68. $_SESSION['error_msg'] = $e->getMessage();
  69. header('Location: /add/webapp/?app='.rawurlencode($_GET['app']).'&domain=' . $v_domain);
  70. exit();
  71. }
  72. }
  73. }
  74. if($installer) {
  75. render_page($user, $TAB, 'setup_webapp');
  76. } else {
  77. render_page($user, $TAB, 'add_webapp');
  78. }
  79. // Flush session messages
  80. unset($_SESSION['error_msg']);
  81. unset($_SESSION['ok_msg']);