HEX
Server: Apache/2
System: Linux host.jethost.pl 4.19.0-26-amd64 #1 SMP Debian 4.19.304-1 (2024-01-09) x86_64
User: frigodor (1049)
PHP: 7.4.33
Disabled: exec,system,passthru,shell_exec,proc_close,proc_open,dl,popen,show_source,posix_kill,posix_mkfifo,posix_getpwuid,posix_setpgid,posix_setsid,posix_setuid,posix_setgid,posix_seteuid,posix_setegid,posix_uname,mail
Upload Files
File: /home/frigodor/domains/frigodor.pl/public_html/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;
	}
}