SILENT KILLERPanel

Current Path: > home > transcarter > > www > wp-content > plugins > query-monitor > output > raw


Operation   : Linux host59.registrar-servers.com 4.18.0-513.18.1.lve.2.el8.x86_64 #1 SMP Sat Mar 30 15:36:11 UTC 2024 x86_64
Software     : Apache
Server IP    : 198.54.126.42 | Your IP: 216.73.216.135
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: /home/transcarter//www/wp-content/plugins/query-monitor/output/raw

NameTypeSizeLast ModifiedActions
cache.php File 1316 bytes July 17 2025 21:05:45.
conditionals.php File 974 bytes July 17 2025 21:05:45.
db_queries.php File 2721 bytes July 17 2025 21:05:45.
http.php File 1633 bytes July 17 2025 21:05:45.
logger.php File 1365 bytes July 17 2025 21:05:45.
transients.php File 1524 bytes July 17 2025 21:05:45.

Reading File: /home/transcarter//www/wp-content/plugins/query-monitor/output/raw/db_queries.php

<?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>
	 * @phpstan-return array{
	 *   total: int,
	 *   time: float,
	 *   queries: mixed[],
	 *   errors?: array{
	 *     total: int,
	 *     errors: array<int, array<string, mixed>>,
	 *   },
	 *   dupes?: array{
	 *     total: int,
	 *     queries: array<string, int[]>,
	 *   },
	 * }|array{}
	 */
	public function get_output() {
		/** @var QM_Data_DB_Queries $data */
		$data = $this->collector->get_data();

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

		$output = array(
			'total' => $data->total_qs,
			'time' => round( $data->total_time, 4 ),
			'queries' => array_map( array( $this, 'output_query_row' ), $data->rows ),
		);

		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 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 );

SILENT KILLER Tool