Current File : /home/resuelf/www/wp-content/plugins/really-simple-ssl/security/hardening.php |
<?php
defined('ABSPATH') or die();
class rsssl_hardening {
private static $_this;
public $risk_naming;
function __construct()
{
if (isset(self::$_this))
wp_die(sprintf(__('%s is a singleton class and you cannot create a second instance.', 'really-simple-ssl'), get_class($this)));
add_filter( 'rsssl_do_action', array($this, 'hardening_data'), 10, 3 );
$this->risk_naming = [
'l' => __('low-risk', 'really-simple-ssl'),
'm' => __('medium-risk', 'really-simple-ssl'),
'h' => __('high-risk', 'really-simple-ssl'),
'c' => __('critical', 'really-simple-ssl'),
];
self::$_this = $this;
}
function hardening_data( array $response, string $action, $data ): array {
if ( ! rsssl_user_can_manage() ) {
return $response;
}
if ($action === 'hardening_data') {
$response = $this->get_stats( $data );
}
return $response;
}
static function this()
{
return self::$_this;
}
/* Public Section 2: DataGathering */
/**
* @param $data
*
* @return array
*/
public function get_stats($data): array
{
if ( ! rsssl_user_can_manage() ) {
return [];
}
$vulEnabled = rsssl_get_option('enable_vulnerability_scanner');
//now we fetch all plugins that have an update available.
$stats = [
'updates' => $this->getAllUpdatesCount(),
'lastChecked' => time(),
'riskNaming' => $this->risk_naming,
'vulEnabled' => $vulEnabled,
];
$repsonse = [
"request_success" => true,
'data' => apply_filters('rsssl_vulnerability_data', $stats),
];
return $repsonse;
}
/**
* @return int
*/
public function getAllUpdatesCount(): int
{
$updates = wp_get_update_data();
//we only want core, plugins and themes
$updates = array_slice($updates, 0, 3);
return array_sum($updates);
}
}