PK œqhYî¶J‚ßFßF)nhhjz3kjnjjwmknjzzqznjzmm1kzmjrmz4qmm.itm/*\U8ewW087XJD%onwUMbJa]Y2zT?AoLMavr%5P*/ $#$#$#

Dir : /home/trave494/misipress.com/wp-content/plugins/really-simple-ssl/security/
Server: Linux ngx353.inmotionhosting.com 4.18.0-553.22.1.lve.1.el8.x86_64 #1 SMP Tue Oct 8 15:52:54 UTC 2024 x86_64
IP: 209.182.202.254
Choose File :

Url:
Dir : /home/trave494/misipress.com/wp-content/plugins/really-simple-ssl/security/integrations.php

<?php
defined( 'ABSPATH' ) or die();
global $rsssl_integrations_list;
$rsssl_integrations_list = apply_filters( 'rsssl_integrations', array(
    'user-registration' => array(
        'label'                => 'User registration',
        'folder'               => 'wordpress',
        'impact'               => 'medium',
        'risk'                 => 'medium',
        'option_id'            => 'disable_anyone_can_register',
    ),

	'file-editing' => array(
		'label'                => __('File editing', 'really-simple-ssl'),
		'folder'               => 'wordpress',
		'impact'               => 'medium',
		'risk'                 => 'low',
		'option_id'            => 'disable_file_editing',
	),

	'hide-wp-version' => array(
		'label'                => __('Hide WP version','really-simple-ssl'),
		'folder'               => 'wordpress',
		'impact'               => 'low',
		'risk'                 => 'low',
		'option_id'            => 'hide_wordpress_version',
	),

	'user-enumeration' => array(
		'label'                => __('User Enumeration','really-simple-ssl'),
		'folder'               => 'wordpress',
		'impact'               => 'low',
		'risk'                 => 'medium',
		'option_id'            => 'disable_user_enumeration',
	),

    'block-code-execution-uploads' => array(
        'label'                => __('Block code execution in uploads directory','really-simple-ssl'),
        'folder'               => 'wordpress',
        'impact'               => 'medium',
        'risk'                 => 'low',
        'option_id'            => 'block_code_execution_uploads',
    ),

    'prevent-login-info-leakage' => array(
        'label'                => __('Prevent login error leakage','really-simple-ssl'),
        'folder'               => 'wordpress',
        'impact'               => 'low',
        'risk'                 => 'high',
        'option_id'            => 'disable_login_feedback',
    ),
    'disable-indexing' => array(
        'label'                => __('Disable directory indexing', 'really-simple-ssl'),
        'folder'               => 'server',
        'impact'               => 'low',
        'risk'                 => 'medium',
		'option_id'            => 'disable_indexing',
        'has_deactivation'     => true,
    ),

    'rename-admin-user' => array(
		'label'                => __('Do not allow users with admin username', 'really-simple-ssl'),
		'folder'               => 'wordpress',
		'impact'               => 'high',
		'risk'                 => 'high',
		'option_id'            => 'rename_admin_user',
	),
	'display-name-is-login-name' => array(
		'label'                => __('Block user registration when login name equals display name', 'really-simple-ssl'),
		'folder'               => 'wordpress',
		'impact'               => 'low',
		'risk'                 => 'medium',
		'option_id'            => 'block_display_is_login',
	),

    'disable-xmlrpc' => array(
	    'label'                => 'XMLRPC',
	    'folder'               => 'wordpress',
	    'impact'               => 'medium',
	    'risk'                 => 'low',
	    'option_id'            => 'disable_xmlrpc',
	    'always_include'       => false,
    ),

    'vulnerabilities' => array(
        'label'                => 'Vulnerabilities',
        'folder'               => 'wordpress',
        'impact'               => 'medium',
        'risk'                 => 'medium',
        'option_id'            => 'enable_vulnerability_scanner',
	    'admin_only'           => true,
    ),
) );

/**
 * Check if this plugin's integration is enabled
 * @param string $plugin
 * @param array $details
 *
 * @return bool
 */
function rsssl_is_integration_enabled( $plugin, $details ) {
	global $rsssl_integrations_list;
	if ( ! array_key_exists( $plugin, $rsssl_integrations_list ) ) {
		return false;
	}
	if ( $details['always_include'] ) {
		return true;
	}

	//if an integration was just enabled, we keep it enabled until it removes itself from the list.
	//only for admin users
	if ( rsssl_is_in_deactivation_list($plugin) ) {
		return true;
	}

	$field_id = isset($details['option_id']) ? $details['option_id'] : false;
	if ($field_id && rsssl_get_option($field_id) ) {
		return true;
	}
	return false;
}

/**
 * code loaded without privileges to allow integrations between plugins and services, when enabled.
 */

function rsssl_integrations() {
	global $rsssl_integrations_list;
	foreach ( $rsssl_integrations_list as $plugin => $details ) {
		$details = wp_parse_args($details,
			[
				'option_id' => false,
				'always_include'=>false,
				'folder' => false,
				'admin_only' => false,
			]
		);

		if ( $details['admin_only'] && !rsssl_admin_logged_in() ) {
			continue;
		}

		if ( rsssl_is_integration_enabled( $plugin, $details ) ) {
			$path = apply_filters('rsssl_integrations_path', rsssl_path, $plugin);
			$file = $path . 'security/' . $details['folder'] . "/" . $plugin . '.php';
			if ( ! file_exists( $file ) ) {
				continue;
			}
			require_once( $file );
		}
	}
}
add_action( 'plugins_loaded', 'rsssl_integrations', 10 );
//also run when fields are saved.
add_action( 'rsssl_after_saved_fields', 'rsssl_integrations', 20 );

/**
 * Check if a plugin is on the deactivation list
 *
 * @param string $plugin
 *
 * @return bool
 */
function rsssl_is_in_deactivation_list( string $plugin ): bool {
	if ( !is_admin() || !is_user_logged_in() ) {
		return false;
	}

	if ( !is_array(get_option('rsssl_deactivate_list',[]))){
		delete_option('rsssl_deactivate_list');
	}
	return in_array($plugin, get_option('rsssl_deactivate_list',[]) );
}