|
<?php |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class WP_REST_Site_Health_Controller extends WP_REST_Controller { |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private $site_health; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function __construct( $site_health ) { |
|
$this->namespace = 'wp-site-health/v1'; |
|
$this->rest_base = 'tests'; |
|
|
|
$this->site_health = $site_health; |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function register_routes() { |
|
register_rest_route( |
|
$this->namespace, |
|
sprintf( |
|
'/%s/%s', |
|
$this->rest_base, |
|
'background-updates' |
|
), |
|
array( |
|
array( |
|
'methods' => 'GET', |
|
'callback' => array( $this, 'test_background_updates' ), |
|
'permission_callback' => function () { |
|
return $this->validate_request_permission( 'background_updates' ); |
|
}, |
|
), |
|
'schema' => array( $this, 'get_public_item_schema' ), |
|
) |
|
); |
|
|
|
register_rest_route( |
|
$this->namespace, |
|
sprintf( |
|
'/%s/%s', |
|
$this->rest_base, |
|
'loopback-requests' |
|
), |
|
array( |
|
array( |
|
'methods' => 'GET', |
|
'callback' => array( $this, 'test_loopback_requests' ), |
|
'permission_callback' => function () { |
|
return $this->validate_request_permission( 'loopback_requests' ); |
|
}, |
|
), |
|
'schema' => array( $this, 'get_public_item_schema' ), |
|
) |
|
); |
|
|
|
register_rest_route( |
|
$this->namespace, |
|
sprintf( |
|
'/%s/%s', |
|
$this->rest_base, |
|
'https-status' |
|
), |
|
array( |
|
array( |
|
'methods' => 'GET', |
|
'callback' => array( $this, 'test_https_status' ), |
|
'permission_callback' => function () { |
|
return $this->validate_request_permission( 'https_status' ); |
|
}, |
|
), |
|
'schema' => array( $this, 'get_public_item_schema' ), |
|
) |
|
); |
|
|
|
register_rest_route( |
|
$this->namespace, |
|
sprintf( |
|
'/%s/%s', |
|
$this->rest_base, |
|
'dotorg-communication' |
|
), |
|
array( |
|
array( |
|
'methods' => 'GET', |
|
'callback' => array( $this, 'test_dotorg_communication' ), |
|
'permission_callback' => function () { |
|
return $this->validate_request_permission( 'dotorg_communication' ); |
|
}, |
|
), |
|
'schema' => array( $this, 'get_public_item_schema' ), |
|
) |
|
); |
|
|
|
register_rest_route( |
|
$this->namespace, |
|
sprintf( |
|
'/%s/%s', |
|
$this->rest_base, |
|
'authorization-header' |
|
), |
|
array( |
|
array( |
|
'methods' => 'GET', |
|
'callback' => array( $this, 'test_authorization_header' ), |
|
'permission_callback' => function () { |
|
return $this->validate_request_permission( 'authorization_header' ); |
|
}, |
|
), |
|
'schema' => array( $this, 'get_public_item_schema' ), |
|
) |
|
); |
|
|
|
register_rest_route( |
|
$this->namespace, |
|
sprintf( |
|
'/%s', |
|
'directory-sizes' |
|
), |
|
array( |
|
'methods' => 'GET', |
|
'callback' => array( $this, 'get_directory_sizes' ), |
|
'permission_callback' => function () { |
|
return $this->validate_request_permission( 'directory_sizes' ) && ! is_multisite(); |
|
}, |
|
) |
|
); |
|
|
|
register_rest_route( |
|
$this->namespace, |
|
sprintf( |
|
'/%s/%s', |
|
$this->rest_base, |
|
'page-cache' |
|
), |
|
array( |
|
array( |
|
'methods' => 'GET', |
|
'callback' => array( $this, 'test_page_cache' ), |
|
'permission_callback' => function () { |
|
return $this->validate_request_permission( 'page_cache' ); |
|
}, |
|
), |
|
) |
|
); |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
protected function validate_request_permission( $check ) { |
|
$default_capability = 'view_site_health_checks'; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
$capability = apply_filters( "site_health_test_rest_capability_{$check}", $default_capability, $check ); |
|
|
|
return current_user_can( $capability ); |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function test_background_updates() { |
|
$this->load_admin_textdomain(); |
|
return $this->site_health->get_test_background_updates(); |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function test_dotorg_communication() { |
|
$this->load_admin_textdomain(); |
|
return $this->site_health->get_test_dotorg_communication(); |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function test_loopback_requests() { |
|
$this->load_admin_textdomain(); |
|
return $this->site_health->get_test_loopback_requests(); |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function test_https_status() { |
|
$this->load_admin_textdomain(); |
|
return $this->site_health->get_test_https_status(); |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function test_authorization_header() { |
|
$this->load_admin_textdomain(); |
|
return $this->site_health->get_test_authorization_header(); |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function test_page_cache() { |
|
$this->load_admin_textdomain(); |
|
return $this->site_health->get_test_page_cache(); |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function get_directory_sizes() { |
|
if ( ! class_exists( 'WP_Debug_Data' ) ) { |
|
require_once ABSPATH . 'wp-admin/includes/class-wp-debug-data.php'; |
|
} |
|
|
|
$this->load_admin_textdomain(); |
|
|
|
$sizes_data = WP_Debug_Data::get_sizes(); |
|
$all_sizes = array( 'raw' => 0 ); |
|
|
|
foreach ( $sizes_data as $name => $value ) { |
|
$name = sanitize_text_field( $name ); |
|
$data = array(); |
|
|
|
if ( isset( $value['size'] ) ) { |
|
if ( is_string( $value['size'] ) ) { |
|
$data['size'] = sanitize_text_field( $value['size'] ); |
|
} else { |
|
$data['size'] = (int) $value['size']; |
|
} |
|
} |
|
|
|
if ( isset( $value['debug'] ) ) { |
|
if ( is_string( $value['debug'] ) ) { |
|
$data['debug'] = sanitize_text_field( $value['debug'] ); |
|
} else { |
|
$data['debug'] = (int) $value['debug']; |
|
} |
|
} |
|
|
|
if ( ! empty( $value['raw'] ) ) { |
|
$data['raw'] = (int) $value['raw']; |
|
} |
|
|
|
$all_sizes[ $name ] = $data; |
|
} |
|
|
|
if ( isset( $all_sizes['total_size']['debug'] ) && 'not available' === $all_sizes['total_size']['debug'] ) { |
|
return new WP_Error( 'not_available', __( 'Directory sizes could not be returned.' ), array( 'status' => 500 ) ); |
|
} |
|
|
|
return $all_sizes; |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
protected function load_admin_textdomain() { |
|
|
|
if ( ! is_admin() ) { |
|
$locale = determine_locale(); |
|
load_textdomain( 'default', WP_LANG_DIR . "/admin-$locale.mo", $locale ); |
|
} |
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public function get_item_schema() { |
|
if ( $this->schema ) { |
|
return $this->schema; |
|
} |
|
|
|
$this->schema = array( |
|
'$schema' => 'http://json-schema.org/draft-04/schema#', |
|
'title' => 'wp-site-health-test', |
|
'type' => 'object', |
|
'properties' => array( |
|
'test' => array( |
|
'type' => 'string', |
|
'description' => __( 'The name of the test being run.' ), |
|
'readonly' => true, |
|
), |
|
'label' => array( |
|
'type' => 'string', |
|
'description' => __( 'A label describing the test.' ), |
|
'readonly' => true, |
|
), |
|
'status' => array( |
|
'type' => 'string', |
|
'description' => __( 'The status of the test.' ), |
|
'enum' => array( 'good', 'recommended', 'critical' ), |
|
'readonly' => true, |
|
), |
|
'badge' => array( |
|
'type' => 'object', |
|
'description' => __( 'The category this test is grouped in.' ), |
|
'properties' => array( |
|
'label' => array( |
|
'type' => 'string', |
|
'readonly' => true, |
|
), |
|
'color' => array( |
|
'type' => 'string', |
|
'enum' => array( 'blue', 'orange', 'red', 'green', 'purple', 'gray' ), |
|
'readonly' => true, |
|
), |
|
), |
|
'readonly' => true, |
|
), |
|
'description' => array( |
|
'type' => 'string', |
|
'description' => __( 'A more descriptive explanation of what the test looks for, and why it is important for the user.' ), |
|
'readonly' => true, |
|
), |
|
'actions' => array( |
|
'type' => 'string', |
|
'description' => __( 'HTML containing an action to direct the user to where they can resolve the issue.' ), |
|
'readonly' => true, |
|
), |
|
), |
|
); |
|
|
|
return $this->schema; |
|
} |
|
} |
|
|