Current File : /home/escuelai/public_html/wp-content/plugins/w3-total-cache/UsageStatistics_Sources.php
<?php
/**
 * File: UsageStatistics_Sources.php
 *
 * @package W3TC
 */

namespace W3TC;

/**
 * Class UsageStatistics_Sources
 */
class UsageStatistics_Sources {
	/**
	 * Generates a summary of usage statistics based on historical data.
	 *
	 * This method processes the provided usage history and compiles statistics for various sources, including
	 * PHP, APC, Memcached, Redis, CPU, and access logs.The summary is populated with the relevant metrics for
	 * each source, such as memory usage, request counts, and CPU averages. It is designed to be used for
	 * generating a comprehensive view of the system's resource usage over time.
	 *
	 * @param array $summary   The current summary to be updated with usage statistics.
	 * @param array $history   The historical data to process for generating the summary.
	 *
	 * @return array The updated summary with the compiled usage statistics.
	 */
	public static function w3tc_usage_statistics_summary_from_history( $summary, $history ) {
		// php data.
		$php_memory_100kb = Util_UsageStatistics::sum( $history, 'php_memory_100kb' );
		$php_requests     = Util_UsageStatistics::sum( $history, 'php_requests' );

		if ( $php_requests > 0 ) {
			if ( ! isset( $summary['php'] ) ) {
				$summary['php'] = array();
			}

			$summary['php']['memory']                  = Util_UsageStatistics::bytes_to_size( $php_memory_100kb / $php_requests * 1024 * 10.24 );
			$summary['php']['php_requests_v']          = $php_requests;
			$summary['php']['php_requests']            = Util_UsageStatistics::integer( $php_requests );
			$summary['php']['php_requests_per_second'] = Util_UsageStatistics::value_per_period_seconds( $php_requests, $summary );
		}

		// apc.
		if ( count( $summary['apc_servers'] ) > 0 ) {
			$apc            = new UsageStatistics_Sources_Apc( $summary['apc_servers'] );
			$summary['apc'] = $apc->get_summary();
		}

		// memcached.
		if ( count( $summary['memcached_servers'] ) > 0 ) {
			$memcached            = new UsageStatistics_Sources_Memcached( $summary['memcached_servers'] );
			$summary['memcached'] = $memcached->get_summary();
		}

		// redis.
		if ( count( $summary['redis_servers'] ) > 0 ) {
			$redis            = new UsageStatistics_Sources_Redis( $summary['redis_servers'] );
			$summary['redis'] = $redis->get_summary();
		}

		// cpu snapshot.
		$c = Dispatcher::config();
		if ( $c->get_boolean( 'stats.cpu.enabled' ) ) {
			$summary['cpu'] = array(
				'avg' => round( Util_UsageStatistics::avg( $history, 'cpu' ), 2 ),
			);
		}

		// access log data.
		if ( $c->get_boolean( 'stats.access_log.enabled' ) ) {
			$o = new UsageStatistics_Source_AccessLog(
				array(
					'webserver' => $c->get_string( 'stats.access_log.webserver' ),
					'filename'  => $c->get_string( 'stats.access_log.filename' ),
					'format'    => $c->get_string( 'stats.access_log.format' ),
				)
			);

			$summary = $o->w3tc_usage_statistics_summary_from_history( $summary, $history );
		}

		return $summary;
	}

	/**
	 * Retrieves the current metric values for various usage statistics sources.
	 *
	 * This method fetches real-time data for Memcached, Redis, APC, and CPU usage. It aggregates these
	 * metrics into an array and returns it. This is useful for generating up-to-date metric snapshots.
	 *
	 * @param array $metric_values   The current metric values to be populated with real-time statistics.
	 *
	 * @return array The updated metric values with data from the available sources.
	 */
	public static function w3tc_usage_statistics_metric_values( $metric_values ) {
		$sources = array(
			'memcached_servers' => array(),
			'redis_servers'     => array(),
			'apc_servers'       => array(),
		);

		$sources = apply_filters( 'w3tc_usage_statistics_sources', $sources );

		if ( count( $sources['memcached_servers'] ) > 0 ) {
			$memcached                  = new UsageStatistics_Sources_Memcached( $sources['memcached_servers'] );
			$metric_values['memcached'] = $memcached->get_snapshot();
		}

		if ( count( $sources['apc_servers'] ) > 0 ) {
			$apc                  = new UsageStatistics_Sources_Apc( $sources['apc_servers'] );
			$metric_values['apc'] = $apc->get_snapshot();
		}

		if ( count( $sources['redis_servers'] ) > 0 ) {
			$redis                  = new UsageStatistics_Sources_Redis( $sources['redis_servers'] );
			$metric_values['redis'] = $redis->get_snapshot();
		}

		$c = Dispatcher::config();
		if ( $c->get_boolean( 'stats.cpu.enabled' ) ) {
			// cpu snapshot.
			$cpu = sys_getloadavg();
			if ( isset( $cpu[0] ) ) {
				$metric_values['cpu'] = $cpu[0];
			}
		}

		return $metric_values;
	}

	/**
	 * Sets the usage history based on the provided historical data.
	 *
	 * This method processes access log data if enabled and adds it to the history.
	 * It updates the provided history with the relevant data for future analysis or reporting.
	 *
	 * @param array $history   The history to be updated with the usage statistics.
	 *
	 * @return array The updated history with additional data.
	 */
	public static function w3tc_usage_statistics_history_set( $history ) {
		$c = Dispatcher::config();
		if ( $c->get_boolean( 'stats.access_log.enabled' ) ) {
			// read access log.
			$o = new UsageStatistics_Source_AccessLog(
				array(
					'webserver' => $c->get_string( 'stats.access_log.webserver' ),
					'filename'  => $c->get_string( 'stats.access_log.filename' ),
					'format'    => $c->get_string( 'stats.access_log.format' ),
				)
			);

			$history = $o->w3tc_usage_statistics_history_set( $history );
		}

		return $history;
	}
}