AppContext.php 9.6 KB

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