PK APOCALYPSE V1

APOCALYPSE V1

Current Path : /home/wallqcyy/www/wp-content/plugins/checkout-plugins-stripe-woo/wizard/
Upload File :
Current File : //home/wallqcyy/www/wp-content/plugins/checkout-plugins-stripe-woo/wizard/onboarding.php

<?php
/**
 * Wizard Class
 *
 * @package checkout-plugins-stripe-woo
 * @since 1.3.0
 */

namespace CPSW\Wizard;

use CPSW\Inc\Traits\Get_Instance;
use CPSW\Admin\Admin_Controller;
use CPSW\Inc\Helper;
/**
 * Onboarding Class - Handles Onboarding Process
 *
 * @since 1.3.0
 */
class Onboarding {
	use Get_Instance;

	/**
	 * Stores slug for WooCommerce plugin
	 *
	 * @var string
	 * @since 1.3.0
	 */
	public $woocommerce_slug = 'woocommerce/woocommerce.php';

	/**
	 * Admin_Controller Object
	 *
	 * @var Admin_Controller
	 * @since 1.3.0
	 */
	public $admin_controller = '';

	/**
	 * Constructor
	 *
	 * @since 1.3.0
	 */
	public function __construct() {
		if ( ! current_user_can( 'manage_options' ) ) {
			return;
		}

		add_action( 'init', [ $this, 'load_classes' ] ); // Moved here.

		add_action( 'admin_menu', [ $this, 'admin_menus' ] );
		add_action( 'admin_init', [ $this, 'setup_wizard' ] );
		add_filter( 'cpsw_stripe_connect_redirect_url', [ $this, 'redirect_to_onboarding' ], 5 );
		add_action( 'cpsw_after_connect_with_stripe', [ $this, 'update_connect_with_stripe_status' ] );
		add_action( 'wp_ajax_cpsw_onboarding_install_woocommerce', [ $this, 'cpsw_onboarding_install_woocommerce' ] );
		add_action( 'wp_ajax_cpsw_onboarding_enable_gateway', [ $this, 'cpsw_onboarding_enable_gateway' ] );
		add_action( 'wp_ajax_cpsw_onboarding_enable_express_checkout', [ $this, 'cpsw_onboarding_enable_express_checkout' ] );
		add_action( 'wp_ajax_cpsw_onboarding_enable_webhooks', [ $this, 'cpsw_onboarding_enable_webhooks' ] );
		add_action( 'wp_ajax_cpsw_onboarding_exit', [ $this, 'cpsw_onboarding_exit' ] );
		add_action( 'admin_init', [ $this, 'hide_notices' ] );
		add_action( 'admin_bar_menu', [ $this, 'admin_bar_icon' ], 999 );
	}

	/**
	 * Sets up base classes.
	 *
	 * @return void
	 */
	public function load_classes() {
		$this->admin_controller = Admin_Controller::get_instance();
	}

	/**
	 * Adding dashboard page for onboarding wizard
	 *
	 * @return void
	 * @since 1.3.0
	 */
	public function admin_menus() {
		// Adds dashboard page for onboarding. Nonce verification may not be required.
		if ( empty( $_GET['page'] ) || 'cpsw-onboarding' !== $_GET['page'] ) { //phpcs:ignore WordPress.Security.NonceVerification.Recommended
			return;
		}

		add_dashboard_page( '', '', 'manage_options', 'cpsw-onboarding', '' );
	}

	/**
	 * Enqueue resource for onboarding wizard
	 *
	 * @return void
	 * @since 1.3.0
	 */
	public function setup_wizard() {
		// Generates HTML for onboarding wizard, Nonce verification may not be required.
		if ( empty( $_GET['page'] ) || 'cpsw-onboarding' !== $_GET['page'] ) { //phpcs:ignore WordPress.Security.NonceVerification.Recommended
			return;
		}

		$this->enqueue_scripts_styles();

		// Stops WooCommerce redirection on activation.
		delete_transient( '_wc_activation_redirect' );

		ob_start();
		$this->setup_wizard_html();
		exit;
	}

