first
This commit is contained in:
60
wp-content/plugins/query-monitor/output/raw/cache.php
Normal file
60
wp-content/plugins/query-monitor/output/raw/cache.php
Normal file
@ -0,0 +1,60 @@
|
||||
<?php declare(strict_types = 1);
|
||||
/**
|
||||
* Raw cache output.
|
||||
*
|
||||
* @package query-monitor
|
||||
*/
|
||||
|
||||
class QM_Output_Raw_Cache extends QM_Output_Raw {
|
||||
|
||||
/**
|
||||
* Collector instance.
|
||||
*
|
||||
* @var QM_Collector_Cache Collector.
|
||||
*/
|
||||
protected $collector;
|
||||
|
||||
/**
|
||||
* @return string
|
||||
*/
|
||||
public function name() {
|
||||
return __( 'Object Cache', 'query-monitor' );
|
||||
}
|
||||
|
||||
/**
|
||||
* @return array<string, mixed>
|
||||
*/
|
||||
public function get_output() {
|
||||
$output = array(
|
||||
'hit_percentage' => null,
|
||||
'hits' => null,
|
||||
'misses' => null,
|
||||
);
|
||||
|
||||
/** @var QM_Data_Cache $data */
|
||||
$data = $this->collector->get_data();
|
||||
|
||||
if ( ! empty( $data->stats ) && ! empty( $data->cache_hit_percentage ) ) {
|
||||
$output['hit_percentage'] = round( $data->cache_hit_percentage, 1 );
|
||||
$output['hits'] = (int) $data->stats['cache_hits'];
|
||||
$output['misses'] = (int) $data->stats['cache_misses'];
|
||||
}
|
||||
|
||||
return $output;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param array<string, QM_Output> $output
|
||||
* @param QM_Collectors $collectors
|
||||
* @return array<string, QM_Output>
|
||||
*/
|
||||
function register_qm_output_raw_cache( array $output, QM_Collectors $collectors ) {
|
||||
$collector = QM_Collectors::get( 'cache' );
|
||||
if ( $collector ) {
|
||||
$output['cache'] = new QM_Output_Raw_Cache( $collector );
|
||||
}
|
||||
return $output;
|
||||
}
|
||||
|
||||
add_filter( 'qm/outputter/raw', 'register_qm_output_raw_cache', 30, 2 );
|
47
wp-content/plugins/query-monitor/output/raw/conditionals.php
Normal file
47
wp-content/plugins/query-monitor/output/raw/conditionals.php
Normal file
@ -0,0 +1,47 @@
|
||||
<?php declare(strict_types = 1);
|
||||
/**
|
||||
* Raw conditionals output.
|
||||
*
|
||||
* @package query-monitor
|
||||
*/
|
||||
|
||||
class QM_Output_Raw_Conditionals extends QM_Output_Raw {
|
||||
|
||||
/**
|
||||
* Collector instance.
|
||||
*
|
||||
* @var QM_Collector_Conditionals Collector.
|
||||
*/
|
||||
protected $collector;
|
||||
|
||||
/**
|
||||
* @return string
|
||||
*/
|
||||
public function name() {
|
||||
return __( 'Conditionals', 'query-monitor' );
|
||||
}
|
||||
|
||||
/**
|
||||
* @return mixed
|
||||
*/
|
||||
public function get_output() {
|
||||
$data = $this->collector->get_data();
|
||||
|
||||
return $data->conds['true'];
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param array<string, QM_Output> $output
|
||||
* @param QM_Collectors $collectors
|
||||
* @return array<string, QM_Output>
|
||||
*/
|
||||
function register_qm_output_raw_conditionals( array $output, QM_Collectors $collectors ) {
|
||||
$collector = QM_Collectors::get( 'conditionals' );
|
||||
if ( $collector ) {
|
||||
$output['conditionals'] = new QM_Output_Raw_Conditionals( $collector );
|
||||
}
|
||||
return $output;
|
||||
}
|
||||
|
||||
add_filter( 'qm/outputter/raw', 'register_qm_output_raw_conditionals', 20, 2 );
|
139
wp-content/plugins/query-monitor/output/raw/db_queries.php
Normal file
139
wp-content/plugins/query-monitor/output/raw/db_queries.php
Normal file
@ -0,0 +1,139 @@
|
||||
<?php declare(strict_types = 1);
|
||||
/**
|
||||
* Raw database query output.
|
||||
*
|
||||
* @package query-monitor
|
||||
*/
|
||||
|
||||
class QM_Output_Raw_DB_Queries extends QM_Output_Raw {
|
||||
|
||||
/**
|
||||
* Collector instance.
|
||||
*
|
||||
* @var QM_Collector_DB_Queries Collector.
|
||||
*/
|
||||
protected $collector;
|
||||
|
||||
/**
|
||||
* @var int
|
||||
*/
|
||||
public $query_row = 0;
|
||||
|
||||
/**
|
||||
* @return string
|
||||
*/
|
||||
public function name() {
|
||||
return __( 'Database Queries', 'query-monitor' );
|
||||
}
|
||||
|
||||
/**
|
||||
* @return array<string, mixed>
|
||||
*/
|
||||
public function get_output() {
|
||||
$output = array();
|
||||
/** @var QM_Data_DB_Queries $data */
|
||||
$data = $this->collector->get_data();
|
||||
|
||||
if ( empty( $data->wpdb ) ) {
|
||||
return $output;
|
||||
}
|
||||
|
||||
$output['wpdb'] = $this->output_queries( $data->wpdb );
|
||||
|
||||
if ( ! empty( $data->errors ) ) {
|
||||
$output['errors'] = array(
|
||||
'total' => count( $data->errors ),
|
||||
'errors' => $data->errors,
|
||||
);
|
||||
}
|
||||
|
||||
if ( ! empty( $data->dupes ) ) {
|
||||
$dupes = $data->dupes;
|
||||
|
||||
// Filter out SQL queries that do not have dupes
|
||||
$dupes = array_filter( $dupes, array( $this->collector, 'filter_dupe_items' ) );
|
||||
|
||||
// Ignore dupes from `WP_Query->set_found_posts()`
|
||||
unset( $dupes['SELECT FOUND_ROWS()'] );
|
||||
|
||||
$output['dupes'] = array(
|
||||
'total' => count( $dupes ),
|
||||
'queries' => $dupes,
|
||||
);
|
||||
}
|
||||
|
||||
return $output;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param stdClass $db
|
||||
* @return array
|
||||
* @phpstan-return array{
|
||||
* total: int,
|
||||
* time: float,
|
||||
* queries: mixed[],
|
||||
* }|array{}
|
||||
*/
|
||||
protected function output_queries( stdClass $db ) {
|
||||
$this->query_row = 0;
|
||||
|
||||
$output = array();
|
||||
|
||||
if ( empty( $db->rows ) ) {
|
||||
return $output;
|
||||
}
|
||||
|
||||
foreach ( $db->rows as $row ) {
|
||||
$output[] = $this->output_query_row( $row );
|
||||
}
|
||||
|
||||
return array(
|
||||
'total' => $db->total_qs,
|
||||
'time' => round( $db->total_time, 4 ),
|
||||
'queries' => $output,
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param array<string, mixed> $row
|
||||
* @return array<string, mixed>
|
||||
*/
|
||||
protected function output_query_row( array $row ) {
|
||||
$output = array();
|
||||
|
||||
$output['i'] = ++$this->query_row;
|
||||
$output['sql'] = $row['sql'];
|
||||
$output['time'] = round( $row['ltime'], 4 );
|
||||
|
||||
if ( isset( $row['trace'] ) ) {
|
||||
$stack = array();
|
||||
$filtered_trace = $row['trace']->get_filtered_trace();
|
||||
|
||||
foreach ( $filtered_trace as $item ) {
|
||||
$stack[] = $item['display'];
|
||||
}
|
||||
} else {
|
||||
$stack = $row['stack'];
|
||||
}
|
||||
|
||||
$output['stack'] = $stack;
|
||||
$output['result'] = $row['result'];
|
||||
|
||||
return $output;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param array<string, QM_Output> $output
|
||||
* @param QM_Collectors $collectors
|
||||
* @return array<string, QM_Output>
|
||||
*/
|
||||
function register_qm_output_raw_db_queries( array $output, QM_Collectors $collectors ) {
|
||||
$collector = QM_Collectors::get( 'db_queries' );
|
||||
if ( $collector ) {
|
||||
$output['db_queries'] = new QM_Output_Raw_DB_Queries( $collector );
|
||||
}
|
||||
return $output;
|
||||
}
|
||||
|
||||
add_filter( 'qm/outputter/raw', 'register_qm_output_raw_db_queries', 20, 2 );
|
75
wp-content/plugins/query-monitor/output/raw/http.php
Normal file
75
wp-content/plugins/query-monitor/output/raw/http.php
Normal file
@ -0,0 +1,75 @@
|
||||
<?php declare(strict_types = 1);
|
||||
/**
|
||||
* Raw HTTP API request output.
|
||||
*
|
||||
* @package query-monitor
|
||||
*/
|
||||
|
||||
class QM_Output_Raw_HTTP extends QM_Output_Raw {
|
||||
|
||||
/**
|
||||
* Collector instance.
|
||||
*
|
||||
* @var QM_Collector_HTTP Collector.
|
||||
*/
|
||||
protected $collector;
|
||||
|
||||
/**
|
||||
* @return string
|
||||
*/
|
||||
public function name() {
|
||||
return __( 'HTTP API Calls', 'query-monitor' );
|
||||
}
|
||||
|
||||
/**
|
||||
* @return array<string, mixed>
|
||||
*/
|
||||
public function get_output() {
|
||||
$output = array();
|
||||
/** @var QM_Data_HTTP $data */
|
||||
$data = $this->collector->get_data();
|
||||
|
||||
if ( empty( $data->http ) ) {
|
||||
return $output;
|
||||
}
|
||||
|
||||
$requests = array();
|
||||
|
||||
foreach ( $data->http as $http ) {
|
||||
$stack = array();
|
||||
|
||||
foreach ( $http['filtered_trace'] as $item ) {
|
||||
$stack[] = $item['display'];
|
||||
}
|
||||
|
||||
$requests[] = array(
|
||||
'url' => $http['url'],
|
||||
'method' => $http['args']['method'],
|
||||
'response' => ( $http['response'] instanceof WP_Error ) ? $http['response']->get_error_message() : $http['response']['response'],
|
||||
'time' => round( $http['ltime'], 4 ),
|
||||
'stack' => $stack,
|
||||
);
|
||||
}
|
||||
|
||||
$output['total'] = count( $requests );
|
||||
$output['time'] = round( $data->ltime, 4 );
|
||||
$output['requests'] = $requests;
|
||||
|
||||
return $output;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param array<string, QM_Output> $output
|
||||
* @param QM_Collectors $collectors
|
||||
* @return array<string, QM_Output>
|
||||
*/
|
||||
function register_qm_output_raw_http( array $output, QM_Collectors $collectors ) {
|
||||
$collector = QM_Collectors::get( 'http' );
|
||||
if ( $collector ) {
|
||||
$output['http'] = new QM_Output_Raw_HTTP( $collector );
|
||||
}
|
||||
return $output;
|
||||
}
|
||||
|
||||
add_filter( 'qm/outputter/raw', 'register_qm_output_raw_http', 30, 2 );
|
64
wp-content/plugins/query-monitor/output/raw/logger.php
Normal file
64
wp-content/plugins/query-monitor/output/raw/logger.php
Normal file
@ -0,0 +1,64 @@
|
||||
<?php declare(strict_types = 1);
|
||||
/**
|
||||
* Raw logger output.
|
||||
*
|
||||
* @package query-monitor
|
||||
*/
|
||||
|
||||
class QM_Output_Raw_Logger extends QM_Output_Raw {
|
||||
|
||||
/**
|
||||
* Collector instance.
|
||||
*
|
||||
* @var QM_Collector_Logger Collector.
|
||||
*/
|
||||
protected $collector;
|
||||
|
||||
/**
|
||||
* @return string
|
||||
*/
|
||||
public function name() {
|
||||
return __( 'Logs', 'query-monitor' );
|
||||
}
|
||||
|
||||
/**
|
||||
* @return array<string, array<int, array<string, mixed>>>
|
||||
* @phpstan-return array<QM_Collector_Logger::*, list<array{
|
||||
* message: string,
|
||||
* stack: list<string>,
|
||||
* }>>
|
||||
*/
|
||||
public function get_output() {
|
||||
$output = array();
|
||||
/** @var QM_Data_Logger $data */
|
||||
$data = $this->collector->get_data();
|
||||
|
||||
if ( empty( $data->logs ) ) {
|
||||
return $output;
|
||||
}
|
||||
|
||||
foreach ( $data->logs as $log ) {
|
||||
$output[ $log['level'] ][] = array(
|
||||
'message' => $log['message'],
|
||||
'stack' => array_column( $log['filtered_trace'], 'display' ),
|
||||
);
|
||||
}
|
||||
|
||||
return $output;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param array<string, QM_Output> $output
|
||||
* @param QM_Collectors $collectors
|
||||
* @return array<string, QM_Output>
|
||||
*/
|
||||
function register_qm_output_raw_logger( array $output, QM_Collectors $collectors ) {
|
||||
$collector = QM_Collectors::get( 'logger' );
|
||||
if ( $collector ) {
|
||||
$output['logger'] = new QM_Output_Raw_Logger( $collector );
|
||||
}
|
||||
return $output;
|
||||
}
|
||||
|
||||
add_filter( 'qm/outputter/raw', 'register_qm_output_raw_logger', 30, 2 );
|
73
wp-content/plugins/query-monitor/output/raw/transients.php
Normal file
73
wp-content/plugins/query-monitor/output/raw/transients.php
Normal file
@ -0,0 +1,73 @@
|
||||
<?php declare(strict_types = 1);
|
||||
/**
|
||||
* Raw transients output.
|
||||
*
|
||||
* @package query-monitor
|
||||
*/
|
||||
|
||||
class QM_Output_Raw_Transients extends QM_Output_Raw {
|
||||
|
||||
/**
|
||||
* Collector instance.
|
||||
*
|
||||
* @var QM_Collector_Transients Collector.
|
||||
*/
|
||||
protected $collector;
|
||||
|
||||
/**
|
||||
* @return string
|
||||
*/
|
||||
public function name() {
|
||||
return __( 'Transients', 'query-monitor' );
|
||||
}
|
||||
|
||||
/**
|
||||
* @return array<string, mixed>
|
||||
*/
|
||||
public function get_output() {
|
||||
$output = array();
|
||||
$data = $this->collector->get_data();
|
||||
|
||||
if ( empty( $data->trans ) ) {
|
||||
return $output;
|
||||
}
|
||||
|
||||
$transients = array();
|
||||
|
||||
foreach ( $data->trans as $transient ) {
|
||||
$stack = array();
|
||||
|
||||
foreach ( $transient['filtered_trace'] as $frame ) {
|
||||
$stack[] = $frame['display'];
|
||||
}
|
||||
|
||||
$transients[] = array(
|
||||
'name' => $transient['name'],
|
||||
'type' => $transient['type'],
|
||||
'size' => $transient['size_formatted'],
|
||||
'expiration' => $transient['expiration'],
|
||||
'stack' => $stack,
|
||||
);
|
||||
}
|
||||
|
||||
$output['total'] = count( $transients );
|
||||
$output['transients'] = $transients;
|
||||
|
||||
return $output;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param array<string, QM_Output> $output
|
||||
* @param QM_Collectors $collectors
|
||||
* @return array<string, QM_Output>
|
||||
*/
|
||||
function register_qm_output_raw_transients( array $output, QM_Collectors $collectors ) {
|
||||
$collector = QM_Collectors::get( 'transients' );
|
||||
if ( $collector ) {
|
||||
$output['transients'] = new QM_Output_Raw_Transients( $collector );
|
||||
}
|
||||
return $output;
|
||||
}
|
||||
|
||||
add_filter( 'qm/outputter/raw', 'register_qm_output_raw_transients', 30, 2 );
|
Reference in New Issue
Block a user