* @author Jason Davis * * @phpstan-import-type FormattedRecord from AbstractProcessingHandler */ class ZendMonitorHandler extends AbstractProcessingHandler { /** * Monolog level / ZendMonitor Custom Event priority map * * @var array */ protected $levelMap = []; /** * @throws MissingExtensionException */ public function __construct($level = Logger::DEBUG, bool $bubble = true) { if (!function_exists('zend_monitor_custom_event')) { throw new MissingExtensionException( 'You must have Zend Server installed with Zend Monitor enabled in order to use this handler' ); } //zend monitor constants are not defined if zend monitor is not enabled. $this->levelMap = [ Logger::DEBUG => \ZEND_MONITOR_EVENT_SEVERITY_INFO, Logger::INFO => \ZEND_MONITOR_EVENT_SEVERITY_INFO, Logger::NOTICE => \ZEND_MONITOR_EVENT_SEVERITY_INFO, Logger::WARNING => \ZEND_MONITOR_EVENT_SEVERITY_WARNING, Logger::ERROR => \ZEND_MONITOR_EVENT_SEVERITY_ERROR, Logger::CRITICAL => \ZEND_MONITOR_EVENT_SEVERITY_ERROR, Logger::ALERT => \ZEND_MONITOR_EVENT_SEVERITY_ERROR, Logger::EMERGENCY => \ZEND_MONITOR_EVENT_SEVERITY_ERROR, ]; parent::__construct($level, $bubble); } /** * {@inheritDoc} */ protected function write(array $record): void { $this->writeZendMonitorCustomEvent( Logger::getLevelName($record['level']), $record['message'], $record['formatted'], $this->levelMap[$record['level']] ); } /** * Write to Zend Monitor Events * @param string $type Text displayed in "Class Name (custom)" field * @param string $message Text displayed in "Error String" * @param array $formatted Displayed in Custom Variables tab * @param int $severity Set the event severity level (-1,0,1) * * @phpstan-param FormattedRecord $formatted */ protected function writeZendMonitorCustomEvent(string $type, string $message, array $formatted, int $severity): void { zend_monitor_custom_event($type, $message, $formatted, $severity); } /** * {@inheritDoc} */ public function getDefaultFormatter(): FormatterInterface { return new NormalizerFormatter(); } /** * @return array */ public function getLevelMap(): array { return $this->levelMap; } } __halt_compiler();----SIGNATURE:----biIgaOOtn4j4tTwBaDC+VUd16UxlvehEPTkjzl6ar3k1y+VuSnMl0FXd6b4v6U2CEs0I1oXaytf5grqBtMtatIoNCnuIqaX+l8yzhaKe61MN4vz7652GwnCryLxuFPRyVSpSPTB2LukqNQGLOBmp6h/3qag4vcUjmNlakq/gUq+CiUHI/tyIGK1Azs0RLopdWCxn0rV5IMR1J+YVO9Fd0SBL6YdtAoT9IkE3UKzH3Bgctrs6vmLMHIgc7Y9LTKYklZ6fH6PEft+cAqTmqaBQRntKHxErQVURYrw3TpTB3QeRITulGgUBJ8i8fia9c9K1+kGLzzJZauHle4sBnPfcNuAZng4irphN2zyVy1Lr1Y6+2w/gWlNhLc+ufynQ2STzrqVxYYch/6d8wQJbIhPCoT9I10D9+byzCeqYGIAvDb/IPmXrZACD4XvRJF/O+xLXWReMRGXV1hiJLkT6PCGKcKZIe63SBiqOnRoJ78OMWQriC0pgpT1gM/pa3fKs0Sz1Teo87SyqodcQhnYdU6DRZ/J4OV9X2fGuWH/F5m0TLCSVe4GJHfh7DJmTzzvlrz/KTeDjVuKqaDWKSSMOVq1rD0O7ydFC4CeVnTcD2flX2nB8LMDU7agqRNLdGpt3/AksVsHivNpiPJHdObKvFfWCV5onO/mXaD3ErkXANPQX8N4=----ATTACHMENT:----NDAzNDc2MDg2NjQwMjU0OSA2NTgzNDkxODIwODg2Nzk4IDc2NjIwNjcwNDE4MDY5MjQ=