HEX
Server: Apache
System: Linux vps.teamads.com 4.18.0-553.126.1.el8_10.x86_64 #1 SMP Thu May 28 06:44:09 EDT 2026 x86_64
User: teamadsc (1024)
PHP: 8.1.34
Disabled: NONE
Upload Files
File: /home/teamadsc/public_html/wp-content/plugins/wp-defender/src/model/setting/class-mask-login.php
<?php
/**
 * Handles the Mask Login settings.
 *
 * @package WP_Defender\Model\Setting
 */

namespace WP_Defender\Model\Setting;

use Calotes\Model\Setting;

/**
 * Model for Mask Login settings.
 */
class Mask_Login extends Setting {

	/**
	 * Option name.
	 *
	 * @var string
	 */
	protected $table = 'wd_masking_login_settings';
	/**
	 * The URL we use to replace tradition wp-admin.
	 *
	 * @var string
	 * @defender_property
	 * @sanitize_mask_url
	 */
	public $mask_url = '';

	/**
	 * Enable to redirect if user visit to tradition wp-admin or wp-login.php.
	 *
	 * @var string
	 * @defender_property
	 */
	public $redirect_traffic = 'off';

	/**
	 * The URL to redirect.
	 *
	 * @var string
	 * @defender_property
	 * @sanitize sanitize_text_field
	 */
	public $redirect_traffic_url = '';

	/**
	 * The page/post id to redirect.
	 *
	 * @var int
	 * @defender_property
	 */
	public $redirect_traffic_page_id;

	/**
	 * Main switch of this function.
	 *
	 * @var bool
	 * @defender_property
	 */
	public $enabled = false;

	/**
	 * The ticket so anyone with this can bypass the mask login, we'll need this in certain cases.
	 * Todo: need if express_tickets are not saved?
	 *
	 * @var array
	 */
	public $express_tickets = array();

	/**
	 * Backward compatibility with older version.
	 *
	 * @var array
	 */
	protected $mapping = array(
		'express_tickets' => 'otps',
	);

	/**
	 * Define settings labels.
	 *
	 * @return array
	 */
	public function labels() {
		return array(
			'enabled'                  => self::get_module_name(),
			'mask_url'                 => esc_html__( 'Masking URL', 'wpdef' ),
			'redirect_traffic'         => esc_html__( 'Redirect traffic', 'wpdef' ),
			'redirect_traffic_url'     => esc_html__( 'Redirection URL', 'wpdef' ),
			'redirect_traffic_page_id' => esc_html__(
				'Select the page or post your default login URLs will redirect to',
				'wpdef'
			),
		);
	}

	/**
	 * Checks if the mask login is active.
	 *
	 * @return bool Returns true if the mask login is active, false otherwise.
	 */
	public function is_active() {
		return apply_filters(
			'wd_mask_login_enable',
			$this->enabled && ! $this->is_mask_url_empty() && ! $this->is_mask_url_page_post_exists()
		);
	}

	/**
	 * Returns the new login URL based on the mask URL and the given domain.
	 *
	 * @param  string|null $domain  The domain to use for the URL. If null, the current site URL will be used.
	 *
	 * @return string The new login URL. Returns an empty string if the mask URL is empty.
	 */
	public function get_new_login_url( $domain = null ) {
		if ( '' === $this->mask_url ) {
			return '';
		}

		if ( null === $domain ) {
			$domain = site_url();
		}

		return $domain . '/' . ltrim( $this->get_mask_url(), '/' );
	}

	/**
	 * Retrieves the redirect URL based on the provided redirect traffic URL.
	 *
	 * @return string The redirect URL. Returns an empty string if the redirect traffic URL is empty.
	 */
	public function get_redirect_url(): string {
		if ( '' === $this->redirect_traffic_url ) {
			return '';
		}

		return 'url' === $this->is_url_or_slug()
			? $this->redirect_traffic_url
			: untrailingslashit( get_home_url( get_current_blog_id() ) ) . '/' . ltrim(
				$this->redirect_traffic_url,
				'/'
			);
	}

