/var/www/html_it/wp-content/plugins/query-monitor/output/headers/php_errors.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
<?php declare(strict_types 1);
/**
 * PHP error output for HTTP headers.
 *
 * @package query-monitor
 */

if ( ! defined'ABSPATH' ) ) {
    exit;
}

class 
QM_Output_Headers_PHP_Errors extends QM_Output_Headers {

    
/**
     * Collector instance.
     *
     * @var QM_Collector_PHP_Errors Collector.
     */
    
protected $collector;

    
/**
     * @return array<string, mixed>
     */
    
public function get_output() {
        
/** @var QM_Data_PHP_Errors $data */
        
$data $this->collector->get_data();
        
$headers = array();

        if ( empty( 
$data->errors ) ) {
            return array();
        }

        
$count 0;

        foreach ( 
$data->errors as $type => $errors ) {

            foreach ( 
$errors as $error_key => $error ) {

                
$count++;

                
$stack = array();

                if ( ! empty( 
$error['filtered_trace'] ) ) {
                    
$stack array_column$error['filtered_trace'], 'display' );
                }

                
$output_error = array(
                    
'key' => $error_key,
                    
'type' => $error['type'],
                    
'message' => $error['message'],
                    
'file' => QM_Util::standard_dir$error['file'], '' ),
                    
'line' => $error['line'],
                    
'stack' => $stack,
                    
'component' => $error['component']->name,
                );

                
$key sprintf'error-%d'$count );
                
$headers$key ] = json_encode$output_error );

            }
        }

        return 
array_merge(
            array(
                
'count' => $count,
            ),
            
$headers
        
);
    }

}

/**
 * @param array<string, QM_Output> $output
 * @param QM_Collectors $collectors
 * @return array<string, QM_Output>
 */
function register_qm_output_headers_php_errors( array $outputQM_Collectors $collectors ) {
    
$collector QM_Collectors::get'php_errors' );
    if ( 
$collector ) {
        
$output['php_errors'] = new QM_Output_Headers_PHP_Errors$collector );
    }
    return 
$output;
}

add_filter'qm/outputter/headers''register_qm_output_headers_php_errors'110);