Current File : /home/escuelai/www/wp-content/plugins/w3-total-cache/Cache_Memcached_Stats.php |
<?php
/**
* File: Cache_Memcached_Stats.php
*
* @package W3TC
*/
namespace W3TC;
/**
* Class Cache_Memcached_Stats
*
* Download extended statistics since module cant do it by itself
*
* phpcs:disable WordPress.PHP.NoSilencedErrors.Discouraged
* phpcs:disable WordPress.WP.AlternativeFunctions
*/
class Cache_Memcached_Stats {
/**
* Constructor to initialize the Memcached stats handler.
*
* @param string $host The hostname or IP address of the Memcached server.
* @param int $port The port number of the Memcached server.
*
* @return void
*/
public function __construct( $host, $port ) {
$this->host = $host;
$this->port = $port;
}
/**
* Sends a command to the Memcached server and retrieves the response.
*
* @param string $command The command to send to the Memcached server.
*
* @return array|null An array of response lines from the server, or null on failure.
*/
public function request( $command ) {
$handle = @fsockopen( $this->host, $this->port );
if ( ! $handle ) {
return null;
}
fwrite( $handle, $command . "\r\n" );
$response = array();
while ( ( ! feof( $handle ) ) ) {
$line = fgets( $handle );
$response[] = $line;
if ( $this->end( $line, $command ) ) {
break;
}
}
@fclose( $handle );
return $response;
}
/**
* Determines if the server response indicates the end of a command's execution.
*
* @param string $buffer The current line of the server's response.
* @param string $command The command that was sent to the server.
*
* @return bool True if the response indicates the end of the command, false otherwise.
*/
private function end( $buffer, $command ) {
// incr or decr also return integer.
if ( ( preg_match( '/^(incr|decr)/', $command ) ) ) {
if ( preg_match( '/^(END|ERROR|SERVER_ERROR|CLIENT_ERROR|NOT_FOUND|[0-9]*)/', $buffer ) ) {
return true;
}
} elseif ( preg_match( '/^(END|DELETED|OK|ERROR|SERVER_ERROR|CLIENT_ERROR|NOT_FOUND|STORED|RESET|TOUCHED)/', $buffer ) ) {
return true;
}
return false;
}
/**
* Parses the response lines into an array of data.
*
* @param array $lines An array of response lines from the Memcached server.
*
* @return array A parsed array where each line is split into words.
*/
public function parse( $lines ) {
$return = array();
foreach ( $lines as $line ) {
$data = explode( ' ', $line );
$return[] = $data;
}
return $return;
}
/**
* Retrieves the IDs of all active slabs on the Memcached server.
*
* A slab is a logical unit of storage in Memcached.
*
* @return array|null An array of slab IDs, or null on failure.
*/
public function slabs() {
$result = $this->request( 'stats slabs' );
if ( is_null( $result ) ) {
return null;
}
$result = $this->parse( $result );
$slabs = array();
foreach ( $result as $line_words ) {
if ( count( $line_words ) < 2 ) {
continue;
}
$key = explode( ':', $line_words[1] );
if ( (int) $key[0] > 0 ) {
$slabs[ $key[0] ] = '*';
}
}
return array_keys( $slabs );
}
/**
* Retrieves a cachedump for a specific slab ID.
*
* A cachedump returns the cached items for the specified slab.
*
* @param int $slab_id The ID of the slab to retrieve the cachedump for.
*
* @return array|null An array of cachedump data, or null on failure.
*/
public function cachedump( $slab_id ) {
$result = $this->request( 'stats cachedump ' . $slab_id . ' 0' );
if ( is_null( $result ) ) {
return null;
}
// return pure data to limit memory usage.
return $result;
}
}