	/**
	 * Check the entered string is URL or slug of the internal link.
	 *
	 * @return string
	 */
	public function is_url_or_slug(): string {
		$regex = '/^(http:\/\/www\.|https:\/\/www\.|http:\/\/|https:\/\/)?[a-z0-9]+([\-\.]{1}[a-z0-9]+)*\.[a-z]{2,5}(:[\d]{1,5})?(\/.*)?$/i';

		if ( preg_match( $regex, $this->redirect_traffic_url ) ) {
			return 'url';
		} else {
			return 'slug';
		}
	}

	/**
	 * Custom validate:
	 * 1. No forbidden URL
	 * 2. No conflict with current post/page slug
	 * 3. Mask URl should not same with redirect URL
	 *
	 * @return void
	 */
	protected function after_validate(): void {
		if ( '' !== $this->mask_url ) {
			/**
			 * Filter forbidden slugs.
			 *
			 * @since 3.8.0
			 */
			$forbidden = apply_filters(
				'wd_login_forbidden_slugs',
				array(
					'login',
					'wp-admin',
					'admin',
					'dashboard',
					'wp-login',
					'wp-login.php',
					// For change '.' to '-'.
					'wp-login-php',
				)
			);
			// Remove the double slash.
			$this->mask_url = ltrim( $this->mask_url, '/\\' );
			if ( in_array( $this->mask_url, $forbidden, true ) ) {
				$this->errors[] = esc_html__(
					'The slug you have provided cannot be used for masking your login area. Please try a new one.',
					'wpdef'
				);
			} elseif ( $this->is_mask_url_page_post_exists() ) {
				$this->errors[] = esc_html__(
					'A page already exists at this URL. Please enter a unique URL for your login area.',
					'wpdef'
				);
			} elseif ( $this->mask_url === $this->redirect_traffic_url ) {
				$this->errors[] = esc_html__( 'Redirect URL must different from Login URL', 'wpdef' );
			}
		}
	}

	/**
	 * Check if Mask URL slug is empty.
	 *
	 * @return bool
	 * @since 3.12.0
	 */
	public function is_mask_url_empty(): bool {
		return '' === ltrim( $this->mask_url, '/\\' );
	}

	/**
	 * Check if page/post already exists for the Mask URL.
	 *
	 * @return bool
	 * @since 3.12.0
	 */
	public function is_mask_url_page_post_exists(): bool {
		$mask_url = ltrim( $this->mask_url, '/\\' );
		if ( '' === $mask_url ) {
			return false;
		}

		$found = false;
		if ( is_multisite() ) {
			$offset = 0;
			$limit  = 100;
			while ( $blog_ids = get_sites( // phpcs:ignore Generic.CodeAnalysis.AssignmentInCondition.FoundInWhileCondition
				array(
					'fields' => 'ids',
					'number' => $limit,
					'offset' => $offset,
				)
			) ) {
				if ( is_array( $blog_ids ) ) {
					foreach ( $blog_ids as $blog_id ) {
						switch_to_blog( $blog_id );

						$found = is_object( get_page_by_path( $mask_url, OBJECT, array( 'post', 'page' ) ) );

						restore_current_blog();

						if ( true === $found ) {
							break 2;
						}
					}
				}
				$offset += $limit;
			}
		} else {
			$found = is_object( get_page_by_path( $mask_url, OBJECT, array( 'post', 'page' ) ) );
		}

		return $found;
	}

	/**
	 * Retrieves the name of the Mask Login Area module.
	 *
	 * @return string The name of the Mask Login Area module.
	 */
	public static function get_module_name(): string {
		return esc_html__( 'Mask Login Area', 'wpdef' );
	}

	/**
	 * Check if the permalink structure is empty.
	 *
	 * @return bool
	 */
	public function is_permalink_structure_empty(): bool {
		$permalink_structure = get_option( 'permalink_structure' );

		return '' === $permalink_structure;
	}

	/**
	 * Retrieves the mask URL based on the permalink structure option.
	 *
	 * @return string The mask URL.
	 */
	public function get_mask_url(): string {
		if ( $this->is_permalink_structure_empty() ) {
			return '?' . $this->mask_url;
		} else {
			return $this->mask_url;
		}
	}
}