File "config.php"

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

<?php defined('ABSPATH') or die();
/**
 * Two possibilities:
 * - a new install: show activation notice, and process onboarding
 * - an upgrade to 6. Only show new features.
 * @param WP_REST_Request $request
 * @return array
 */

function rsssl_rest_api_onboarding($request) {
	$is_upgrade = get_option('rsssl_show_onboarding');
	// "warning", // yellow dot
	// "error", // red dot
	// "active" // green dot
	$steps = [];
	$info = "";
	$refresh = isset($_GET['forceRefresh']) && $_GET['forceRefresh']===true;
	$nonce = $_GET['nonce'] ?? false;
	if ( !wp_verify_nonce($nonce, 'rsssl_nonce') ) {
		return [];
	}
	if( !defined('rsssl_pro_version')) {
		$info = __('You can also let the automatic scan of the pro version handle this for you, and get premium support, increased security with HSTS and more!', 'really-simple-ssl'). " " . sprintf('<a target="_blank" href="%s">%s</a>', RSSSL()->admin->pro_url, __("Check out Really Simple SSL Pro", "really-simple-ssl"));;
	}

	if ( !rsssl_get_option('ssl_enabled') || get_site_option('rsssl_network_activation_status')!=='completed' ) {
		$steps[] = [
			"id" => 'activate_ssl',
			"title" => __( "Almost ready to migrate to SSL!", 'really-simple-ssl' ),
			"subtitle" => __("Before you migrate, please check for:", "really-simple-ssl"),
			"items" => rsssl_get_items_for_first_step(),
			"info_text" => $info,
			"visible" => false
		];
	}

	$steps[] = [
		"id" => 'onboarding',
		"title" => $is_upgrade ? __( "Thanks for updating!", 'really-simple-ssl' ) : __( "Congratulations!", 'really-simple-ssl' ),
		"subtitle" => __("Now have a look at our new features.", "really-simple-ssl"),
		"items" => rsssl_get_items_for_second_step(),
		"info_text" => __("Want to know more about our features and plugins?", "really-simple-ssl").' '.sprintf(__("Please read this %sarticle%s.", 'really-simple-ssl'), '<a target="_blank" href="https://really-simple-ssl.com/meet-really-simple-ssl-6/">', '</a>'),
		"visible" => false
	];

	//if the user called with a refresh action, clear the cache
	if ($refresh) {
		delete_transient('rsssl_certinfo');
	}
	return [
		"steps" => $steps,
		"ssl_enabled" => rsssl_get_option("ssl_enabled"),
		"ssl_detection_overridden" => get_option('rsssl_ssl_detection_overridden'),
		'certificate_valid' => RSSSL()->certificate->is_valid(),
		"networkwide" => is_multisite() && rsssl_is_networkwide_active(),
		"network_activation_status" => get_site_option('rsssl_network_activation_status'),
	];
}

/**
 * Returns onboarding items if user upgraded plugin to 6.0 or SSL is detected
 * @return array
 */
function rsssl_get_items_for_second_step () {
	$plugins_to_install = [
		[
			"slug" => "burst-statistics",
			'constant_premium' => false,
			"title" => "Burst Statistics",
			"description" => __("Burst Statistics - Self-hosted, Privacy-friendly analytics tool", "really-simple-ssl"),
		],
		[
			"slug" => "complianz-gdpr",
			'constant_premium' => 'cmplz_premium',
			"title" => "Complianz",
			"description" => __("Complianz - Cookie Consent Management as it should be", "really-simple-ssl"),
		]
	];

	$items = [];
	$items[] = [
		"id" => 'ssl_enabled',
		"title" => __("SSL has been activated", "really-simple-ssl"),
		"action" => "none",
		"status" => "success",
	];


	$all_enabled = RSSSL()->onboarding->all_recommended_hardening_features_enabled();
	if( !$all_enabled ) {
		$items[] = [
			"title" => __("Enable recommended hardening features in Really Simple SSL", "really-simple-ssl"),
			"id" => "hardening",
			"action" => "activate_setting",
			"current_action" => "none",
			"status" => "warning",
			"button" => __("Enable", "really-simple-ssl"),
		];
	} else {
		$items[] = [
			"title" => __("Hardening features are enabled!", "really-simple-ssl"),
			"action" => "none",
			"current_action" => "none",
			"status" => "success",
			"id" => "hardening",
		];
	}

	foreach ($plugins_to_install as $plugin_info) {
		require_once(rsssl_path . 'class-installer.php');
		$plugin = new rsssl_installer($plugin_info["slug"]);
		$premium_active = $plugin_info['constant_premium'] && defined($plugin_info['constant_premium']);
		$free_active = $plugin->plugin_is_downloaded() && $plugin->plugin_is_activated();
		if( $premium_active || $free_active ) {
			$items[] = [
				"title" => sprintf(__("%s has been installed!", "really-simple-ssl"), $plugin_info["title"]),
				"action" => "none",
				"current_action" => "none",
				"status" => "success",
			];
		} else if( !$plugin->plugin_is_downloaded() && !$plugin->plugin_is_activated() ){
			$items[] = [
				"title" => $plugin_info["description"],
				"action" => "install_plugin",
				"current_action" => "none",
				"status" => "warning",
				"id" => $plugin_info['slug'],
				"button" => __("Install", "really-simple-ssl"),
			];
		} else if ( $plugin->plugin_is_downloaded() && !$plugin->plugin_is_activated() ) {
			$items[] = [
				"title" => sprintf(__("Activate our plugin %s", "really-simple-ssl"), $plugin_info["title"]),
				"action" => "activate",
				"current_action" => "none",
				"status" => "warning",
				"id" => $plugin_info['slug'],
				"button" => __("Activate", "really-simple-ssl"),
			];
		}


	}

	return $items;
}

/**
 * Return onboarding items for fresh installs
 * @param $ssl_detected
 * @return array[]
 */
function rsssl_get_items_for_first_step () {
	$items = [
		[
			"title" => __("Http references in your .css and .js files: change any http:// into https://", "really-simple-ssl"),
			"status" => "inactive",
		],
		[
			"title" => __("Images, stylesheets or scripts from a domain without an SSL certificate: remove them or move to your own server.", "really-simple-ssl"),
			"status" => "inactive",
		],
		[
			"title" => __("You may need to login in again.", "really-simple-ssl"),
			"status" => "inactive",
		],
	];

	if ( RSSSL()->certificate->is_valid() ) {
		$items[] = [
			"title" => __("An SSL certificate has been detected", "really-simple-ssl"),
			"status" => "success"
		];
	} else if ( RSSSL()->certificate->detection_failed() ) {
		$items[] = [
			"title" => __("Could not test certificate.", "really-simple-ssl") . " " . __("Automatic certificate detection is not possible on your server.", "really-simple-ssl"),
			"status" => "error"
		];
	} else {
		$items[] = [
			"title" => __("No SSL certificate has been detected.", "really-simple-ssl") . " " . __("Please refresh the SSL status if a certificate has been installed recently.", "really-simple-ssl"),
			"status" => "error"
		];
	}

	return $items;
}