	/**
	 * Enqueues scripts and styles required for onboarding wizard
	 *
	 * @return void
	 * @since 1.3.0
	 */
	public function enqueue_scripts_styles() {
		// adding tailwindcss scripts and styles.
		wp_register_style( 'cpsw-onboarding', CPSW_URL . 'wizard/build/app.css', [], CPSW_VERSION );
		wp_enqueue_style( 'cpsw-onboarding' );
		wp_style_add_data( 'cpsw-onboarding', 'rtl', 'replace' );

		$script_asset_path = CPSW_DIR . 'wizard/build/app.asset.php';
		$script_info       = file_exists( $script_asset_path )
			? include $script_asset_path
			: [
				'dependencies' => [],
				'version'      => CPSW_VERSION,
			];

		$script_dep = array_merge( $script_info['dependencies'], [ 'updates' ] );

		wp_register_script( 'cpsw-onboarding', CPSW_URL . 'wizard/build/app.js', $script_dep, CPSW_VERSION, true );
		wp_enqueue_script( 'cpsw-onboarding' );
		wp_localize_script( 'cpsw-onboarding', 'onboarding_vars', $this->localize_vars() );

		wp_register_script( 'cpsw-onboarding-helper', CPSW_URL . 'wizard/js/helper.js', [ 'jquery', 'updates' ], CPSW_VERSION, true );
		wp_enqueue_script( 'cpsw-onboarding-helper' );
	}

	/**
	 * Creates HTML for onboarding wizard
	 *
	 * @return void
	 * @since 1.3.0
	 */
	public function setup_wizard_html() {
		set_current_screen();
		?>
		<html <?php language_attributes(); ?>>
			<head>
				<meta name="viewport" content="width=device-width" />
				<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
				<title><?php esc_html_e( 'Stripe for WooCommerce - Onboarding', 'checkout-plugins-stripe-woo' ); ?></title>

				<script type="text/javascript">
					addLoadEvent = function(func){
						if(typeof jQuery!="undefined")jQuery(document).ready(func);else if(typeof wpOnload!='function'){wpOnload=func;}else{var oldonload=wpOnload;wpOnload=function(){oldonload();func();}}
					};
					var ajaxurl = '<?php echo esc_url( admin_url( 'admin-ajax.php', 'relative' ) ); ?>';
					var pagenow = '';
				</script>
				<?php do_action( 'admin_print_styles' ); ?>
				<?php do_action( 'admin_head' ); ?>
			</head>
			<body class="cpsw-setup wp-core-ui">
				<div class="cpsw-onboarding-content" id="cpsw-onboarding-content"></div>
			</body>
			<?php wp_print_scripts( [ 'cpsw-onboarding' ] ); ?>
			<?php wp_print_scripts( [ 'cpsw-onboarding-helper' ] ); ?>
		</html>
		<?php
	}

	/**
	 * Return url for stripe connect success
	 *
	 * @param string $return_url default return url to admin page.
	 * @return string
	 * @since 1.3.0
	 */
	public function redirect_to_onboarding( $return_url ) {
		return admin_url( 'index.php?page=cpsw-onboarding' );
	}

	/**
	 * Update onboarding setup status
	 *
	 * @param string $status Set status.
	 * @return void
	 * @since 1.3.0
	 */
	public function update_connect_with_stripe_status( $status = 'success' ) {
		if ( ! current_user_can( 'manage_woocommerce' ) ) {
			return;
		}
		update_option( 'cpsw_setup_status', $status );
	}

