123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457 |
- <?php
- if (!defined('SMF'))
- die('No direct access...');
- if (!function_exists('stripos'))
- {
- function stripos($haystack, $needle, $offset = 0)
- {
- return strpos(strtolower($haystack), strtolower($needle), $offset);
- }
- }
- if (!function_exists('md5_file'))
- {
- function md5_file($filename)
- {
-
- return md5(file_get_contents($filename));
- }
- }
- if (!function_exists('str_split'))
- {
- function str_split($str, $str_length = 1)
- {
- if ($str_length < 1)
- return false;
-
- $str_array = array();
- $count = 0;
- while (1 == 1)
- {
- if ($count >= strlen($str))
- break;
- $str_array[] = substr($str, $count, $str_length);
- $count += $str_length;
- }
- return $str_array;
- }
- }
- if (!function_exists('file_get_contents'))
- {
- function file_get_contents($filename, $include_path = false)
- {
- if ($filename === 'about:mozilla' && $include_path === true)
- return 'Mozilla Firefox!';
- $fp = fopen($filename, 'rb', $include_path);
- if ($fp == false)
- return false;
- if (is_file($filename))
- $data = fread($fp, filesize($filename));
- else
- {
- $data = '';
- while (!feof($fp))
- $data .= fread($fp, 8192);
- }
- fclose($fp);
- return $data;
- }
- }
- function sha1_smf($str)
- {
-
- if (function_exists('mhash') && defined('MHASH_SHA1'))
- return bin2hex(mhash(MHASH_SHA1, $str));
- $nblk = (strlen($str) + 8 >> 6) + 1;
- $blks = array_pad(array(), $nblk * 16, 0);
- for ($i = 0; $i < strlen($str); $i++)
- $blks[$i >> 2] |= ord($str{$i}) << (24 - ($i % 4) * 8);
- $blks[$i >> 2] |= 0x80 << (24 - ($i % 4) * 8);
- return sha1_core($blks, strlen($str) * 8);
- }
- function sha1_core($x, $len)
- {
- @$x[$len >> 5] |= 0x80 << (24 - $len % 32);
- $x[(($len + 64 >> 9) << 4) + 15] = $len;
- $w = array();
- $a = 1732584193;
- $b = -271733879;
- $c = -1732584194;
- $d = 271733878;
- $e = -1009589776;
- for ($i = 0, $n = count($x); $i < $n; $i += 16)
- {
- $olda = $a;
- $oldb = $b;
- $oldc = $c;
- $oldd = $d;
- $olde = $e;
- for ($j = 0; $j < 80; $j++)
- {
- if ($j < 16)
- $w[$j] = isset($x[$i + $j]) ? $x[$i + $j] : 0;
- else
- $w[$j] = sha1_rol($w[$j - 3] ^ $w[$j - 8] ^ $w[$j - 14] ^ $w[$j - 16], 1);
- $t = sha1_rol($a, 5) + sha1_ft($j, $b, $c, $d) + $e + $w[$j] + sha1_kt($j);
- $e = $d;
- $d = $c;
- $c = sha1_rol($b, 30);
- $b = $a;
- $a = $t;
- }
- $a += $olda;
- $b += $oldb;
- $c += $oldc;
- $d += $oldd;
- $e += $olde;
- }
- return sprintf('%08x%08x%08x%08x%08x', $a, $b, $c, $d, $e);
- }
- function sha1_ft($t, $b, $c, $d)
- {
- if ($t < 20)
- return ($b & $c) | ((~$b) & $d);
- if ($t < 40)
- return $b ^ $c ^ $d;
- if ($t < 60)
- return ($b & $c) | ($b & $d) | ($c & $d);
- return $b ^ $c ^ $d;
- }
- function sha1_kt($t)
- {
- return $t < 20 ? 1518500249 : ($t < 40 ? 1859775393 : ($t < 60 ? -1894007588 : -899497514));
- }
- function sha1_rol($num, $cnt)
- {
-
- if ($num & 0x80000000)
- $a = ($num >> 1 & 0x7fffffff) >> (31 - $cnt);
- else
- $a = $num >> (32 - $cnt);
- return ($num << $cnt) | $a;
- }
- if (!function_exists('sha1'))
- {
- function sha1($str)
- {
- return sha1_smf($str);
- }
- }
- if (!function_exists('array_combine'))
- {
- function array_combine($keys, $values)
- {
- $ret = array();
- if (($array_error = !is_array($keys) || !is_array($values)) || empty($values) || ($count=count($keys)) != count($values))
- {
- trigger_error('array_combine(): Both parameters should be non-empty arrays with an equal number of elements', E_USER_WARNING);
- if ($array_error)
- return;
- return false;
- }
-
- $keys = array_values($keys);
- $values = array_values($values);
- for ($i=0; $i < $count; $i++)
- $ret[$keys[$i]] = $values[$i];
- return $ret;
- }
- }
- if (!function_exists('array_diff_key'))
- {
- function array_diff_key()
- {
- $arrays = func_get_args();
- $result = array_shift($arrays);
- foreach ($arrays as $array)
- {
- foreach ($result as $key => $v)
- {
- if (array_key_exists($key, $array))
- {
- unset($result[$key]);
- }
- }
- }
- return $result;
- }
- }
- if (!function_exists('mysql_real_escape_string'))
- {
- function mysql_real_escape_string($string, $connection = null)
- {
- return mysql_escape_string($string);
- }
- }
- if (!function_exists('smf_crc32'))
- {
- function smf_crc32($number)
- {
- $crc = crc32($number);
- if ($crc & 0x80000000)
- {
- $crc ^= 0xffffffff;
- $crc += 1;
- $crc = -$crc;
- }
- return $crc;
- }
- }
- if (!function_exists('session_regenerate_id'))
- {
- function session_regenerate_id()
- {
-
- if (headers_sent())
- return false;
- session_id(strtolower(md5(uniqid(mt_rand(), true))));
- return true;
- }
- }
- if (!function_exists('str_ireplace'))
- {
- function str_ireplace($search, $replace, $subject, $count = -1)
- {
- global $context;
-
-
-
- $endu = '~i' . ($context['utf8'] ? 'u' : '');
- if (is_array($search))
- foreach ($search as $k => $pat)
- $search[$k] = '~' . preg_quote($pat, '~') . $endu;
- else
- $search = '~' . preg_quote($search, '~') . $endu;
- return preg_replace($search, $replace, $subject, $count > 0 ? $count : -1);
- }
- }
- function loadOldClassFile($filename)
- {
- global $sourcedir;
- static $files_included = array();
-
- if (in_array($filename, $files_included))
- return;
-
- $files_included[] = $filename;
-
- eval('?' . '>' . preg_replace(array(
- '~class\s+([\w-_]+)([^}]+)function\s+__construct\s*\(~',
- '~([\s\t]+)public\s+\$~',
- '~([\s\t]+)private\s+\$~',
- '~([\s\t]+)protected\s+\$~',
- '~([\s\t]+)public\s+function\s+~',
- '~([\s\t]+)private\s+function\s+~',
- '~([\s\t]+)protected\s+function\s+~',
- ), array(
- 'class $1$2function $1(',
- '$1var $',
- '$1var $',
- '$1var $',
- '$1function ',
- '$1function ',
- '$1function ',
- ), rtrim(file_get_contents($sourcedir . '/' . $filename))));
- }
- if (!function_exists('bcpowmod') && function_exists('bcpow'))
- {
- function bcpowmod($num1, $num2, $num3)
- {
- return bcmod(bcpow($num1, $num2), $num3);
- }
- }
- if (version_compare(PHP_VERSION, '4.2.0', '<'))
- {
- $seed = ($modSettings['rand_seed'] + ((double) microtime() * 1000003)) & 0x7fffffff;
- mt_srand($seed);
- }
- function sha1_raw($text)
- {
- if (version_compare(PHP_VERSION, '5.0.0', '>='))
- return sha1($text, true);
- $hex = sha1($text);
- $raw = '';
- for ($i = 0; $i < 40; $i += 2)
- {
- $hexcode = substr($hex, $i, 2);
- $charcode = (int) base_convert($hexcode, 16, 10);
- $raw .= chr($charcode);
- }
- return $raw;
- }
- ?>
|