File "rlrsssl-really-simple-ssl.php"

Full Path: /home/arielcor/public_html/wp-content/plugins/revslider/rlrsssl-really-simple-ssl.php
File size: 10.35 KB
MIME-type: text/x-php
Charset: utf-8

<?php
/**
 * Plugin Name: Really Simple SSL
 * Plugin URI: https://really-simple-ssl.com
 * Description: Lightweight SSL & Hardening Plugin
 * Version: 6.1.1
 * Author: Really Simple Plugins
 * Author URI: https://really-simple-plugins.com
 * License: GPL2
 * Text Domain: really-simple-ssl
 * Domain Path: /languages
 */
/*  Copyright 2020  Really Simple Plugins BV  (email : support@really-simple-ssl.com)
    This program is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License, version 2, as
    published by the Free Software Foundation.
    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.
    You should have received a copy of the GNU General Public License
    along with this program; if not, write to the Free Software
    Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
*/
defined('ABSPATH') or die("you do not have access to this page!");

if (!function_exists('rsssl_activation_check')) {
	/**
	 * Checks if the plugin can safely be activated, at least php 5.6 and wp 4.8
	 */
	function rsssl_activation_check()
	{
		if (version_compare(PHP_VERSION, '7.2', '<')) {
			deactivate_plugins(plugin_basename(__FILE__));
			wp_die(__('Really Simple SSL cannot be activated. The plugin requires PHP 7.2 or higher', 'really-simple-ssl'));
		}

		global $wp_version;
		if (version_compare($wp_version, '5.7', '<')) {
			deactivate_plugins(plugin_basename(__FILE__));
			wp_die(__('Really Simple SSL cannot be activated. The plugin requires WordPress 5.7 or higher', 'really-simple-ssl'));
		}
        update_option('rsssl_show_onboarding', true);
        set_transient('rsssl_redirect_to_settings_page', true, HOUR_IN_SECONDS );
    }
	register_activation_hook( __FILE__, 'rsssl_activation_check' );
}

class REALLY_SIMPLE_SSL
{
	private static $instance;
	public $front_end;
	public $mixed_content_fixer;
	public $multisite;
	public $cache;
	public $server;
	public $admin;
	public $progress;
	public $onboarding;
	public $placeholder;
	public $certificate;
	public $wp_cli;
	public $site_health;

	private function __construct()
	{
        if (isset($_GET['rsssl_apitoken']) && $_GET['rsssl_apitoken'] == get_option('rsssl_csp_report_token') ) {
            if ( !defined('RSSSL_LEARNING_MODE') ) define( 'RSSSL_LEARNING_MODE' , true );
        }
	}

	public static function instance()
	{
		if (!isset(self::$instance) && !(self::$instance instanceof REALLY_SIMPLE_SSL)) {
			self::$instance = new REALLY_SIMPLE_SSL;
			self::$instance->setup_constants();
			self::$instance->includes();
			self::$instance->front_end = new rsssl_front_end();
			self::$instance->mixed_content_fixer = new rsssl_mixed_content_fixer();

			$wpcli = defined( 'WP_CLI' ) && WP_CLI;
			if ( is_multisite() ) {
				self::$instance->multisite = new rsssl_multisite();
			}
			if ( is_admin() || rsssl_is_logged_in_rest() || wp_doing_cron() || $wpcli || defined('RSSSL_DOING_SYSTEM_STATUS') || defined('RSSSL_LEARNING_MODE') ) {
				self::$instance->cache = new rsssl_cache();
				self::$instance->placeholder = new rsssl_placeholder();
				self::$instance->server = new rsssl_server();
				self::$instance->admin = new rsssl_admin();
				self::$instance->onboarding = new rsssl_onboarding();
				self::$instance->progress = new rsssl_progress();
				self::$instance->certificate = new rsssl_certificate();
				self::$instance->site_health = new rsssl_site_health();
                if ( $wpcli ) {
					self::$instance->wp_cli = new rsssl_wp_cli();
				}
			}
			self::$instance->hooks();
		}
		return self::$instance;
	}