	/**
	 * Localized variables for onboarding wizard
	 *
	 * @return array
	 * @since 1.3.0
	 */
	public function localize_vars() {
		$redirect_url       = admin_url( 'index.php?page=cpsw-onboarding' );
		$available_gateways = $this->available_gateways();
		return [
			'ajax_url'                                => admin_url( 'admin-ajax.php' ),
			'base_url'                                => $redirect_url,
			'assets_url'                              => CPSW_URL . 'wizard/',
			'authorization_url'                       => $this->admin_controller->get_stripe_connect_url( $redirect_url ),
			'settings_url'                            => admin_url( 'admin.php?page=wc-settings&tab=cpsw_api_settings' ),
			'gateways_url'                            => admin_url( 'admin.php?page=wc-settings&tab=checkout&section=cpsw_stripe' ),
			'manual_connect_url'                      => admin_url( 'admin.php?page=wc-settings&tab=cpsw_api_settings&connect=manually' ),
			'available_gateways'                      => $available_gateways,
			'woocommerce_setup_url'                   => admin_url( 'plugin-install.php?s=woocommerce&tab=search' ),
			'cpsw_onboarding_enable_gateway'          => wp_create_nonce( 'cpsw_onboarding_enable_gateway' ),
			'cpsw_onboarding_enable_express_checkout' => wp_create_nonce( 'cpsw_onboarding_enable_express_checkout' ),
			'cpsw_onboarding_install_woocommerce'     => wp_create_nonce( 'cpsw_onboarding_install_woocommerce' ),
			'cpsw_onboarding_enable_webhooks'         => wp_create_nonce( 'cpsw_onboarding_enable_webhooks' ),
			'cpsw_onboarding_exit'                    => wp_create_nonce( 'cpsw_onboarding_exit' ),
			'woocommerce_installed'                   => $this->is_woocommerce_installed(),
			'woocommerce_activated'                   => class_exists( 'woocommerce' ),
			'navigator_base'                          => '/wp-admin/index.php?page=cpsw-onboarding',
			'onboarding_base'                         => admin_url( 'index.php?page=cpsw-onboarding' ),
			'get_payment_mode'                        => Helper::get_payment_mode(),
			'get_webhook_secret'                      => Helper::get_webhook_secret(),
			'webhook_url'                             => esc_url( get_home_url() . '/wp-json/cpsw/v1/webhook' ),
			'get_element'                             => Helper::get_setting( 'cpsw_element_type' ),
			'plugins_page_url'                        => admin_url( 'plugins.php' ),
			'incomplete_step'                         => get_option( 'cpsw_exit_setup_step' ),
		];
	}

	/**
	 * Returns available gateways as per woocommerce store setup
	 *
	 * @return mixed
	 * @since 1.3.0
	 */
	public function available_gateways() {

		// Return if WooCommerce is not active.
		if ( ! function_exists( 'WC' ) ) {
			return;
		}

		// Retrieves available payment gateways, does not save anything. Nonce verification may not be required.
		if ( empty( $_GET['cpsw_call'] ) ) { //phpcs:ignore WordPress.Security.NonceVerification.Recommended
			return false;
		}

		$gateways = \WC()->payment_gateways->payment_gateways();
		if ( empty( $gateways ) ) {
			return false;
		}

		$available_gateways = [
			[
				'id'          => 'cpsw_stripe',
				'name'        => 'Stripe Card Processing',
				'icon'        => CPSW_URL . 'assets/icon/credit-card.svg',
				'recommended' => true,
				'currencies'  => 'all',
				'enabled'     => true,
			],
		];

		$currency = get_woocommerce_currency();
		foreach ( $gateways as $id => $class ) {
			if (
				0 === strpos( $id, 'cpsw_' ) &&
				method_exists( $class, 'get_supported_currency' ) &&
				in_array( $currency, $class->get_supported_currency(), true )
				) {
				$temp                 = [];
				$icon                 = str_replace( 'cpsw_', '', $id );
				$temp['id']           = $id;
				$temp['name']         = $class->method_title;
				$temp['icon']         = CPSW_URL . 'assets/icon/' . $icon . '.svg';
				$temp['recommended']  = false;
				$temp['currencies']   = implode( ', ', $class->get_supported_currency() );
				$temp['enabled']      = false;
				$available_gateways[] = $temp;
			}
		}

		// Create webhook secret key.
		Admin_Controller::get_instance()->create_webhooks( 'automatic' );

		return $available_gateways;
	}

