HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux wordpress-ubuntu-s-2vcpu-4gb-fra1-01 5.4.0-169-generic #187-Ubuntu SMP Thu Nov 23 14:52:28 UTC 2023 x86_64
User: root (0)
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/linde/wp-content/plugins/better-wp-security/core/modules/firewall/Extension.php
<?php

namespace iThemesSecurity\Modules\Firewall;

use iThemesSecurity\Lib\Lockout;
use iThemesSecurity\Strauss\Patchstack\Extensions\ExtensionInterface;

class Extension implements ExtensionInterface {

	/** @var \ITSEC_Lockout */
	private $lockout;

	public function __construct( \ITSEC_Lockout $lockout ) { $this->lockout = $lockout; }

	public function logRequest( $ruleId, $bodyData, $blockType ) {
		$code = $blockType . '::' . $ruleId;
		$data = [
			'body_data'  => $bodyData,
			'user_agent' => $_SERVER['HTTP_USER_AGENT'] ?? '',
			'method'     => $_SERVER['REQUEST_METHOD'] ?? '',
		];

		if ( $blockType === 'BLOCK' ) {
			$context = new Lockout\Host_Context( 'firewall' );

			if ( \ITSEC_Lib_IP_Detector::is_configured() ) {
				$this->lockout->do_lockout( $context );
			} else {
				$this->lockout->execute_lock( $context->make_execute_lock_context() );
			}

			\ITSEC_Log::add_action( 'firewall', $code, $data );
		} else {
			\ITSEC_Log::add_notice( 'firewall', $code, $data );
		}
	}

	public function canBypass( $isMuCall ) {
		if ( ! \ITSEC_Lib_IP_Detector::is_configured() ) {
			return false;
		}

		return \ITSEC_Lib::is_ip_whitelisted( $this->getIpAddress() );
	}

	public function isBlocked( $minutes, $blockTime, $attempts ) {
		if ( ! \ITSEC_Lib_IP_Detector::is_configured() ) {
			return false;
		}

		return $this->lockout->is_host_locked_out( $this->getIpAddress() );
	}

	public function forceExit( $ruleId ) {
		$this->lockout->execute_lock( $this->lockout_context()->make_execute_lock_context() );
	}

	public function getIpAddress() {
		return \ITSEC_Lib::get_ip();
	}

	public function getHostName() {
		return parse_url( home_url(), PHP_URL_HOST );
	}

	public function isWhitelisted( $whitelistRules, $request ) {
		return false;
	}

	public function isFileUploadRequest() {
		return isset( $_FILES ) && count( $_FILES ) > 0;
	}

	private function lockout_context(): Lockout\Context {
		return new Lockout\Host_Context( 'firewall' );
	}
}