first commit
This commit is contained in:
@@ -0,0 +1,68 @@
|
||||
<?php
|
||||
namespace Elementor\Modules\System_Info\Helpers;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit; // Exit if accessed directly.
|
||||
}
|
||||
|
||||
/**
|
||||
* Elementor model helper.
|
||||
*
|
||||
* Elementor model helper handler class is responsible for filtering properties.
|
||||
*
|
||||
* @since 1.0.0
|
||||
*/
|
||||
final class Model_Helper {
|
||||
|
||||
/**
|
||||
* Model helper constructor.
|
||||
*
|
||||
* Initializing the model helper class.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access private
|
||||
*/
|
||||
private function __construct() {}
|
||||
|
||||
/**
|
||||
* Filter possible properties.
|
||||
*
|
||||
* Retrieve possible properties filtered by property intersect key.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
* @static
|
||||
*
|
||||
* @param array $possible_properties All the possible properties.
|
||||
* @param array $properties Properties to filter.
|
||||
*
|
||||
* @return array Possible properties filtered by property intersect key.
|
||||
*/
|
||||
public static function filter_possible_properties( $possible_properties, $properties ) {
|
||||
$properties_keys = array_flip( $possible_properties );
|
||||
|
||||
return array_intersect_key( $properties, $properties_keys );
|
||||
}
|
||||
|
||||
/**
|
||||
* Prepare properties.
|
||||
*
|
||||
* Combine the possible properties with the user properties and filter them.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
* @static
|
||||
*
|
||||
* @param array $possible_properties All the possible properties.
|
||||
* @param array $user_properties User properties.
|
||||
*
|
||||
* @return array Possible properties and user properties filtered by property intersect key.
|
||||
*/
|
||||
public static function prepare_properties( $possible_properties, $user_properties ) {
|
||||
$properties = array_fill_keys( $possible_properties, null );
|
||||
|
||||
$properties = array_merge( $properties, $user_properties );
|
||||
|
||||
return self::filter_possible_properties( $possible_properties, $properties );
|
||||
}
|
||||
}
|
||||
360
wp-content/plugins/elementor/modules/system-info/module.php
Normal file
360
wp-content/plugins/elementor/modules/system-info/module.php
Normal file
@@ -0,0 +1,360 @@
|
||||
<?php
|
||||
namespace Elementor\Modules\System_Info;
|
||||
|
||||
use Elementor\Core\Admin\Menu\Admin_Menu_Manager;
|
||||
use Elementor\Core\Base\Module as BaseModule;
|
||||
use Elementor\Modules\System_Info\Reporters\Base;
|
||||
use Elementor\Modules\System_Info\Helpers\Model_Helper;
|
||||
use Elementor\Plugin;
|
||||
use Elementor\Settings;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit; // Exit if accessed directly.
|
||||
}
|
||||
|
||||
/**
|
||||
* Elementor system info module.
|
||||
*
|
||||
* Elementor system info module handler class is responsible for registering and
|
||||
* managing Elementor system info reports.
|
||||
*
|
||||
* @since 2.9.0
|
||||
*/
|
||||
class Module extends BaseModule {
|
||||
|
||||
/**
|
||||
* Get module name.
|
||||
*
|
||||
* Retrieve the system info module name.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access public
|
||||
*
|
||||
* @return string Module name.
|
||||
*/
|
||||
public function get_name() {
|
||||
return 'system-info';
|
||||
}
|
||||
|
||||
/**
|
||||
* Required user capabilities.
|
||||
*
|
||||
* Holds the user capabilities required to manage Elementor menus.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access private
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
private $capability = 'manage_options';
|
||||
|
||||
/**
|
||||
* Elementor system info reports.
|
||||
*
|
||||
* Holds an array of available reports in Elementor system info page.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access private
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
private static $reports = [
|
||||
'server' => [],
|
||||
'wordpress' => [],
|
||||
'theme' => [],
|
||||
'user' => [],
|
||||
'plugins' => [],
|
||||
'network_plugins' => [],
|
||||
'mu_plugins' => [],
|
||||
];
|
||||
|
||||
public function get_capability() {
|
||||
return $this->capability;
|
||||
}
|
||||
|
||||
/**
|
||||
* Main system info page constructor.
|
||||
*
|
||||
* Initializing Elementor system info page.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access public
|
||||
*/
|
||||
public function __construct() {
|
||||
$this->add_actions();
|
||||
}
|
||||
|
||||
/**
|
||||
* Get default settings.
|
||||
*
|
||||
* Retrieve the default settings. Used to reset the report settings on
|
||||
* initialization.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access protected
|
||||
*
|
||||
* @return array Default settings.
|
||||
*/
|
||||
protected function get_init_settings() {
|
||||
$settings = [];
|
||||
|
||||
$reporter_properties = Base::get_properties_keys();
|
||||
|
||||
array_push( $reporter_properties, 'category', 'name', 'class_name' );
|
||||
|
||||
$settings['reporter_properties'] = $reporter_properties;
|
||||
|
||||
$settings['reportFilePrefix'] = '';
|
||||
|
||||
return $settings;
|
||||
}
|
||||
|
||||
/**
|
||||
* Add actions.
|
||||
*
|
||||
* Register filters and actions for the main system info page.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access private
|
||||
*/
|
||||
private function add_actions() {
|
||||
if ( ! Plugin::$instance->experiments->is_feature_active( 'admin_menu_rearrangement' ) ) {
|
||||
add_action( 'elementor/admin/menu/register', function ( Admin_Menu_Manager $admin_menu_manager ) {
|
||||
$this->register_menu( $admin_menu_manager );
|
||||
}, Settings::ADMIN_MENU_PRIORITY + 30 );
|
||||
}
|
||||
|
||||
add_action( 'wp_ajax_elementor_system_info_download_file', [ $this, 'download_file' ] );
|
||||
}
|
||||
|
||||
/**
|
||||
* Register admin menu.
|
||||
*
|
||||
* Add new Elementor system info admin menu.
|
||||
*
|
||||
* Fired by `admin_menu` action.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access private
|
||||
*/
|
||||
private function register_menu( Admin_Menu_Manager $admin_menu ) {
|
||||
$admin_menu->register( 'elementor-system-info', new System_Info_Menu_Item( $this ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* Display page.
|
||||
*
|
||||
* Output the content for the main system info page.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access public
|
||||
*/
|
||||
public function display_page() {
|
||||
$reports_info = self::get_allowed_reports();
|
||||
|
||||
$reports = $this->load_reports( $reports_info );
|
||||
?>
|
||||
<div id="elementor-system-info">
|
||||
<div class="elementor-system-info-header">
|
||||
<h3 class="wp-heading-inline"><?php echo esc_html__( 'System Info', 'elementor' ); ?></h3>
|
||||
<form action="<?php echo esc_url( admin_url( 'admin-ajax.php' ) ); ?>" method="post">
|
||||
<input type="hidden" name="action" value="elementor_system_info_download_file">
|
||||
<input type="submit" class="button button-primary" value="<?php echo esc_attr__( 'Download System Info', 'elementor' ); ?>">
|
||||
</form>
|
||||
</div>
|
||||
<div><?php $this->print_report( $reports, 'html' ); ?></div>
|
||||
<h3><?php echo esc_html__( 'Copy & Paste Info', 'elementor' ); ?></h3>
|
||||
<div id="elementor-system-info-raw">
|
||||
<label id="elementor-system-info-raw-code-label" for="elementor-system-info-raw-code"><?php echo esc_html__( 'You can copy the below info as simple text with Ctrl+C / Ctrl+V:', 'elementor' ); ?></label>
|
||||
<textarea id="elementor-system-info-raw-code" readonly>
|
||||
<?php
|
||||
$this->print_report( $reports, 'raw' );
|
||||
?>
|
||||
</textarea>
|
||||
<script>
|
||||
var textarea = document.getElementById( 'elementor-system-info-raw-code' );
|
||||
var selectRange = function() {
|
||||
textarea.setSelectionRange( 0, textarea.value.length );
|
||||
};
|
||||
textarea.onfocus = textarea.onblur = textarea.onclick = selectRange;
|
||||
textarea.onfocus();
|
||||
</script>
|
||||
</div>
|
||||
<hr>
|
||||
<form action="<?php echo esc_url( admin_url( 'admin-ajax.php' ) ); ?>" method="post">
|
||||
<input type="hidden" name="action" value="elementor_system_info_download_file">
|
||||
<input type="submit" class="button button-primary" value="<?php echo esc_attr__( 'Download System Info', 'elementor' ); ?>">
|
||||
</form>
|
||||
</div>
|
||||
<?php
|
||||
}
|
||||
|
||||
/**
|
||||
* Download file.
|
||||
*
|
||||
* Download the reports files.
|
||||
*
|
||||
* Fired by `wp_ajax_elementor_system_info_download_file` action.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access public
|
||||
*/
|
||||
public function download_file() {
|
||||
if ( ! current_user_can( $this->capability ) ) {
|
||||
wp_die( esc_html__( 'You do not have permission to download this file.', 'elementor' ) );
|
||||
}
|
||||
|
||||
$reports_info = self::get_allowed_reports();
|
||||
$reports = $this->load_reports( $reports_info );
|
||||
|
||||
$domain = parse_url( site_url(), PHP_URL_HOST );
|
||||
|
||||
header( 'Content-Type: text/plain' );
|
||||
header( 'Content-Disposition:attachment; filename=system-info-' . $domain . '-' . gmdate( 'd-m-Y' ) . '.txt' );
|
||||
|
||||
$this->print_report( $reports );
|
||||
|
||||
die;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get report class.
|
||||
*
|
||||
* Retrieve the class of the report for any given report type.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access public
|
||||
*
|
||||
* @param string $reporter_type The type of the report.
|
||||
*
|
||||
* @return string The class of the report.
|
||||
*/
|
||||
public function get_reporter_class( $reporter_type ) {
|
||||
return __NAMESPACE__ . '\Reporters\\' . ucfirst( $reporter_type );
|
||||
}
|
||||
|
||||
/**
|
||||
* Load reports.
|
||||
*
|
||||
* Retrieve the system info reports.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access public
|
||||
*
|
||||
* @param array $reports An array of system info reports.
|
||||
*
|
||||
* @return array An array of system info reports.
|
||||
*/
|
||||
public function load_reports( $reports ) {
|
||||
$result = [];
|
||||
|
||||
foreach ( $reports as $report_name => $report_info ) {
|
||||
$reporter_params = [
|
||||
'name' => $report_name,
|
||||
];
|
||||
|
||||
$reporter_params = array_merge( $reporter_params, $report_info );
|
||||
|
||||
$reporter = $this->create_reporter( $reporter_params );
|
||||
|
||||
if ( ! $reporter instanceof Base ) {
|
||||
continue;
|
||||
}
|
||||
|
||||
$result[ $report_name ] = [
|
||||
'report' => $reporter,
|
||||
'label' => $reporter->get_title(),
|
||||
];
|
||||
|
||||
if ( ! empty( $report_info['sub'] ) ) {
|
||||
$result[ $report_name ]['sub'] = $this->load_reports( $report_info['sub'] );
|
||||
}
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
|
||||
/**
|
||||
* Create a report.
|
||||
*
|
||||
* Register a new report that will be displayed in Elementor system info page.
|
||||
*
|
||||
* @param array $properties Report properties.
|
||||
*
|
||||
* @return \WP_Error|false|Base Base instance if the report was created,
|
||||
* False or WP_Error otherwise.
|
||||
*@since 2.9.0
|
||||
* @access public
|
||||
*
|
||||
*/
|
||||
public function create_reporter( array $properties ) {
|
||||
$properties = Model_Helper::prepare_properties( $this->get_settings( 'reporter_properties' ), $properties );
|
||||
|
||||
$reporter_class = $properties['class_name'] ? $properties['class_name'] : $this->get_reporter_class( $properties['name'] );
|
||||
|
||||
$reporter = new $reporter_class( $properties );
|
||||
|
||||
if ( ! ( $reporter instanceof Base ) ) {
|
||||
return new \WP_Error( 'Each reporter must to be an instance or sub-instance of `Base` class.' );
|
||||
}
|
||||
|
||||
if ( ! $reporter->is_enabled() ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return $reporter;
|
||||
}
|
||||
|
||||
/**
|
||||
* Print report.
|
||||
*
|
||||
* Output the system info page reports using an output template.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access public
|
||||
*
|
||||
* @param array $reports An array of system info reports.
|
||||
* @param string $template Output type from the templates folder. Available
|
||||
* templates are `raw` and `html`. Default is `raw`.
|
||||
*/
|
||||
public function print_report( $reports, $template = 'raw' ) {
|
||||
static $tabs_count = 0;
|
||||
|
||||
$template_path = __DIR__ . '/templates/' . $template . '.php';
|
||||
|
||||
require $template_path;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get allowed reports.
|
||||
*
|
||||
* Retrieve the available reports in Elementor system info page.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access public
|
||||
* @static
|
||||
*
|
||||
* @return array Available reports in Elementor system info page.
|
||||
*/
|
||||
public static function get_allowed_reports() {
|
||||
do_action( 'elementor/system_info/get_allowed_reports' );
|
||||
|
||||
return self::$reports;
|
||||
}
|
||||
|
||||
/**
|
||||
* Add report.
|
||||
*
|
||||
* Register a new report to Elementor system info page.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access public
|
||||
* @static
|
||||
*
|
||||
* @param string $report_name The name of the report.
|
||||
* @param array $report_info Report info.
|
||||
*/
|
||||
public static function add_report( $report_name, $report_info ) {
|
||||
self::$reports[ $report_name ] = $report_info;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,79 @@
|
||||
<?php
|
||||
namespace Elementor\Modules\System_Info\Reporters;
|
||||
|
||||
use Elementor\Utils;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit; // Exit if accessed directly.
|
||||
}
|
||||
|
||||
abstract class Base_Plugin extends Base {
|
||||
public static $required_plugins_properties = [
|
||||
'Name',
|
||||
'Version',
|
||||
'URL',
|
||||
'Author',
|
||||
];
|
||||
|
||||
public function print_html() {
|
||||
foreach ( $this->get_report( 'html' ) as $field ) {
|
||||
foreach ( $field['value'] as $plugin_info ) :
|
||||
?>
|
||||
<tr>
|
||||
<td><?php
|
||||
if ( $plugin_info['PluginURI'] ) :
|
||||
$plugin_name = sprintf( '<a href="%s">%s</a>', $plugin_info['PluginURI'], $plugin_info['Name'] );
|
||||
else :
|
||||
$plugin_name = $plugin_info['Name'];
|
||||
endif;
|
||||
|
||||
if ( $plugin_info['Version'] ) :
|
||||
$plugin_name .= ' - ' . $plugin_info['Version'];
|
||||
endif;
|
||||
|
||||
Utils::print_unescaped_internal_string( $plugin_name );
|
||||
?></td>
|
||||
<td><?php
|
||||
if ( $plugin_info['Author'] ) :
|
||||
if ( $plugin_info['AuthorURI'] ) :
|
||||
$author = sprintf( '<a href="%s">%s</a>', $plugin_info['AuthorURI'], $plugin_info['Author'] );
|
||||
else :
|
||||
$author = $plugin_info['Author'];
|
||||
endif;
|
||||
|
||||
Utils::print_unescaped_internal_string( "By $author" );
|
||||
endif;
|
||||
?></td>
|
||||
<td></td>
|
||||
</tr>
|
||||
<?php
|
||||
endforeach;
|
||||
}
|
||||
}
|
||||
|
||||
public function print_raw( $tabs_count ) {
|
||||
echo PHP_EOL;
|
||||
|
||||
$required_plugins_properties = array_flip( self::$required_plugins_properties );
|
||||
|
||||
unset( $required_plugins_properties['Name'] );
|
||||
|
||||
foreach ( $this->get_report( 'raw' ) as $field_name => $field ) :
|
||||
$sub_indent = str_repeat( "\t", $tabs_count );
|
||||
|
||||
echo "== {$field['label']} ==" . PHP_EOL; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
|
||||
|
||||
foreach ( $field['value'] as $plugin_info ) :
|
||||
$plugin_properties = array_intersect_key( $plugin_info, $required_plugins_properties );
|
||||
|
||||
echo esc_html( $sub_indent . $plugin_info['Name'] );
|
||||
|
||||
foreach ( $plugin_properties as $property_name => $property ) :
|
||||
echo PHP_EOL . "{$sub_indent}\t{$property_name}: {$property}"; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
|
||||
endforeach;
|
||||
|
||||
echo PHP_EOL . PHP_EOL;
|
||||
endforeach;
|
||||
endforeach;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,242 @@
|
||||
<?php
|
||||
namespace Elementor\Modules\System_Info\Reporters;
|
||||
|
||||
use Elementor\Modules\System_Info\Helpers\Model_Helper;
|
||||
use Elementor\Utils;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit; // Exit if accessed directly.
|
||||
}
|
||||
|
||||
/**
|
||||
* Elementor base reporter.
|
||||
*
|
||||
* A base abstract class that provides the needed properties and methods to
|
||||
* manage and handle reporter in inheriting classes.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @abstract
|
||||
*/
|
||||
abstract class Base {
|
||||
|
||||
/**
|
||||
* Reporter properties.
|
||||
*
|
||||
* Holds the list of all the properties of the report.
|
||||
*
|
||||
* @access protected
|
||||
* @static
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $_properties;
|
||||
|
||||
/**
|
||||
* Get report title.
|
||||
*
|
||||
* Retrieve the title of the report.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access public
|
||||
* @abstract
|
||||
*/
|
||||
abstract public function get_title();
|
||||
|
||||
/**
|
||||
* Get report fields.
|
||||
*
|
||||
* Retrieve the required fields for the report.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access public
|
||||
* @abstract
|
||||
*/
|
||||
abstract public function get_fields();
|
||||
|
||||
/**
|
||||
* Is report enabled.
|
||||
*
|
||||
* Whether the report is enabled.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access public
|
||||
*
|
||||
* @return bool Whether the report is enabled.
|
||||
*/
|
||||
public function is_enabled() {
|
||||
return true;
|
||||
}
|
||||
|
||||
public function print_html() {
|
||||
foreach ( $this->get_report( 'html' ) as $field ) {
|
||||
$warning_class = ! empty( $field['warning'] ) ? ' class="elementor-warning"' : '';
|
||||
$log_label = ! empty( $field['label'] ) ? $field['label'] . ':' : '';
|
||||
?>
|
||||
<tr<?php Utils::print_unescaped_internal_string( $warning_class ); ?>>
|
||||
<td><?php Utils::print_unescaped_internal_string( $log_label ); ?></td>
|
||||
<td><?php Utils::print_unescaped_internal_string( $field['value'] ); ?></td>
|
||||
<td><?php
|
||||
if ( ! empty( $field['recommendation'] ) ) :
|
||||
Utils::print_unescaped_internal_string( $field['recommendation'] );
|
||||
endif;
|
||||
?></td>
|
||||
</tr>
|
||||
<?php
|
||||
}
|
||||
}
|
||||
|
||||
public function print_html_label( $label ) {
|
||||
Utils::print_unescaped_internal_string( $label );
|
||||
}
|
||||
|
||||
public function print_raw( $tabs_count ) {
|
||||
$indent = str_repeat( "\t", $tabs_count - 1 );
|
||||
|
||||
$report = $this->get_report( 'raw' );
|
||||
|
||||
echo PHP_EOL . $indent . '== ' . $this->get_title() . ' =='; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
|
||||
echo PHP_EOL;
|
||||
|
||||
foreach ( $report as $field_name => $field ) :
|
||||
$sub_indent = str_repeat( "\t", $tabs_count );
|
||||
|
||||
$label = $field['label'];
|
||||
|
||||
if ( ! empty( $label ) ) {
|
||||
$label .= ': ';
|
||||
}
|
||||
echo "{$sub_indent}{$label}{$field['value']}" . PHP_EOL; // phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped
|
||||
endforeach;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get report.
|
||||
*
|
||||
* Retrieve the report with all it's containing fields.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access public
|
||||
*
|
||||
* @return \WP_Error | array {
|
||||
* Report fields.
|
||||
*
|
||||
* @type string $name Field name.
|
||||
* @type string $label Field label.
|
||||
* }
|
||||
*/
|
||||
final public function get_report( $format = '' ) {
|
||||
$result = [];
|
||||
|
||||
$format = ( empty( $format ) ) ? '' : $format . '_';
|
||||
|
||||
foreach ( $this->get_fields() as $field_name => $field_label ) {
|
||||
$method = 'get_' . $format . $field_name;
|
||||
|
||||
if ( ! method_exists( $this, $method ) ) {
|
||||
$method = 'get_' . $field_name;
|
||||
//fallback:
|
||||
if ( ! method_exists( $this, $method ) ) {
|
||||
return new \WP_Error( sprintf( "Getter method for the field '%s' wasn't found in %s.", $field_name, get_called_class() ) );
|
||||
}
|
||||
}
|
||||
|
||||
$reporter_field = [
|
||||
'name' => $field_name,
|
||||
'label' => $field_label,
|
||||
];
|
||||
|
||||
$reporter_field = array_merge( $reporter_field, $this->$method() );
|
||||
$result[ $field_name ] = $reporter_field;
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get properties keys.
|
||||
*
|
||||
* Retrieve the keys of the properties.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access public
|
||||
* @static
|
||||
*
|
||||
* @return array {
|
||||
* Property keys.
|
||||
*
|
||||
* @type string $name Property name.
|
||||
* @type string $fields Property fields.
|
||||
* }
|
||||
*/
|
||||
public static function get_properties_keys() {
|
||||
return [
|
||||
'name',
|
||||
'format',
|
||||
'fields',
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Filter possible properties.
|
||||
*
|
||||
* Retrieve possible properties filtered by property keys.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access public
|
||||
* @static
|
||||
*
|
||||
* @param array $properties Properties to filter.
|
||||
*
|
||||
* @return array Possible properties filtered by property keys.
|
||||
*/
|
||||
final public static function filter_possible_properties( $properties ) {
|
||||
return Model_Helper::filter_possible_properties( self::get_properties_keys(), $properties );
|
||||
}
|
||||
|
||||
/**
|
||||
* Set properties.
|
||||
*
|
||||
* Add/update properties to the report.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access public
|
||||
*
|
||||
* @param array $key Property key.
|
||||
* @param array $value Optional. Property value. Default is `null`.
|
||||
*/
|
||||
final public function set_properties( $key, $value = null ) {
|
||||
if ( is_array( $key ) ) {
|
||||
$key = self::filter_possible_properties( $key );
|
||||
|
||||
foreach ( $key as $sub_key => $sub_value ) {
|
||||
$this->set_properties( $sub_key, $sub_value );
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
if ( ! in_array( $key, self::get_properties_keys(), true ) ) {
|
||||
return;
|
||||
}
|
||||
|
||||
$this->_properties[ $key ] = $value;
|
||||
}
|
||||
|
||||
/**
|
||||
* Reporter base constructor.
|
||||
*
|
||||
* Initializing the reporter base class.
|
||||
*
|
||||
* @since 2.9.0
|
||||
* @access public
|
||||
*
|
||||
* @param array $properties Optional. Properties to filter. Default is `null`.
|
||||
*/
|
||||
public function __construct( $properties = null ) {
|
||||
$this->_properties = array_fill_keys( self::get_properties_keys(), null );
|
||||
|
||||
if ( $properties ) {
|
||||
$this->set_properties( $properties, null );
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,111 @@
|
||||
<?php
|
||||
namespace Elementor\Modules\System_Info\Reporters;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit; // Exit if accessed directly.
|
||||
}
|
||||
|
||||
/**
|
||||
* Elementor must-use plugins report.
|
||||
*
|
||||
* Elementor system report handler class responsible for generating a report for
|
||||
* must-use plugins.
|
||||
*
|
||||
* @since 1.0.0
|
||||
*/
|
||||
class MU_Plugins extends Base_Plugin {
|
||||
|
||||
/**
|
||||
* Must-Use plugins.
|
||||
*
|
||||
* Holds the sites must-use plugins list.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access private
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
private $plugins;
|
||||
|
||||
/**
|
||||
* Get must-use plugins.
|
||||
*
|
||||
* Retrieve the must-use plugins.
|
||||
*
|
||||
* @since 2.0.0
|
||||
* @access private
|
||||
*
|
||||
* @return array Must-Use plugins.
|
||||
*/
|
||||
private function get_mu_plugins() {
|
||||
if ( ! $this->plugins ) {
|
||||
$this->plugins = get_mu_plugins();
|
||||
}
|
||||
|
||||
return $this->plugins;
|
||||
}
|
||||
|
||||
/**
|
||||
* Is enabled.
|
||||
*
|
||||
* Whether there are must-use plugins or not.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return bool True if the site has must-use plugins, False otherwise.
|
||||
*/
|
||||
public function is_enabled() {
|
||||
return ! ! $this->get_mu_plugins();
|
||||
}
|
||||
|
||||
/**
|
||||
* Get must-use plugins reporter title.
|
||||
*
|
||||
* Retrieve must-use plugins reporter title.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return string Reporter title.
|
||||
*/
|
||||
public function get_title() {
|
||||
return 'Must-Use Plugins';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get must-use plugins report fields.
|
||||
*
|
||||
* Retrieve the required fields for the must-use plugins report.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array Required report fields with field ID and field label.
|
||||
*/
|
||||
public function get_fields() {
|
||||
return [
|
||||
'must_use_plugins' => 'Must-Use Plugins',
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get must-use plugins.
|
||||
*
|
||||
* Retrieve the sites must-use plugins.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value The must-use plugins list.
|
||||
* }
|
||||
*/
|
||||
public function get_must_use_plugins() {
|
||||
return [
|
||||
'value' => $this->get_mu_plugins(),
|
||||
];
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,116 @@
|
||||
<?php
|
||||
namespace Elementor\Modules\System_Info\Reporters;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit; // Exit if accessed directly.
|
||||
}
|
||||
|
||||
/**
|
||||
* Elementor network plugins report.
|
||||
*
|
||||
* Elementor system report handler class responsible for generating a report for
|
||||
* network plugins.
|
||||
*
|
||||
* @since 1.0.0
|
||||
*/
|
||||
class Network_Plugins extends Base_Plugin {
|
||||
|
||||
/**
|
||||
* Network plugins.
|
||||
*
|
||||
* Holds the sites network plugins list.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access private
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
private $plugins;
|
||||
|
||||
/**
|
||||
* Get network plugins reporter title.
|
||||
*
|
||||
* Retrieve network plugins reporter title.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return string Reporter title.
|
||||
*/
|
||||
public function get_title() {
|
||||
return 'Network Plugins';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get active network plugins.
|
||||
*
|
||||
* Retrieve the active network plugins from the list of active site-wide plugins.
|
||||
*
|
||||
* @since 2.0.0
|
||||
* @access private
|
||||
*
|
||||
* @return array Active network plugins.
|
||||
*/
|
||||
private function get_network_plugins() {
|
||||
if ( ! $this->plugins ) {
|
||||
$active_plugins = get_site_option( 'active_sitewide_plugins' );
|
||||
$this->plugins = array_intersect_key( get_plugins(), $active_plugins );
|
||||
}
|
||||
|
||||
return $this->plugins;
|
||||
}
|
||||
|
||||
/**
|
||||
* Is enabled.
|
||||
*
|
||||
* Whether there are active network plugins or not.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return bool True if the site has active network plugins, False otherwise.
|
||||
*/
|
||||
public function is_enabled() {
|
||||
if ( ! is_multisite() ) {
|
||||
return false;
|
||||
};
|
||||
|
||||
return ! ! $this->get_network_plugins();
|
||||
}
|
||||
|
||||
/**
|
||||
* Get network plugins report fields.
|
||||
*
|
||||
* Retrieve the required fields for the network plugins report.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array Required report fields with field ID and field label.
|
||||
*/
|
||||
public function get_fields() {
|
||||
return [
|
||||
'network_active_plugins' => 'Network Plugins',
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get active network plugins.
|
||||
*
|
||||
* Retrieve the sites active network plugins.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value The active network plugins list.
|
||||
* }
|
||||
*/
|
||||
public function get_network_active_plugins() {
|
||||
return [
|
||||
'value' => $this->get_network_plugins(),
|
||||
];
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,113 @@
|
||||
<?php
|
||||
namespace Elementor\Modules\System_Info\Reporters;
|
||||
|
||||
use Elementor\Plugin;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit; // Exit if accessed directly.
|
||||
}
|
||||
|
||||
/**
|
||||
* Elementor active plugins report.
|
||||
*
|
||||
* Elementor system report handler class responsible for generating a report for
|
||||
* active plugins.
|
||||
*
|
||||
* @since 1.0.0
|
||||
*/
|
||||
class Plugins extends Base_Plugin {
|
||||
|
||||
/**
|
||||
* Active plugins.
|
||||
*
|
||||
* Holds the sites active plugins list.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access private
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
private $plugins;
|
||||
|
||||
/**
|
||||
* Get active plugins.
|
||||
*
|
||||
* Retrieve the active plugins from the list of all the installed plugins.
|
||||
*
|
||||
* @since 2.0.0
|
||||
* @access private
|
||||
*
|
||||
* @return array Active plugins.
|
||||
*/
|
||||
private function get_plugins() {
|
||||
if ( ! $this->plugins ) {
|
||||
$this->plugins = Plugin::$instance->wp->get_active_plugins()->all();
|
||||
}
|
||||
|
||||
return $this->plugins;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get active plugins reporter title.
|
||||
*
|
||||
* Retrieve active plugins reporter title.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return string Reporter title.
|
||||
*/
|
||||
public function get_title() {
|
||||
return 'Active Plugins';
|
||||
}
|
||||
|
||||
/**
|
||||
* Is enabled.
|
||||
*
|
||||
* Whether there are active plugins or not.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return bool True if the site has active plugins, False otherwise.
|
||||
*/
|
||||
public function is_enabled() {
|
||||
return ! ! $this->get_plugins();
|
||||
}
|
||||
|
||||
/**
|
||||
* Get active plugins report fields.
|
||||
*
|
||||
* Retrieve the required fields for the active plugins report.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array Required report fields with field ID and field label.
|
||||
*/
|
||||
public function get_fields() {
|
||||
return [
|
||||
'active_plugins' => 'Active Plugins',
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get active plugins.
|
||||
*
|
||||
* Retrieve the sites active plugins.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value The active plugins list.
|
||||
* }
|
||||
*/
|
||||
public function get_active_plugins() {
|
||||
return [
|
||||
'value' => $this->get_plugins(),
|
||||
];
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,493 @@
|
||||
<?php
|
||||
namespace Elementor\Modules\System_Info\Reporters;
|
||||
|
||||
use Elementor\Api;
|
||||
use Elementor\Utils;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit; // Exit if accessed directly.
|
||||
}
|
||||
|
||||
/**
|
||||
* Elementor server environment report.
|
||||
*
|
||||
* Elementor system report handler class responsible for generating a report for
|
||||
* the server environment.
|
||||
*
|
||||
* @since 1.0.0
|
||||
*/
|
||||
class Server extends Base {
|
||||
|
||||
const KEY_PATH_WP_ROOT_DIR = 'wp_root';
|
||||
const KEY_PATH_WP_CONTENT_DIR = 'wp_content';
|
||||
const KEY_PATH_UPLOADS_DIR = 'uploads';
|
||||
const KEY_PATH_ELEMENTOR_UPLOADS_DIR = 'elementor_uploads';
|
||||
const KEY_PATH_HTACCESS_FILE = '.htaccess';
|
||||
|
||||
/**
|
||||
* Get server environment reporter title.
|
||||
*
|
||||
* Retrieve server environment reporter title.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return string Reporter title.
|
||||
*/
|
||||
public function get_title() {
|
||||
return 'Server Environment';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get server environment report fields.
|
||||
*
|
||||
* Retrieve the required fields for the server environment report.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array Required report fields with field ID and field label.
|
||||
*/
|
||||
public function get_fields() {
|
||||
return [
|
||||
'os' => 'Operating System',
|
||||
'software' => 'Software',
|
||||
'mysql_version' => 'MySQL version',
|
||||
'php_version' => 'PHP Version',
|
||||
'php_memory_limit' => 'PHP Memory Limit',
|
||||
'php_max_input_vars' => 'PHP Max Input Vars',
|
||||
'php_max_post_size' => 'PHP Max Post Size',
|
||||
'gd_installed' => 'GD Installed',
|
||||
'zip_installed' => 'ZIP Installed',
|
||||
'write_permissions' => 'Write Permissions',
|
||||
'elementor_library' => 'Elementor Library',
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get server operating system.
|
||||
*
|
||||
* Retrieve the server operating system.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value Server operating system.
|
||||
* }
|
||||
*/
|
||||
public function get_os() {
|
||||
return [
|
||||
'value' => PHP_OS,
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get server software.
|
||||
*
|
||||
* Retrieve the server software.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value Server software.
|
||||
* }
|
||||
*/
|
||||
public function get_software() {
|
||||
return [
|
||||
'value' => Utils::get_super_global_value( $_SERVER, 'SERVER_SOFTWARE' ),
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get PHP version.
|
||||
*
|
||||
* Retrieve the PHP version.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value PHP version.
|
||||
* @type string $recommendation Minimum PHP version recommendation.
|
||||
* @type bool $warning Whether to display a warning.
|
||||
* }
|
||||
*/
|
||||
public function get_php_version() {
|
||||
$result = [
|
||||
'value' => PHP_VERSION,
|
||||
];
|
||||
$recommended_php_version = '7.4';
|
||||
|
||||
if ( version_compare( $result['value'], $recommended_php_version, '<' ) ) {
|
||||
$result['recommendation'] = sprintf(
|
||||
/* translators: %s: Recommended PHP version. */
|
||||
esc_html__( 'We recommend using PHP version %s or higher.', 'elementor' ),
|
||||
$recommended_php_version
|
||||
);
|
||||
|
||||
$result['warning'] = true;
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get PHP memory limit.
|
||||
*
|
||||
* Retrieve the PHP memory limit.
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value PHP memory limit.
|
||||
* @type string $recommendation Recommendation memory limit.
|
||||
* @type bool $warning Whether to display a warning. True if the limit
|
||||
* is below the recommended 128M, False otherwise.
|
||||
* }
|
||||
*/
|
||||
public function get_php_memory_limit() {
|
||||
$result = [
|
||||
'value' => (string) ini_get( 'memory_limit' ),
|
||||
];
|
||||
|
||||
$min_recommended_memory = '128M';
|
||||
$preferred_memory = '256M';
|
||||
|
||||
$memory_limit_bytes = wp_convert_hr_to_bytes( $result['value'] );
|
||||
|
||||
$min_recommended_bytes = wp_convert_hr_to_bytes( $min_recommended_memory );
|
||||
|
||||
if ( $memory_limit_bytes < $min_recommended_bytes ) {
|
||||
$result['recommendation'] = sprintf(
|
||||
/* translators: 1: Minimum recommended_memory, 2: Preferred memory, 3: WordPress wp-config memory documentation. */
|
||||
__( 'We recommend setting memory to at least %1$s. (%2$s or higher is preferred) For more information, read about <a href="%3$s">how to increase memory allocated to PHP</a>.', 'elementor' ),
|
||||
$min_recommended_memory,
|
||||
$preferred_memory,
|
||||
'https://go.elementor.com/wordpress-wp-config-memory/'
|
||||
);
|
||||
|
||||
$result['warning'] = true;
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get PHP `max_input_vars`.
|
||||
*
|
||||
* Retrieve the value of `max_input_vars` from `php.ini` configuration file.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value PHP `max_input_vars`.
|
||||
* }
|
||||
*/
|
||||
public function get_php_max_input_vars() {
|
||||
return [
|
||||
'value' => ini_get( 'max_input_vars' ),
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get PHP `post_max_size`.
|
||||
*
|
||||
* Retrieve the value of `post_max_size` from `php.ini` configuration file.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value PHP `post_max_size`.
|
||||
* }
|
||||
*/
|
||||
public function get_php_max_post_size() {
|
||||
return [
|
||||
'value' => ini_get( 'post_max_size' ),
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get GD installed.
|
||||
*
|
||||
* Whether the GD extension is installed.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value Yes if the GD extension is installed, No otherwise.
|
||||
* @type bool $warning Whether to display a warning. True if the GD extension is installed, False otherwise.
|
||||
* }
|
||||
*/
|
||||
public function get_gd_installed() {
|
||||
$gd_installed = extension_loaded( 'gd' );
|
||||
|
||||
return [
|
||||
'value' => $gd_installed ? 'Yes' : 'No',
|
||||
'warning' => ! $gd_installed,
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get ZIP installed.
|
||||
*
|
||||
* Whether the ZIP extension is installed.
|
||||
*
|
||||
* @since 2.1.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value Yes if the ZIP extension is installed, No otherwise.
|
||||
* @type bool $warning Whether to display a warning. True if the ZIP extension is installed, False otherwise.
|
||||
* }
|
||||
*/
|
||||
public function get_zip_installed() {
|
||||
$zip_installed = extension_loaded( 'zip' );
|
||||
|
||||
return [
|
||||
'value' => $zip_installed ? 'Yes' : 'No',
|
||||
'warning' => ! $zip_installed,
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get MySQL version.
|
||||
*
|
||||
* Retrieve the MySQL version.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value MySQL version.
|
||||
* }
|
||||
*/
|
||||
public function get_mysql_version() {
|
||||
global $wpdb;
|
||||
|
||||
$db_server_version = $wpdb->get_results( "SHOW VARIABLES WHERE `Variable_name` IN ( 'version_comment', 'innodb_version' )", OBJECT_K );
|
||||
|
||||
$db_server_version_string = $db_server_version['version_comment']->Value . ' v';
|
||||
|
||||
// On some hosts, `innodb_version` is empty, in PHP 8.1.
|
||||
if ( isset( $db_server_version['innodb_version'] ) ) {
|
||||
$db_server_version_string .= $db_server_version['innodb_version']->Value;
|
||||
} else {
|
||||
$db_server_version_string .= $wpdb->get_var( 'SELECT VERSION() AS version' );
|
||||
}
|
||||
|
||||
return [
|
||||
'value' => $db_server_version_string,
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get write permissions.
|
||||
* Check whether the required paths for have writing permissions.
|
||||
*
|
||||
* @since 1.9.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value Writing permissions status.
|
||||
* @type bool $warning Whether to display a warning. True if some required
|
||||
* folders don't have writing permissions, False otherwise.
|
||||
* }
|
||||
*/
|
||||
public function get_write_permissions() : array {
|
||||
$paths_to_check = [
|
||||
static::KEY_PATH_WP_ROOT_DIR => $this->get_system_path( static::KEY_PATH_WP_ROOT_DIR ),
|
||||
static::KEY_PATH_HTACCESS_FILE => $this->get_system_path( static::KEY_PATH_HTACCESS_FILE ),
|
||||
static::KEY_PATH_UPLOADS_DIR => $this->get_system_path( static::KEY_PATH_UPLOADS_DIR ),
|
||||
static::KEY_PATH_ELEMENTOR_UPLOADS_DIR => $this->get_system_path( static::KEY_PATH_ELEMENTOR_UPLOADS_DIR ),
|
||||
];
|
||||
|
||||
$paths_permissions = $this->get_paths_permissions( $paths_to_check );
|
||||
|
||||
$write_problems = [];
|
||||
|
||||
if ( ! $paths_permissions[ static::KEY_PATH_WP_ROOT_DIR ]['write'] ) {
|
||||
$write_problems[] = 'WordPress root directory';
|
||||
}
|
||||
|
||||
if ( ! $paths_permissions[ static::KEY_PATH_UPLOADS_DIR ]['write'] ) {
|
||||
$write_problems[] = 'WordPress uploads directory';
|
||||
}
|
||||
|
||||
if ( $paths_permissions[ self::KEY_PATH_ELEMENTOR_UPLOADS_DIR ]['exists'] && ! $paths_permissions[ self::KEY_PATH_ELEMENTOR_UPLOADS_DIR ]['write'] ) {
|
||||
$write_problems[] = 'Elementor uploads directory';
|
||||
}
|
||||
|
||||
if ( $paths_permissions[ self::KEY_PATH_HTACCESS_FILE ]['exists'] && ! $paths_permissions[ self::KEY_PATH_HTACCESS_FILE ]['write'] ) {
|
||||
$write_problems[] = '.htaccess file';
|
||||
}
|
||||
|
||||
if ( $write_problems ) {
|
||||
$value = 'There are some writing permissions issues with the following directories/files:' . "\n\t\t - ";
|
||||
|
||||
$value .= implode( "\n\t\t - ", $write_problems );
|
||||
} else {
|
||||
$value = 'All right';
|
||||
}
|
||||
|
||||
return [
|
||||
'value' => $value,
|
||||
'warning' => ! ! $write_problems,
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Check for elementor library connectivity.
|
||||
*
|
||||
* Check whether the remote elementor library is reachable.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value The status of elementor library connectivity.
|
||||
* @type bool $warning Whether to display a warning. True if elementor
|
||||
* * library is not reachable, False otherwise.
|
||||
* }
|
||||
*/
|
||||
public function get_elementor_library() {
|
||||
$response = wp_remote_get(
|
||||
Api::$api_info_url, [
|
||||
'timeout' => 5,
|
||||
'body' => [
|
||||
// Which API version is used
|
||||
'api_version' => ELEMENTOR_VERSION,
|
||||
// Which language to return
|
||||
'site_lang' => get_bloginfo( 'language' ),
|
||||
],
|
||||
]
|
||||
);
|
||||
|
||||
if ( is_wp_error( $response ) ) {
|
||||
return [
|
||||
'value' => 'Not connected (' . $response->get_error_message() . ')',
|
||||
'warning' => true,
|
||||
];
|
||||
}
|
||||
|
||||
$http_response_code = wp_remote_retrieve_response_code( $response );
|
||||
|
||||
if ( 200 !== (int) $http_response_code ) {
|
||||
$error_msg = 'HTTP Error (' . $http_response_code . ')';
|
||||
|
||||
return [
|
||||
'value' => 'Not connected (' . $error_msg . ')',
|
||||
'warning' => true,
|
||||
];
|
||||
}
|
||||
|
||||
$info_data = json_decode( wp_remote_retrieve_body( $response ), true );
|
||||
|
||||
if ( empty( $info_data ) ) {
|
||||
return [
|
||||
'value' => 'Not connected (Returns invalid JSON)',
|
||||
'warning' => true,
|
||||
];
|
||||
}
|
||||
|
||||
return [
|
||||
'value' => 'Connected',
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* @param $paths [] Paths to check permissions.
|
||||
* @return array []{exists: bool, read: bool, write: bool, execute: bool}
|
||||
*/
|
||||
public function get_paths_permissions( $paths ) : array {
|
||||
$permissions = [];
|
||||
|
||||
foreach ( $paths as $key_path => $path ) {
|
||||
$permissions[ $key_path ] = $this->get_path_permissions( $path );
|
||||
}
|
||||
|
||||
return $permissions;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get path by path key.
|
||||
*
|
||||
* @param $path_key
|
||||
* @return string
|
||||
*/
|
||||
public function get_system_path( $path_key ) : string {
|
||||
switch ( $path_key ) {
|
||||
case static::KEY_PATH_WP_ROOT_DIR:
|
||||
return ABSPATH;
|
||||
|
||||
case static::KEY_PATH_WP_CONTENT_DIR:
|
||||
return WP_CONTENT_DIR;
|
||||
|
||||
case static::KEY_PATH_HTACCESS_FILE:
|
||||
return file_exists( ABSPATH . '/.htaccess' ) ? ABSPATH . '/.htaccess' : '';
|
||||
|
||||
case static::KEY_PATH_UPLOADS_DIR:
|
||||
return wp_upload_dir()['basedir'] ?? '';
|
||||
|
||||
case static::KEY_PATH_ELEMENTOR_UPLOADS_DIR:
|
||||
if ( empty( wp_upload_dir()['basedir'] ) ) {
|
||||
return '';
|
||||
}
|
||||
|
||||
$elementor_uploads_dir = wp_upload_dir()['basedir'] . '/elementor';
|
||||
|
||||
return is_dir( $elementor_uploads_dir ) ? $elementor_uploads_dir : '';
|
||||
|
||||
default:
|
||||
return '';
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Check the permissions of a path.
|
||||
*
|
||||
* @param $path
|
||||
* @return array{exists: bool, read: bool, write: bool, execute: bool}
|
||||
*/
|
||||
public function get_path_permissions( $path ) : array {
|
||||
if ( empty( $path ) ) {
|
||||
return [
|
||||
'exists' => false,
|
||||
'read' => false,
|
||||
'write' => false,
|
||||
'execute' => false,
|
||||
];
|
||||
}
|
||||
|
||||
return [
|
||||
'exists' => true,
|
||||
'read' => is_readable( $path ),
|
||||
'write' => is_writeable( $path ),
|
||||
'execute' => is_executable( $path ),
|
||||
];
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,274 @@
|
||||
<?php
|
||||
namespace Elementor\Modules\System_Info\Reporters;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit; // Exit if accessed directly.
|
||||
}
|
||||
|
||||
/**
|
||||
* Elementor theme report.
|
||||
*
|
||||
* Elementor system report handler class responsible for generating a report for
|
||||
* the theme.
|
||||
*
|
||||
* @since 1.0.0
|
||||
*/
|
||||
class Theme extends Base {
|
||||
|
||||
/**
|
||||
* Theme.
|
||||
*
|
||||
* Holds the sites theme object.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access private
|
||||
*
|
||||
* @var \WP_Theme WordPress theme object.
|
||||
*/
|
||||
private $theme = null;
|
||||
|
||||
/**
|
||||
* Get theme reporter title.
|
||||
*
|
||||
* Retrieve theme reporter title.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return string Reporter title.
|
||||
*/
|
||||
public function get_title() {
|
||||
return 'Theme';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get theme report fields.
|
||||
*
|
||||
* Retrieve the required fields for the theme report.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array Required report fields with field ID and field label.
|
||||
*/
|
||||
public function get_fields() {
|
||||
$fields = [
|
||||
'name' => 'Name',
|
||||
'version' => 'Version',
|
||||
'author' => 'Author',
|
||||
'is_child_theme' => 'Child Theme',
|
||||
];
|
||||
|
||||
if ( $this->get_parent_theme() ) {
|
||||
$parent_fields = [
|
||||
'parent_name' => 'Parent Theme Name',
|
||||
'parent_version' => 'Parent Theme Version',
|
||||
'parent_author' => 'Parent Theme Author',
|
||||
];
|
||||
$fields = array_merge( $fields, $parent_fields );
|
||||
}
|
||||
|
||||
return $fields;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get theme.
|
||||
*
|
||||
* Retrieve the theme.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @deprecated 3.1.0 Use `get_theme()` method instead.
|
||||
* @access protected
|
||||
*
|
||||
* @return \WP_Theme WordPress theme object.
|
||||
*/
|
||||
protected function _get_theme() {
|
||||
Plugin::$instance->modules_manager->get_modules( 'dev-tools' )->deprecation->deprecated_function( __METHOD__, '3.1.0', 'get_theme()' );
|
||||
|
||||
return $this->get_theme();
|
||||
}
|
||||
|
||||
/**
|
||||
* Get theme.
|
||||
*
|
||||
* Retrieve the theme.
|
||||
*
|
||||
* @since 3.1.0
|
||||
* @access private
|
||||
*
|
||||
* @return \WP_Theme WordPress theme object.
|
||||
*/
|
||||
private function get_theme() {
|
||||
if ( is_null( $this->theme ) ) {
|
||||
$this->theme = wp_get_theme();
|
||||
}
|
||||
return $this->theme;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get parent theme.
|
||||
*
|
||||
* Retrieve the parent theme.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access protected
|
||||
*
|
||||
* @return \WP_Theme|false WordPress theme object, or false if the current theme is not a child theme.
|
||||
*/
|
||||
protected function get_parent_theme() {
|
||||
return $this->get_theme()->parent();
|
||||
}
|
||||
|
||||
/**
|
||||
* Get theme name.
|
||||
*
|
||||
* Retrieve the theme name.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value The theme name.
|
||||
* }
|
||||
*/
|
||||
public function get_name() {
|
||||
return [
|
||||
'value' => $this->get_theme()->get( 'Name' ),
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get theme author.
|
||||
*
|
||||
* Retrieve the theme author.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value The theme author.
|
||||
* }
|
||||
*/
|
||||
public function get_author() {
|
||||
return [
|
||||
'value' => $this->get_theme()->get( 'Author' ),
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get theme version.
|
||||
*
|
||||
* Retrieve the theme version.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value The theme version.
|
||||
* }
|
||||
*/
|
||||
public function get_version() {
|
||||
return [
|
||||
'value' => $this->get_theme()->get( 'Version' ),
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Is the theme is a child theme.
|
||||
*
|
||||
* Whether the theme is a child theme.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value Yes if the theme is a child theme, No otherwise.
|
||||
* @type string $recommendation Theme source code modification recommendation.
|
||||
* }
|
||||
*/
|
||||
public function get_is_child_theme() {
|
||||
$is_child_theme = is_child_theme();
|
||||
|
||||
$result = [
|
||||
'value' => $is_child_theme ? 'Yes' : 'No',
|
||||
];
|
||||
|
||||
if ( ! $is_child_theme ) {
|
||||
$result['recommendation'] = sprintf(
|
||||
/* translators: %s: WordPress child themes documentation. */
|
||||
__( 'If you want to modify the source code of your theme, we recommend using a <a href="%s">child theme</a>.', 'elementor' ),
|
||||
'https://go.elementor.com/wordpress-child-themes/'
|
||||
);
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get parent theme version.
|
||||
*
|
||||
* Retrieve the parent theme version.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value The parent theme version.
|
||||
* }
|
||||
*/
|
||||
public function get_parent_version() {
|
||||
return [
|
||||
'value' => $this->get_parent_theme()->get( 'Version' ),
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get parent theme author.
|
||||
*
|
||||
* Retrieve the parent theme author.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value The parent theme author.
|
||||
* }
|
||||
*/
|
||||
public function get_parent_author() {
|
||||
return [
|
||||
'value' => $this->get_parent_theme()->get( 'Author' ),
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get parent theme name.
|
||||
*
|
||||
* Retrieve the parent theme name.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value The parent theme name.
|
||||
* }
|
||||
*/
|
||||
public function get_parent_name() {
|
||||
return [
|
||||
'value' => $this->get_parent_theme()->get( 'Name' ),
|
||||
];
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,122 @@
|
||||
<?php
|
||||
namespace Elementor\Modules\System_Info\Reporters;
|
||||
|
||||
use Elementor\Utils;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit; // Exit if accessed directly.
|
||||
}
|
||||
|
||||
/**
|
||||
* Elementor user report.
|
||||
*
|
||||
* Elementor system report handler class responsible for generating a report for
|
||||
* the user.
|
||||
*
|
||||
* @since 1.0.0
|
||||
*/
|
||||
class User extends Base {
|
||||
|
||||
public function is_enabled() {
|
||||
return (bool) wp_get_current_user()->ID;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get user reporter title.
|
||||
*
|
||||
* Retrieve user reporter title.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return string Reporter title.
|
||||
*/
|
||||
public function get_title() {
|
||||
return 'User';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get user report fields.
|
||||
*
|
||||
* Retrieve the required fields for the user report.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array Required report fields with field ID and field label.
|
||||
*/
|
||||
public function get_fields() {
|
||||
return [
|
||||
'role' => 'Role',
|
||||
'locale' => 'WP Profile lang',
|
||||
'agent' => 'User Agent',
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get user role.
|
||||
*
|
||||
* Retrieve the user role.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value The user role.
|
||||
* }
|
||||
*/
|
||||
public function get_role() {
|
||||
$role = null;
|
||||
|
||||
$current_user = wp_get_current_user();
|
||||
if ( ! empty( $current_user->roles ) ) {
|
||||
$role = $current_user->roles[0];
|
||||
}
|
||||
|
||||
return [
|
||||
'value' => $role,
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get user profile language.
|
||||
*
|
||||
* Retrieve the user profile language.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value User profile language.
|
||||
* }
|
||||
*/
|
||||
public function get_locale() {
|
||||
return [
|
||||
'value' => get_bloginfo( 'language' ),
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get user agent.
|
||||
*
|
||||
* Retrieve user agent.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value HTTP user agent.
|
||||
* }
|
||||
*/
|
||||
public function get_agent() {
|
||||
return [
|
||||
'value' => esc_html( Utils::get_super_global_value( $_SERVER, 'HTTP_USER_AGENT' ) ),
|
||||
];
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,308 @@
|
||||
<?php
|
||||
namespace Elementor\Modules\System_Info\Reporters;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit; // Exit if accessed directly.
|
||||
}
|
||||
|
||||
/**
|
||||
* Elementor WordPress environment report.
|
||||
*
|
||||
* Elementor system report handler class responsible for generating a report for
|
||||
* the WordPress environment.
|
||||
*
|
||||
* @since 1.0.0
|
||||
*/
|
||||
class WordPress extends Base {
|
||||
|
||||
/**
|
||||
* Get WordPress environment reporter title.
|
||||
*
|
||||
* Retrieve WordPress environment reporter title.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return string Reporter title.
|
||||
*/
|
||||
public function get_title() {
|
||||
return 'WordPress Environment';
|
||||
}
|
||||
|
||||
/**
|
||||
* Get WordPress environment report fields.
|
||||
*
|
||||
* Retrieve the required fields for the WordPress environment report.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array Required report fields with field ID and field label.
|
||||
*/
|
||||
public function get_fields() {
|
||||
return [
|
||||
'version' => 'Version',
|
||||
'site_url' => 'Site URL',
|
||||
'home_url' => 'Home URL',
|
||||
'is_multisite' => 'WP Multisite',
|
||||
'max_upload_size' => 'Max Upload Size',
|
||||
'memory_limit' => 'Memory limit',
|
||||
'max_memory_limit' => 'Max Memory limit',
|
||||
'permalink_structure' => 'Permalink Structure',
|
||||
'language' => 'Language',
|
||||
'timezone' => 'Timezone',
|
||||
'admin_email' => 'Admin Email',
|
||||
'debug_mode' => 'Debug Mode',
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get WordPress memory limit.
|
||||
*
|
||||
* Retrieve the WordPress memory limit.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value WordPress memory limit.
|
||||
* }
|
||||
*/
|
||||
public function get_memory_limit() {
|
||||
return [
|
||||
'value' => (string) WP_MEMORY_LIMIT,
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get WordPress max memory limit.
|
||||
*
|
||||
* Retrieve the WordPress max memory limit.
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value WordPress max memory limit.
|
||||
* }
|
||||
*/
|
||||
public function get_max_memory_limit() {
|
||||
return [
|
||||
'value' => (string) WP_MAX_MEMORY_LIMIT,
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get WordPress version.
|
||||
*
|
||||
* Retrieve the WordPress version.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value WordPress version.
|
||||
* }
|
||||
*/
|
||||
public function get_version() {
|
||||
return [
|
||||
'value' => get_bloginfo( 'version' ),
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Is multisite.
|
||||
*
|
||||
* Whether multisite is enabled or not.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value Yes if multisite is enabled, No otherwise.
|
||||
* }
|
||||
*/
|
||||
public function get_is_multisite() {
|
||||
return [
|
||||
'value' => is_multisite() ? 'Yes' : 'No',
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get site URL.
|
||||
*
|
||||
* Retrieve WordPress site URL.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value WordPress site URL.
|
||||
* }
|
||||
*/
|
||||
public function get_site_url() {
|
||||
return [
|
||||
'value' => get_site_url(),
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get home URL.
|
||||
*
|
||||
* Retrieve WordPress home URL.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value WordPress home URL.
|
||||
* }
|
||||
*/
|
||||
public function get_home_url() {
|
||||
return [
|
||||
'value' => get_home_url(),
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get permalink structure.
|
||||
*
|
||||
* Retrieve the permalink structure
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value WordPress permalink structure.
|
||||
* }
|
||||
*/
|
||||
public function get_permalink_structure() {
|
||||
global $wp_rewrite;
|
||||
|
||||
$structure = $wp_rewrite->permalink_structure;
|
||||
|
||||
if ( ! $structure ) {
|
||||
$structure = 'Plain';
|
||||
}
|
||||
|
||||
return [
|
||||
'value' => $structure,
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get site language.
|
||||
*
|
||||
* Retrieve the site language.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value WordPress site language.
|
||||
* }
|
||||
*/
|
||||
public function get_language() {
|
||||
return [
|
||||
'value' => get_locale(),
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get PHP `max_upload_size`.
|
||||
*
|
||||
* Retrieve the value of maximum upload file size defined in `php.ini` configuration file.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value Maximum upload file size allowed.
|
||||
* }
|
||||
*/
|
||||
public function get_max_upload_size() {
|
||||
return [
|
||||
'value' => size_format( wp_max_upload_size() ),
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get WordPress timezone.
|
||||
*
|
||||
* Retrieve WordPress timezone.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value WordPress timezone.
|
||||
* }
|
||||
*/
|
||||
public function get_timezone() {
|
||||
$timezone = get_option( 'timezone_string' );
|
||||
if ( ! $timezone ) {
|
||||
$timezone = get_option( 'gmt_offset' );
|
||||
}
|
||||
|
||||
return [
|
||||
'value' => $timezone,
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get WordPress administrator email.
|
||||
*
|
||||
* Retrieve WordPress administrator email.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value WordPress administrator email.
|
||||
* }
|
||||
*/
|
||||
public function get_admin_email() {
|
||||
return [
|
||||
'value' => get_option( 'admin_email' ),
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Get debug mode.
|
||||
*
|
||||
* Whether WordPress debug mode is enabled or not.
|
||||
*
|
||||
* @since 1.0.0
|
||||
* @access public
|
||||
*
|
||||
* @return array {
|
||||
* Report data.
|
||||
*
|
||||
* @type string $value Active if debug mode is enabled, Inactive otherwise.
|
||||
* }
|
||||
*/
|
||||
public function get_debug_mode() {
|
||||
return [
|
||||
'value' => WP_DEBUG ? 'Active' : 'Inactive',
|
||||
];
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,43 @@
|
||||
<?php
|
||||
namespace Elementor\Modules\System_Info;
|
||||
|
||||
use Elementor\Core\Admin\Menu\Interfaces\Admin_Menu_Item_With_Page;
|
||||
use Elementor\Settings;
|
||||
use Elementor\Modules\System_Info\Module as System_Info_Page;
|
||||
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit; // Exit if accessed directly.
|
||||
}
|
||||
|
||||
class System_Info_Menu_Item implements Admin_Menu_Item_With_Page {
|
||||
|
||||
private $system_info_page;
|
||||
|
||||
public function __construct( System_Info_Page $system_info_page ) {
|
||||
$this->system_info_page = $system_info_page;
|
||||
}
|
||||
|
||||
public function is_visible() {
|
||||
return true;
|
||||
}
|
||||
|
||||
public function get_parent_slug() {
|
||||
return Settings::PAGE_ID;
|
||||
}
|
||||
|
||||
public function get_label() {
|
||||
return esc_html__( 'System Info', 'elementor' );
|
||||
}
|
||||
|
||||
public function get_page_title() {
|
||||
return esc_html__( 'System Info', 'elementor' );
|
||||
}
|
||||
|
||||
public function get_capability() {
|
||||
return $this->system_info_page->get_capability();
|
||||
}
|
||||
|
||||
public function render() {
|
||||
$this->system_info_page->display_page();
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,27 @@
|
||||
<?php
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit; // Exit if accessed directly.
|
||||
}
|
||||
|
||||
/**
|
||||
* @var array $reports
|
||||
*/
|
||||
foreach ( $reports as $report_name => $report ) : ?>
|
||||
<div class="elementor-system-info-section elementor-system-info-<?php echo esc_attr( $report_name ); ?>">
|
||||
<table class="widefat">
|
||||
<thead>
|
||||
<tr>
|
||||
<th><?php $report['report']->print_html_label( ( $report['label'] ) ); ?></th>
|
||||
<th></th>
|
||||
<th></th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<?php
|
||||
$report['report']->print_html();
|
||||
?>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
<?php
|
||||
endforeach;
|
||||
@@ -0,0 +1,20 @@
|
||||
<?php
|
||||
if ( ! defined( 'ABSPATH' ) ) {
|
||||
exit; // Exit if accessed directly.
|
||||
}
|
||||
|
||||
/**
|
||||
* @var array $reports
|
||||
* @var int $tabs_count
|
||||
*/
|
||||
$tabs_count++;
|
||||
|
||||
foreach ( $reports as $report_name => $report ) :
|
||||
$report['report']->print_raw( $tabs_count );
|
||||
|
||||
if ( ! empty( $report['sub'] ) ) :
|
||||
$this->print_report( $report['sub'], $template, true );
|
||||
endif;
|
||||
endforeach;
|
||||
|
||||
$tabs_count--;
|
||||
Reference in New Issue
Block a user