	/**
	 * Installs WooCommerce if reuired
	 *
	 * @return void
	 * @since 1.3.0
	 */
	public function cpsw_onboarding_install_woocommerce() {
		check_ajax_referer( 'cpsw_onboarding_install_woocommerce', 'security' );

		$activate = activate_plugin( $this->woocommerce_slug, '', false, true );

		if ( is_wp_error( $activate ) ) {
			wp_send_json_error(
				array(
					'success' => false,
					'message' => $activate->get_error_message(),
				)
			);
		}

		wp_send_json_success();
	}

	/**
	 * Handles enabling gateways from onboarding wizard
	 * Returns success / failure in form of json
	 *
	 * @return void
	 * @since 1.3.0
	 */
	public function cpsw_onboarding_enable_gateway() {
		check_ajax_referer( 'cpsw_onboarding_enable_gateway', 'security' );
		// sanitization is being done in later stage using wc_clean function.
		$gateway_status = isset( $_POST['formdata'] ) ? json_decode( wp_unslash( $_POST['formdata'] ), true ) : []; // phpcs:ignore WordPress.Security.ValidatedSanitizedInput.InputNotSanitized

		if ( empty( $gateway_status ) || ! is_array( $gateway_status ) ) {
			wp_send_json_success( [ 'message' => 'no gateway selected' ] );
		}

		// Update element type before activating any gateway to ensure backward compatibility.
		update_option( 'cpsw_element_type', Helper::default_element_type() );

		$gateways = WC()->payment_gateways->payment_gateways();

		$response = [];
		foreach ( $gateway_status as $id => $status ) {
			$status = wc_clean( $status );
			$id     = sanitize_text_field( $id );
			if ( 'true' === $status && isset( $gateways[ $id ] ) ) {
				if ( ( 'yes' !== $gateways[ $id ]->enabled && $gateways[ $id ]->update_option( 'enabled', 'yes' ) ) || 'yes' === $gateways[ $id ]->enabled ) {
					$response[ $id ] = true;
				} else {
					$response[ $id ] = false;
				}
			}
		}

		wp_send_json_success( [ 'activated_gateways' => $response ] );
	}

	/**
	 * Handles Express Checkout enabling call from onboarding wizard
	 *
	 * @return void
	 * @since 1.3.0
	 */
	public function cpsw_onboarding_enable_express_checkout() {
		check_ajax_referer( 'cpsw_onboarding_enable_express_checkout', 'security' );
		if ( ! current_user_can( 'manage_woocommerce' ) ) {
			return;
		}
		$cpsw_stripe = Helper::get_gateway_settings();
		if ( 'yes' === $cpsw_stripe['express_checkout_enabled'] ) {
			wp_send_json_success( [ 'express_checkout' => true ] );
		}
		$cpsw_stripe = array_merge( $cpsw_stripe, [ 'express_checkout_enabled' => 'yes' ] );
		if ( update_option( 'woocommerce_cpsw_stripe_settings', $cpsw_stripe ) ) {
			wp_send_json_success( [ 'express_checkout' => true ] );
		}

		wp_send_json_error( [ 'express_checkout' => false ] );
	}

	/**
	 * Checks if woocommerce is installed
	 *
	 * @return boolean
	 * @since 1.3.0
	 */
	public function is_woocommerce_installed() {
		$plugins = get_plugins();
		if ( isset( $plugins[ $this->woocommerce_slug ] ) ) {
			return true;
		}
		return false;
	}

	/**
	 * Hide onboarding notice on clck of skip setup button
	 *
	 * @return void
	 * @since 1.3.0
	 */
	public function hide_notices() {
		if ( ! isset( $_GET['cpsw-hide-notice'] ) ) {
			return;
		}

		$cpsw_hide_notice   = isset( $_GET['cpsw-hide-notice'] ) ? sanitize_text_field( $_GET['cpsw-hide-notice'] ) : '';
		$_cpsw_notice_nonce = isset( $_GET['_cpsw_notice_nonce'] ) ? sanitize_text_field( $_GET['_cpsw_notice_nonce'] ) : '';

		if ( $cpsw_hide_notice && $_cpsw_notice_nonce && wp_verify_nonce( sanitize_text_field( wp_unslash( $_cpsw_notice_nonce ) ), 'cpsw_hide_notices_nonce' ) ) {
			$this->update_connect_with_stripe_status( 'skipped' );
		}
	}

