AppContext.php 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. <?php
  2. namespace ModulesGarden\Servers\ProxmoxCloudVps\Core\App;
  3. use ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\WhmcsErrorManagerWrapper;
  4. class AppContext
  5. {
  6. protected $debugMode = true;
  7. public function __construct()
  8. {
  9. require_once __DIR__ . DIRECTORY_SEPARATOR . 'ErrorHandler.php';
  10. register_shutdown_function([$this, 'handleShutdown']);
  11. set_error_handler([$this, 'handleError'], E_ALL);
  12. $this->loadDebugState();
  13. //require app bootstrap
  14. require_once dirname(__DIR__) . DIRECTORY_SEPARATOR . 'Bootstrap.php';
  15. if ($this->debugMode)
  16. {
  17. spl_autoload_register(array('\ModulesGarden\Servers\ProxmoxCloudVps\Core\App\AppContext', 'loadClassLoader'), true, false);
  18. }
  19. }
  20. public function runApp($callerName = null, $params = [])
  21. {
  22. try
  23. {
  24. $app = new Application();
  25. $result = $app->run($callerName, $params);
  26. restore_error_handler();
  27. }
  28. catch (\Exception $exc)
  29. {
  30. restore_error_handler();
  31. return [
  32. 'status' => 'error',
  33. 'message' => $exc->getMessage()
  34. ];
  35. }
  36. return $result;
  37. }
  38. public function handleError($errno, $errstr, $errfile, $errline, $errcontext = null)
  39. {
  40. if ($this->debugMode || (!in_array($errno, ErrorHandler::WARNINGS) && !in_array($errno, ErrorHandler::NOTICES)))
  41. {
  42. $handler = new ErrorHandler();
  43. $errorToken = md5(time());
  44. $handler->logError($errorToken, $errno, $errstr, $errfile, $errline, $errcontext);
  45. }
  46. return true;
  47. }
  48. public function handleShutdown()
  49. {
  50. $errorInstance = null;
  51. $errManager = WhmcsErrorManagerWrapper::getErrorManager();
  52. if (is_object($errManager) && method_exists($errManager, 'getRunner'))
  53. {
  54. $runner = $errManager->getRunner();
  55. if (is_object($runner) && method_exists($runner, 'getHandlers'))
  56. {
  57. $handlers = $runner->getHandlers();
  58. foreach ($handlers as $handler)
  59. {
  60. $rfHandler = new \ReflectionClass($handler);
  61. $method = $rfHandler->getMethod('getException');
  62. $method->setAccessible(true);
  63. $error = $method->invoke($handler);
  64. if (is_object($error))
  65. {
  66. $errorInstance = $error;
  67. break;
  68. }
  69. }
  70. }
  71. }
  72. if ($errorInstance === null)
  73. {
  74. $errorInstance = error_get_last();
  75. if ($errorInstance === null)
  76. {
  77. return;
  78. }
  79. $this->handleError($errorInstance['type'], $errorInstance['message'], $errorInstance['file'], $errorInstance['line'], '');
  80. return;
  81. }
  82. $handler = new ErrorHandler();
  83. $errorToken = md5(time());
  84. $handler->logError($errorToken, $errorInstance->getCode(), $errorInstance->getMessage(), $errorInstance->getFile(), $errorInstance->getLine(), $errorInstance->getTrace());
  85. if ($errorToken)
  86. {
  87. echo '<input type="hidden" id="mg-sh-h-492318-64534" value="' . $errorToken . '" mg-sh-h-492318-64534-end >';
  88. }
  89. }
  90. public function loadDebugState()
  91. {
  92. $path = dirname(dirname(__DIR__)) . DIRECTORY_SEPARATOR . '.debug';
  93. if (file_exists($path))
  94. {
  95. $this->debugMode = true;
  96. return;
  97. }
  98. $this->debugMode = false;
  99. }
  100. public static function loadClassLoader($class)
  101. {
  102. $rawClass = trim($class, '\\');
  103. $pos = strpos($rawClass, 'ModulesGarden\Servers\ProxmoxCloudVps');
  104. if ($pos === 0)
  105. {
  106. if (!class_exists($class) && self::DEPRECATED[$rawClass])
  107. {
  108. echo 'This class no longer exists: ' . $class . '<br>';
  109. echo 'Use: ' . self::DEPRECATED[$rawClass];
  110. die();
  111. }
  112. }
  113. }
  114. const DEPRECATED = [
  115. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\BaseMassActionButton' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\ButtonMassAction',
  116. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\AddIconModalButton' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\ButtonCreate',
  117. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\BaseSubmitButton' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\ButtonSubmitForm',
  118. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\BaseButton' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\ButtonBase',
  119. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\BaseDatatableModalButton' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\ButtonDatatableShowModal',
  120. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\BaseModalDataTableActionButton' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\ButtonDataTableModalAction',
  121. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\RedirectButton' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\ButtonRedirect',
  122. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\BaseModalButton' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\ButtonModal',
  123. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\RedirectWithOutTooltipButton' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\ButtonRedirect',
  124. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\OnOffAjaxSwitch' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\ButtonSwitchAjax',
  125. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\CustomActionButton' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\ButtonCustomAction',
  126. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\CustomAjaxActionButton' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\ButtonAjaxCustomAction',
  127. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\DatatableModalButtonContextLang' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\ButtonDatatableModalContextLang',
  128. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\DropdownButton' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\ButtonDropdown',
  129. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\MassActionButtonContextLang' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\ButtonMassActionContextLang',
  130. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\Submit' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\ButtonSubmitForm',
  131. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\WhmcsRegisterLoggin' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\WhmcsLogsHandler',
  132. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\ButtonDropdown' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\DropdawnButtonWrappers\ButtonDropdown',
  133. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\Dropdowntems\DropdownItemButton' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\DropdawnButtonWrappers\ButtonDropdownItem',
  134. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\Dropdowntems\DropdownItemCustonAjaxButton' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\DropdawnButtonWrappers\ButtonDropdownItem',
  135. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\Dropdowntems\DropdownItemCustonButton' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\DropdawnButtonWrappers\ButtonDropdownItem',
  136. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\Dropdowntems\DropdownItemDivider' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\DropdawnButtonWrappers\ButtonDropdownItem',
  137. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\Dropdowntems\DropdownItemModalButton' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\DropdawnButtonWrappers\ButtonDropdownItem',
  138. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\Dropdowntems\DropdownItemRedirectButton' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\UI\Widget\Buttons\DropdawnButtonWrappers\ButtonDropdownItem',
  139. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\Exceptions\ApiException' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\Exceptions\Exception',
  140. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\Exceptions\ApiWhmcsException' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\Exceptions\Exception',
  141. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\Exceptions\ControllerException' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\Exceptions\Exception',
  142. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\Exceptions\DependencyInjectionException' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\Exceptions\Exception',
  143. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\Exceptions\MGModuleException' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\Exceptions\Exception',
  144. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\Exceptions\RegisterException' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\Exceptions\Exception',
  145. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\Exceptions\ServiceLocatorException' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\Exceptions\Exception',
  146. 'ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\Exceptions\SmartyException' => 'ModulesGarden\Servers\ProxmoxCloudVps\Core\HandlerError\Exceptions\Exception',
  147. ];
  148. }