Пример #1
0
                $item['exc_frames'][] = $frame['args'];
            }
            $file = str_replace(dirname(dirname(dirname($e->getFile()))), "…", $e->getFile());
            $item['template'] = ($e instanceof \ErrorException ? '' : get_class($e) . ': ') . $e->getMessage() . ($e->getCode() ? ' #' . $e->getCode() : '') . ' in ' . $file . ':' . $e->getLine();
            array_unshift($trace, array('file' => $e->getFile(), 'line' => $e->getLine()));
        } else {
            $trace = debug_backtrace();
            if (isset($trace[0]['class']) && $trace[0]['class'] === __CLASS__ && ($trace[0]['function'] === '_shutdownHandler' || $trace[0]['function'] === '_errorHandler')) {
                unset($trace[0]);
            }
        }
        if (isset($args[0]) && in_array($args[0], array(self::DEBUG, self::INFO, self::WARNING, self::ERROR, self::CRITICAL), TRUE)) {
            $item['level'] = array_shift($args);
        }
        $item['args'] = $args;
        foreach ($trace as $frame) {
            if (isset($frame['file']) && is_file($frame['file'])) {
                $item['pathname'] = $frame['file'];
                $item['lineno'] = $frame['line'];
                break;
            }
        }
        $payload['logs'][] = DebugHelpers::jsonDump($item, -1);
        foreach (str_split(base64_encode(@json_encode($payload)), 4990) as $k => $v) {
            header("FireLogger-de11e-{$k}:{$v}");
        }
        return TRUE;
    }
}
Debug::_init();