/var/www/html_it/wp-content/plugins/query-monitor/collectors/db_callers.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
<?php declare(strict_types 1);
/**
 * Database query calling function collector.
 *
 * @package query-monitor
 */

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

/**
 * @extends QM_DataCollector<QM_Data_DB_Callers>
 */
class QM_Collector_DB_Callers extends QM_DataCollector {

    public 
$id 'db_callers';

    public function 
get_storage(): QM_Data {
        return new 
QM_Data_DB_Callers();
    }

    
/**
     * @return void
     */
    
public function process() {
        
/** @var QM_Collector_DB_Queries|null $dbq */
        
$dbq QM_Collectors::get'db_queries' );

        if ( 
$dbq ) {
            
/** @var QM_Data_DB_Queries $dbq_data */
            
$dbq_data $dbq->get_data();

            
$this->data->times $dbq_data->times;
            
QM_Util::rsort$this->data->times'ltime' );

            
$this->data->types $dbq_data->types;
        }

    }

}

/**
 * @param array<string, QM_Collector> $collectors
 * @param QueryMonitor $qm
 * @return array<string, QM_Collector>
 */
function register_qm_collector_db_callers( array $collectorsQueryMonitor $qm ) {
    
$collectors['db_callers'] = new QM_Collector_DB_Callers();
    return 
$collectors;
}

add_filter'qm/collectors''register_qm_collector_db_callers'20);