	/**
	 * Adds admin bar icon for onboarding wizard
	 *
	 * @param object $admin_bar object of WP_Admin_Bar.
	 * @return void
	 * @since 1.3.0
	 */
	public function admin_bar_icon( $admin_bar ) {
		if ( ! current_user_can( 'manage_options' ) || ! is_admin() ) {
			return;
		}

		// Return if he setup is not skipped and connected to the Stripe.
		if (
			'skipped' !== get_option( 'cpsw_setup_status', false ) &&
			$this->admin_controller->is_stripe_connected()
		) {
			return;
		}

		$title = '<span class="cpsw-setup-payment-link" style="float: left;" title="' . __( 'Connect to Stripe for accepting the payments.', 'checkout-plugins-stripe-woo' ) . '">' . __( 'Setup Payments', 'checkout-plugins-stripe-woo' ) . '</span>';

		$onboarding_url = admin_url( 'index.php?page=cpsw-onboarding' );

		// If WooCommerce is not installed then install the WooCommerce first.
		if ( ! class_exists( 'woocommerce' ) ) {
			$onboarding_url = add_query_arg( 'cpsw_call', 'setup-woocommerce', $onboarding_url );
		}

		$args = [
			'id'    => 'cpsw-onboarding-link',
			'title' => $title,
			'href'  => $onboarding_url,
		];
		$admin_bar->add_node( $args );
	}

	/**
	 * Handles webhooks enabling call from onboarding wizard
	 *
	 * @return void
	 * @since 1.10.0
	 */
	public function cpsw_onboarding_enable_webhooks() {
		if ( ! check_ajax_referer( 'cpsw_onboarding_enable_webhooks', 'security', false ) ) {
			wp_send_json_error( [ 'message' => __( 'Nonce verification failed.', 'checkout-plugins-stripe-woo' ) ] );
		}

		$cpsw_mode = Helper::get_payment_mode();

		if ( ! empty( $_POST['cpsw_mode'] ) ) {
			$cpsw_mode = sanitize_text_field( wp_unslash( $_POST['cpsw_mode'] ) );
		}

		// Updating mode.
		update_option( 'cpsw_mode', $cpsw_mode );

		// Function call to create webhook.
		$creation_response = $this->admin_controller->create_webhooks( 'manually', sanitize_text_field( $cpsw_mode ) );

		// Sending JSON response.
		if ( true === $creation_response ) {
			wp_send_json_success( [ 'webhook_secret' => true ] );
		} else {
			// translators: %s - Error reason sent from stripe.
			wp_send_json_error( [ 'message' => sprintf( __( 'Webhook secret key not created.%s', 'checkout-plugins-stripe-woo' ), PHP_EOL . $creation_response ) ] );
		}
	}

	/**
	 * Update option.
	 *
	 * @since 1.10.0
	 * @return void
	 */
	public function cpsw_onboarding_exit() {
		// Nonce verification.
		if ( ! check_ajax_referer( 'cpsw_onboarding_exit', 'security', false ) ) {
			wp_send_json_error( [ 'message' => __( 'Nonce verification failed.', 'checkout-plugins-stripe-woo' ) ] );
		}
		$completed = isset( $_POST['completed'] ) && 'true' === $_POST['completed'];
		$step      = isset( $_POST['current_step'] ) ? sanitize_text_field( wp_unslash( $_POST['current_step'] ) ) : '';
		if ( $completed ) {
			update_option( 'cpsw_setup_complete', 1 );
			delete_option( 'cpsw_exit_setup_step' );
		} else {
			update_option( 'cpsw_setup_complete', 'no' );
			update_option( 'cpsw_exit_setup_step', $step );
		}

		wp_send_json_success();
	}

}

if you don't want to be vaporized in a nuclear explosion, i simply have to become nuclear myself… i am atomic