	private function setup_constants()
	{
		define('rsssl_url', plugin_dir_url(__FILE__));
		define('rsssl_path', trailingslashit(plugin_dir_path(__FILE__)));
        define('rsssl_template_path', trailingslashit(plugin_dir_path(__FILE__)).'grid/templates/');
        define('rsssl_plugin', plugin_basename(__FILE__));
        define('rsssl_add_on_version_requirement', '6.0');
        if (!defined('rsssl_file') ){
            define('rsssl_file', __FILE__);
        }
		define('rsssl_version', '6.1.1');
		define('rsssl_le_cron_generation_renewal_check', 20);
		define('rsssl_le_manual_generation_renewal_check', 15);
	}

	private function includes()
	{
		require_once(rsssl_path . 'class-front-end.php');
		require_once(rsssl_path . 'functions.php');
		require_once(rsssl_path . 'class-mixed-content-fixer.php');
		$wpcli = defined( 'WP_CLI' ) && WP_CLI;
		if ( $wpcli ) {
			require_once( rsssl_path . 'class-wp-cli.php');
		}
		if ( is_multisite() ) {
			require_once( rsssl_path . 'class-multisite.php');
		}
		if ( is_admin() || rsssl_is_logged_in_rest() ||  wp_doing_cron() || $wpcli || defined('RSSSL_DOING_SYSTEM_STATUS') || defined('RSSSL_LEARNING_MODE') ) {
			require_once( rsssl_path . 'compatibility.php');
            require_once( rsssl_path . 'upgrade.php');
			require_once( rsssl_path . 'settings/settings.php' );
            require_once( rsssl_path . 'onboarding/config.php' );
            require_once( rsssl_path . 'onboarding/class-onboarding.php' );
            require_once( rsssl_path . 'placeholders/class-placeholder.php' );
            require_once( rsssl_path . 'class-admin.php');
			require_once( rsssl_path . 'class-cache.php');
			require_once( rsssl_path . 'class-server.php');
            require_once( rsssl_path . 'progress/class-progress.php');
			require_once( rsssl_path . 'class-certificate.php');
			require_once( rsssl_path . 'class-site-health.php');
			if ( isset($_GET['install_pro'])) {
				require_once( rsssl_path . 'upgrade/upgrade-to-pro.php');
			}
		}

		if ( is_admin() || rsssl_is_logged_in_rest() || wp_doing_cron() ) {
            require_once( rsssl_path . 'lets-encrypt/letsencrypt.php' );
        }

        require_once( rsssl_path . 'lets-encrypt/cron.php' );
		require_once( rsssl_path . '/security/security.php');
	}

	private function hooks()
	{
		/**
		 * Fire custom hook
		 */
		if ( is_admin() ) {
			add_action('admin_notices', array( $this, 'admin_notices'));
            if ( is_multisite() ) {
	            add_action('network_admin_notices', array( $this, 'admin_notices'));
            }
		}

		add_action('wp_loaded', array(self::$instance->front_end, 'force_ssl'), 20);
		if ( is_admin() ) {
			add_action('plugins_loaded', array(self::$instance->admin, 'init'), 10);
		}
	}

