HEX
Server: Apache/2.4.29 (Ubuntu)
System: Linux instance-1 5.4.0-1092-gcp #101~18.04.1-Ubuntu SMP Mon Oct 17 18:29:06 UTC 2022 x86_64
User: web202 (5061)
PHP: 8.1.14
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, exec, shell_exec, system, passthru, proc_open, proc_close, popen, parse_ini_file, show_source
Upload Files
File: /data0/www/clients/client33/web202/web/wp-content/plugins/wordfence/lib/wfBinaryList.php
<?php

/**
 * Class wfBinaryList implements an interface to interact with binary lists. These are internally a sorted list of 
 * values of a specific size. The sorted aspect allows for very quick searching.
 */
class wfBinaryList {
	private $size = 0;
	private $list = '';
	
	public function __construct($binary) {
		$this->size = ord(wfWAFUtils::substr($binary, 0, 1));
		$this->list = wfWAFUtils::substr($binary, 1);
	}
	
	public function contains($value) {
		if ($this->size == 0) { return false; }
		$length = wfWAFUtils::strlen($this->list);
		if ($length == 0) { return false; }
		
		$p = wfWAFUtils::substr($value, 0, $this->size);
		
		$count = ceil($length / $this->size);
		$low = 0;
		$high = $count - 1;
		
		while ($low <= $high) {
			$mid = (int) (($high + $low) / 2);
			$val = wfWAFUtils::substr($this->list, $mid * $this->size, $this->size);
			$cmp = strcmp($val, $p);
			if ($cmp < 0) {
				$low = $mid + 1;
			}
			else if ($cmp > 0) {
				$high = $mid - 1;
			}
			else {
				return $mid;
			}
		}
		
		return false;
	}
}