HEX
Server: Apache/2.4.52 (Ubuntu)
System: Linux ip-172-31-4-197 6.8.0-1036-aws #38~22.04.1-Ubuntu SMP Fri Aug 22 15:44:33 UTC 2025 x86_64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/html/wordpress/wp-content/plugins/hide-my-wp/models/compatibility/Woocommerce.php
<?php
/**
 * WooCommerce Class
 *
 * @file The WooCommerce Model file
 * @package HMWP/Compatibility/WooCommerce
 */

defined('ABSPATH') || die('Cheatin\' uh?');

class HMWP_Models_Compatibility_Woocommerce extends HMWP_Models_Compatibility_Abstract
{

    public function __construct()
    {
	    parent::__construct();

	    add_action('admin_url', array($this, 'admin_url'), PHP_INT_MAX, 3);

        if(HMWP_Classes_Tools::getValue('noredicts')) {
            add_filter('woocommerce_is_rest_api_request', '__return_false');
        }

	    // If brute force is active
	    if (HMWP_Classes_Tools::getOption('hmwp_bruteforce') &&  HMWP_Classes_Tools::getOption('hmwp_bruteforce_woocommerce')) {

		    // Load the brute force for woocommerce login/register process
		    $this->hookBruteForce();

		    // Load brute force comments on Woocommerce reviews
		    if ( HMWP_Classes_Tools::getOption( 'hmwp_bruteforce_comments' ) ) {
			    add_filter( 'woocommerce_product_review_comment_form_args', array(HMWP_Classes_ObjController::getClass( 'HMWP_Models_Bruteforce_Comments' ), 'formArgs'), 99 );
		    }

	    }else{

		    //Check if WooCommerce login support is loaded
		    if(HMWP_Classes_Tools::getValue('woocommerce-login-nonce')) {
			    add_filter('hmwp_preauth_check', '__return_false');
		    }

	    }

	    //If Login/Signup Popup is active and logged in through it
	    if(HMWP_Classes_Tools::isPluginActive('easy-login-woocommerce/xoo-el-main.php')
	       && !HMWP_Classes_Tools::getOption('brute_use_math')
	       && HMWP_Classes_Tools::isAjax()
	       && HMWP_Classes_Tools::getValue('xoo-el-username')
	       && HMWP_Classes_Tools::getValue('xoo-el-password') ) {

		    add_filter('hmwp_preauth_check', '__return_false');
	    }
    }

	public function hookBruteForce() {

		// Get the active brute force class
		$bruteforce = HMWP_Classes_ObjController::getClass( 'HMWP_Models_Brute' )->getInstance();

		add_filter( 'woocommerce_login_form', array( $bruteforce, 'head' ), 99 );
		add_filter( 'woocommerce_login_form', array( $bruteforce, 'form' ), 99 );

		if ( HMWP_Classes_Tools::getOption( 'hmwp_bruteforce_register' ) ) {
			if ( ! HMWP_Classes_Tools::getOption( 'brute_use_captcha_v3' ) ) {

				add_filter( 'woocommerce_registration_errors', function( $errors, $sanitizedLogin, $userEmail ) {

					//check if the registering process is on woocommerce checkout
					//if woocommerce nonce is correct return
					$nonce_value = HMWP_Classes_Tools::getValue( 'woocommerce-process-checkout-nonce', HMWP_Classes_Tools::getValue( '_wpnonce' ) );
					if ( wp_verify_nonce( $nonce_value, 'woocommerce-process_checkout' ) ) {
						return $errors;
					}

					// Get the brute force registration class
					return HMWP_Classes_ObjController::getClass( 'HMWP_Models_Bruteforce_Registration' )->call( $errors, $sanitizedLogin, $userEmail );
				}, 99, 3 );
			}
			add_filter( 'woocommerce_register_form', array( $bruteforce, 'head' ), 99 );
			add_filter( 'woocommerce_register_form', array( $bruteforce, 'form' ), 99 );
		}

		if ( HMWP_Classes_Tools::getOption( 'hmwp_bruteforce_lostpassword' ) ) {
			add_action( 'lostpassword_post', array( HMWP_Classes_ObjController::getClass( 'HMWP_Models_Bruteforce_LostPassword' ), 'call' ), 99, 2 );
			add_filter( 'woocommerce_lostpassword_form', array( $bruteforce, 'head' ), 99 );
			add_filter( 'woocommerce_lostpassword_form', array( $bruteforce, 'form' ), 99 );
		}

	}


