logger.php
59 lines
| 1 | <?php |
| 2 | |
| 3 | |
| 4 | namespace Jet_Form_Builder\Dev_Mode; |
| 5 | |
| 6 | |
| 7 | use Jet_Form_Builder\Classes\Instance_Trait; |
| 8 | use Jet_Form_Builder\Exceptions\Handler_Exception; |
| 9 | use Jet_Form_Builder\Plugin; |
| 10 | |
| 11 | class Logger { |
| 12 | |
| 13 | private $logged = array(); |
| 14 | |
| 15 | use Instance_Trait; |
| 16 | |
| 17 | private function __construct() { |
| 18 | //$this->run_engine_debugger(); |
| 19 | } |
| 20 | |
| 21 | public function run_engine_debugger() { |
| 22 | add_action( 'jet-engine/forms/handler/query-args', function ( $query_args, $args, $handler ) { |
| 23 | if ( ! $handler->is_ajax() ) { |
| 24 | return $query_args; |
| 25 | } |
| 26 | $query_args['__jfb_logger'] = $this->get_logs(); |
| 27 | |
| 28 | return $query_args; |
| 29 | }, 10, 3 ); |
| 30 | } |
| 31 | |
| 32 | public function log( Handler_Exception $exception ) { |
| 33 | if ( ! Manager::instance()->active() ) { |
| 34 | return; |
| 35 | } |
| 36 | $this->save_log( $exception ); |
| 37 | } |
| 38 | |
| 39 | public function get_logs() { |
| 40 | return $this->logged; |
| 41 | } |
| 42 | |
| 43 | private function save_log( Handler_Exception $exception ) { |
| 44 | $this->logged[ get_class( $exception ) ][] = array( |
| 45 | 'message' => $exception->getMessage(), |
| 46 | 'file' => $this->make_pretty_filename( $exception->getFile() ), |
| 47 | 'line' => $exception->getLine(), |
| 48 | 'data' => $exception->get_additional() |
| 49 | ); |
| 50 | } |
| 51 | |
| 52 | private function make_pretty_filename( $file ) { |
| 53 | $path = explode( 'plugins\\', $file ); |
| 54 | |
| 55 | return isset( $path[1] ) ? $path[1] : explode( 'plugins/', $file )[1]; |
| 56 | } |
| 57 | |
| 58 | |
| 59 | } |