	/**
	 * Notice about possible compatibility issues with add ons
	 */
	public static function admin_notices() {
		//prevent showing on edit screen, as gutenberg removes the class which makes it editable.
		$screen = get_current_screen();
		if ( $screen && $screen->base === 'post' ) return;
		if ( self::has_old_addon('really-simple-ssl-pro/really-simple-ssl-pro.php') ||
		     self::has_old_addon('really-simple-ssl-pro-multisite/really-simple-ssl-pro-multisite.php' )
		) {
			$license = get_site_option('rsssl_pro_license_key');
			if ( strpos( $license , 'really_simple_ssl_') !== FALSE ) {
				$key = get_site_option( 'rsssl_key' );
				$string = str_replace('really_simple_ssl_', '', $license);
				$ivlength = openssl_cipher_iv_length('aes-256-cbc');
				$iv = substr(base64_decode($string), 0, $ivlength);
				$encrypted_data = substr(base64_decode($string), $ivlength);
				$license =  openssl_decrypt($encrypted_data, 'aes-256-cbc', $key, 0, $iv);
			}
			$item_id = is_multisite() ? 35206 : 860;
			$update_link = add_query_arg(['plugin'=>'rsssl_pro', 'license'=>$license, 'item_id'=>$item_id, 'install_pro'=>true], admin_url('plugins.php') );
			?>
			<div id="message" class="error notice really-simple-plugins">
				<p><?php echo __("Update Really Simple SSL Pro: the plugin needs to be updated to the latest version to be compatible.","really-simple-ssl");?></p>
                <p>
                    <?php
                    if (!empty($license) ) {
	                    echo sprintf(__("%sUpdate%s or %srenew your license%s.","really-simple-ssl"),'<a href="'.$update_link.'.">','</a>','<a href="https://really-simple-ssl.com/pro" target="_blank">','</a>');
                    } else {
                        echo sprintf(__("Visit the plugins overview or %srenew your license%s.","really-simple-ssl"),'<a href="https://really-simple-ssl.com/pro" target="_blank">','</a>');
                   }
                    ?>
                </p>
			</div>
			<?php
		}
	}

	/**
	 * Check if we have a pre 4.0 add on active which should be upgraded
	 * @param $file
	 *
	 * @return bool
	 */

	public static function has_old_addon($file) {
		require_once(ABSPATH.'wp-admin/includes/plugin.php');
		$data = false;
		if ( is_plugin_active($file)) $data = get_plugin_data( trailingslashit(WP_PLUGIN_DIR) . $file, false, false );
		if ($data && version_compare($data['Version'], '6.0.0', '<')) {
			return true;
		}

		if ($data && $data['Name']==='Really Simple SSL social' && version_compare($data['Version'], '4.0.8', '<')) {
			return true;
		}
		return false;
	}
}

if ( ! function_exists('rsssl_add_manage_security_capability')){
	/**
	 * Add a user capability to WordPress and add to admin and editor role
	 */
	function rsssl_add_manage_security_capability(){
		$capability = 'manage_security';
		$roles = apply_filters('rsssl_add_manage_security_capability', array('administrator') );
		foreach( $roles as $role ){
			$role = get_role( $role );
			if( $role && !$role->has_cap( $capability ) ){
				$role->add_cap( $capability );
			}
		}
	}

	register_activation_hook( __FILE__, 'rsssl_add_manage_security_capability' );
}

if ( ! function_exists( 'rsssl_user_can_manage' ) ) {
	/**
     * Check if user has required capability
	 * @return bool
	 */
	function rsssl_user_can_manage() {
		if ( current_user_can('manage_security') ) {
			return true;
		}

        #allow wp-cli access to activate ssl
		if ( defined( 'WP_CLI' ) && WP_CLI ){
            return true;
        }

		return false;
	}
}

function RSSSL()
{
	global $wp_version;
	if ( version_compare($wp_version, '5.7', '>=') && version_compare(PHP_VERSION, '7.2', '>=')) {
		return REALLY_SIMPLE_SSL::instance();
	}
}
add_action('plugins_loaded', 'RSSSL', 8);

if ( !function_exists('rsssl_is_logged_in_rest')){
	function rsssl_is_logged_in_rest(){
		$valid_request = isset($_SERVER['REQUEST_URI']) && strpos($_SERVER['REQUEST_URI'], '/reallysimplessl/v1/')!==false;
        if ( !$valid_request ) {
            return false;
        }
        return is_user_logged_in();
	}
}