	/**
     * Fix the admin url if wrong redirect
     *
     * @param mixed $url
     * @param mixed $path
     * @param mixed $blog_id
     */
    public function admin_url( $url, $path, $blog_id )
    {
        if (HMWP_Classes_Tools::getDefault('hmwp_admin_url') <> HMWP_Classes_Tools::getOption('hmwp_admin_url')) {

            if (strpos( $url, '/wp-admin/' . HMWP_Classes_Tools::getOption('hmwp_admin_url') . '/' ) !== false ) {
                $url = str_replace('/' . HMWP_Classes_Tools::getOption('hmwp_admin_url') . '/', '/', $url);
            }

        }

        return $url;

    }

	/**
	 * Show the reCaptcha form on login/register
	 *
	 * @return void
	 */
	public function woocommerce_brute_recaptcha_form()
	{
		?>
		<script src='https://www.google.com/recaptcha/api.js?hl=<?php echo(HMWP_Classes_Tools::getOption('brute_captcha_language') <> '' ? HMWP_Classes_Tools::getOption('brute_captcha_language') : get_locale()) ?>' async defer></script>
		<style>#login{min-width: 354px;}</style>
		<?php

		if (HMWP_Classes_Tools::getOption('brute_captcha_site_key') <> '' && HMWP_Classes_Tools::getOption('brute_captcha_secret_key') <> '') {
			?>
			<div class="g-recaptcha" data-sitekey="<?php echo HMWP_Classes_Tools::getOption('brute_captcha_site_key') ?>" data-theme="<?php echo HMWP_Classes_Tools::getOption('brute_captcha_theme') ?>"></div>
			<?php
		}
	}

	/**
	 * reCaptcha V3 support for WooCommerce
	 * @return void
	 */
	public function woocommerce_brute_recaptcha_form_v3()
	{
		?>
		<script src='https://www.google.com/recaptcha/api.js?render=<?php echo HMWP_Classes_Tools::getOption('brute_captcha_site_key_v3') ?>' async defer></script>
		<style>#login{min-width: 354px;}</style>
		<?php

		if (HMWP_Classes_Tools::getOption('brute_captcha_site_key_v3') <> '' && HMWP_Classes_Tools::getOption('brute_captcha_secret_key_v3') <> '') {
			?>
			<script>
                function reCaptchaSubmit(e) {
                    var form = this;
                    e.preventDefault();

                    grecaptcha.ready(function() {
                        grecaptcha.execute('<?php echo HMWP_Classes_Tools::getOption('brute_captcha_site_key_v3') ?>', {action: 'submit'}).then(function(token) {
                            //add google data
                            var input = document.createElement("input");
                            input.type = "hidden";
                            input.name = "g-recaptcha-response" ;
                            input.value = token ;
                            form.appendChild(input);

                            //complete form integration
                            var submit = document.createElement("input");
                            submit.type = "hidden";
                            submit.name = "login" ;
                            form.appendChild(submit);

                            form.submit();
                        });
                    });
                }

                if(document.getElementsByTagName("form").length > 0) {
                    var x = document.getElementsByTagName("form");
                    for (var i = 0; i < x.length; i++) {
                        x[i].addEventListener("submit", reCaptchaSubmit);
                    }
                }
			</script>
			<?php
		}
	}

}