Файл: Arh/inc/func.php
Строк: 201
<?
defined('WBCAT') or die('Restricted access');
// Функция обработка тегов в тексте
function tags($text = '') {
$text = preg_replace('#[b](.*?)[/b]#si', '<span style="font-weight: bold;">1</span>', $text);
$text = preg_replace('#[i](.*?)[/i]#si', '<span style="font-style:italic;">1</span>', $text);
$text = preg_replace('#[u](.*?)[/u]#si', '<span style="text-decoration:underline;">1</span>', $text);
$text = preg_replace('#[s](.*?)[/s]#si', '<span style="text-decoration: line-through;">1</span>', $text);
$text = preg_replace('#[red](.*?)[/red]#si', '<span style="color:red">1</span>', $text);
$text = preg_replace('#[green](.*?)[/green]#si', '<span style="color:green">1</span>', $text);
$text = preg_replace('#[blue](.*?)[/blue]#si', '<span style="color:blue">1</span>', $text);
$text = preg_replace_callback('~\[url=(https?://.+?)\](.+?)\[/url\]|(https?://(www.)?[0-9a-z.-]+.[0-9a-z]{2,6}[0-9a-zA-Z/?.~&_=/%-:#]*)~', 'url_replace', $text);
return $text;
}
// Функция парсинга ссылки
function url_replace($s) {
if (!isset ($s[3])) {
return '<a href="' . $s[1] . '">' . $s[2] . '</a>';
}
else {
return '<a href="' . $s[3] . '">' . $s[3] . '</a>';
}
}
// Функция смайлов
function smileys($text){
$text = strtr($text, array(
':)'=>'<img src="smileys/1.gif" alt=":)"/>',
':('=>'<img src="smileys/2.gif" alt=":("/>',
':P'=>'<img src="smileys/3.gif" alt=":P"/>',
':D'=>'<img src="smileys/4.gif" alt=":D"/>',
));
return $text;
}
// Преобразование числа в ip
function int2ip($i) {
$d[0]=(int)($i/256/256/256);
$d[1]=(int)(($i-$d[0]*256*256*256)/256/256);
$d[2]=(int)(($i-$d[0]*256*256*256-$d[1]*256*256)/256);
$d[3]=$i-$d[0]*256*256*256-$d[1]*256*256-$d[2]*256;
return "$d[0].$d[1].$d[2].$d[3]";
}
// Преобразование ip в число
function ip2int($ip) {
$a=explode(".",$ip);
return $a[0]*256*256*256+$a[1]*256*256+$a[2]*256+$a[3];
}
// Получаем реальный ip-адрес пользователя
function getip()
{
if (!empty($_SERVER['HTTP_CLIENT_IP']))
{
$ip=htmlspecialchars($_SERVER['HTTP_CLIENT_IP']);
}
elseif (!empty($_SERVER['HTTP_X_FORWARDED_FOR']))
{
$ip=htmlspecialchars($_SERVER['HTTP_X_FORWARDED_FOR']);
}
else
{
$ip=htmlspecialchars($_SERVER['REMOTE_ADDR']);
}
return $ip;
}
// Функция вычисления размера
function format_size($size) {
$sizes = array(" Bytes", " KB", " MB", " GB", " TB", " PB", " EB", " ZB", " YB");
if ($size == 0) { return('n/a'); } else {
return (round($size/pow(1024, ($i = floor(log($size, 1024)))), 2) . $sizes[$i]); }
}
// Функция иконок
function ico_format($text){
$text = strtr($text, array(
'zip'=>'<img src="img/zip.png" alt="zip"/>',
'txt'=>'<img src="img/txt.png" alt="txt"/>',
'rar'=>'<img src="img/rar.png" alt="rar"/>',
'mp3'=>'<img src="img/mp3.gif" alt="mp3"/>',
));
return $text;
}
########################
# Seo-функции
#########################
///////////// Google PR //////////////////
$googlehost='toolbarqueries.google.com';
$googleua='Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.0.6) Gecko/20060728 Firefox/1.5';
function StrToNum($Str, $Check, $Magic) {
$Int32Unit = 4294967296;
$length = strlen($Str);
for ($i = 0; $i < $length; $i++) {
$Check *= $Magic;
if ($Check >= $Int32Unit) {
$Check = ($Check - $Int32Unit * (int) ($Check / $Int32Unit));
$Check = ($Check < -2147483648) ? ($Check + $Int32Unit) : $Check;
}
$Check += ord($Str{$i});
}
return $Check;
}
function HashURL($String) {
$Check1 = StrToNum($String, 0x1505, 0x21);
$Check2 = StrToNum($String, 0, 0x1003F);
$Check1 >>= 2;
$Check1 = (($Check1 >> 4) & 0x3FFFFC0 ) | ($Check1 & 0x3F);
$Check1 = (($Check1 >> 4) & 0x3FFC00 ) | ($Check1 & 0x3FF);
$Check1 = (($Check1 >> 4) & 0x3C000 ) | ($Check1 & 0x3FFF);
$T1 = (((($Check1 & 0x3C0) << 4) | ($Check1 & 0x3C)) <<2 ) | ($Check2 & 0xF0F );
$T2 = (((($Check1 & 0xFFFFC000) << 4) | ($Check1 & 0x3C00)) << 0xA) | ($Check2 & 0xF0F0000 );
return ($T1 | $T2);
}
function CheckHash($Hashnum) {
$CheckByte = 0;
$Flag = 0;
$HashStr = sprintf('%u', $Hashnum) ;
$length = strlen($HashStr);
for ($i = $length-1; $i >= 0; $i--) {
$Re = $HashStr{$i};
if (1 === ($Flag % 2)) {
$Re += $Re;
$Re = (int)($Re / 10) + ($Re % 10);
}
$CheckByte += $Re;
$Flag ++;
}
$CheckByte %= 10;
if (0 !== $CheckByte) {
$CheckByte = 10 - $CheckByte;
if (1 === ($Flag % 2) ) {
if (1 === ($CheckByte % 2)) {
$CheckByte += 9;
}
$CheckByte >>= 1;
}
}
return '7'.$CheckByte.$HashStr;
}
function getch($url) { return CheckHash(HashURL($url)); }
function getpr($url) {
global $googlehost,$googleua;
$ch = getch($url);
$fp = fsockopen($googlehost, 80, $errno, $errstr, 30);
if ($fp) {
$out = "GET /tbr?client=navclient-auto&ch=$ch&features=Rank&q=info:$url HTTP/1.1rn";
$out .= "User-Agent: $googleuarn";
$out .= "Host: $googlehostrn";
$out .= "Connection: Closernrn";
fwrite($fp, $out);
while (!feof($fp)) {
$data = fgets($fp, 128);
$pos = strpos($data, "Rank_");
if($pos === false){
} else{
$pr=substr($data, $pos + 9);
$pr=trim($pr);
$pr=str_replace("n",'',$pr);
if ($pr == "") {return 0;}
else {
return $pr;
}
}
}
fclose($fp);
}
}
////////////// Определяем Alexrank ////////////////
function getAlexaRank($domain)
{
$url = 'http://data.alexa.com/data?cli=10&dat=snbamz&url=' . trim($domain);
$xmldata = simplexml_load_file($url);
if(isset($xmldata->SD[1]->POPULARITY['TEXT'])){
return number_format((string)$xmldata->SD[1]->POPULARITY['TEXT']);
}
else
{
return 0;
}
}
////////////// Определяем ТИЦ ////////////////
function getCI($url)
{
$url = str_replace("http://", "", $url);
$url = str_replace("www.", "", $url);
$url = str_replace("wap.", "", $url);
$ci_url = "http://bar-navig.yandex.ru/u?ver=2&show=32&url=http://www.".$url."/";
$ci_data = implode("", file("$ci_url"));
preg_match("/value="(.d*)"/", $ci_data, $ci);
if ($ci[1] == "")
return 0; // Если не смогли определить ТИЦ...
else
return $ci[1]; // Вот оно счастье...
}
// Проверка корректности url
function check_url($url,$data) { // (www.)?
$a = false;
if (preg_match("/^(([w,-]+.)($data))$/i", $url)) {
$a = true;
}
if (preg_match("/^(([0-9А-яёЁтТыЫ-]+.)(рф))$/",$url)) {
$a = true;
}
return $a;
}
// Вывод преаью текста
function preview_desc ( $str, $length = 150 ) {
if (strstr($str,'[code]')) return '';
$result = substr ( stripslashes( $str ), 0, $length );
while( true ) {
if( $tmp = substr ( stripslashes( $str ), $length, 1 ) ) {
if ( $tmp == ' ' ) break;
$result .= $tmp;
} else break;
$length++;
}
return $result;
}
// Браузер
function ua() {
if (isset($_SERVER['HTTP_USER_AGENT'])) {
if (!empty($_SERVER['HTTP_USER_AGENT'])) {
return htmlspecialchars($_SERVER['HTTP_USER_AGENT']);
} else return 'n/a';
} else return 'n/a';
}
// Вывод сообщения
function print_msg ($array,$bbcode = false,$smileys = false , $module = false) {
$view = '';
$array['date'] = $module == 'book' ? $array['time'] : $array['date'];
$array['text'] = $bbcode ? tags($array['text']) : $array['text'];
$array['text'] = $smileys ? smileys($array['text']) : $array['text'];
$view.= '<a name="'.$array['id'].'"></a>[<b>'.$array['name'].'</b>] <small>['.date('d.m.y H:i',$array['date']).'] <a href="#'.$array['id'].'">#</a></small><br/>'.nl2br($array['text']).'<br/>';
return $view;
}
function check_msg_space($string) {
$count = mb_strlen($string,'UTF-8');
$i = 0;
$space_count = 0;
while($i<$count) {
if (ord($string[$i]) == 32) $space_count++;
$i++;
}
return ($space_count == $count) ? false : true;
}
// Автозагрузка классов
function __autoload($classname) {
require_once("classes/$classname.php");
}
//////
function seo_news(){
function updates(){
error_reporting(0);
$str=@file_get_contents('http://www.pr-cy.ru/updates.xml');
preg_match( "'<cy>(.*?)</cy>'si", $str, $rez1 );
preg_match( "'<pr>(.*?)</pr>'si", $str, $rez2 );
preg_match( "'<yav>(.*?)</yav>'si", $str, $rez3 );
$rez4 = array ($rez1[1],$rez2[1],$rez3[1]);
return $rez4;
}
function elm($str){
$elms = explode(" ", $str); // Выбрать из строки даты день, месяц и год
return $elms;
}
function days($m, $d, $y){ // Дней назад
$tm=time(); // Сегодня
$rez1=intval(($tm-mktime(0, 0, 0, $m, $d, $y))/86400,10); // Разница между сегодня и апдейтом (в сутках 86400 секунд)
if($rez1==0){$rez=' (сегодня)';}else
if($rez1==1){$rez=' (вчера)';}else
if($rez1==2){$rez=' (позавчера)';}else
if($rez1==3){$rez=' (' .$rez1 .' дня назад)';}else
if($rez1==4){$rez=' (' .$rez1 .' дня назад)';}else
$rez=' (' .$rez1 .' дней назад)';
return $rez;
}
$out = updates();
$cy=$out[0]; $pr=$out[1]; $yv=$out[2];
$cy1=preg_replace ( "'.'si", ' ',$cy); // Замена точек на пробелы в строке даты
$pr1=preg_replace ( "'.'si", ' ',$pr);
$yv1=preg_replace ( "'.'si", ' ',$yv);
$ecy=elm($cy1); $epr=elm($pr1); $eyv=elm($yv1);
$cyd=$ecy[0]; $cym=$ecy[1]; $cyy=$ecy[2];
$prd=$epr[0]; $prm=$epr[1]; $pry=$epr[2];
$yvd=$eyv[0]; $yvm=$eyv[1]; $yvy=$eyv[2];
$daycy=days($cym,$cyd,$cyy); $daypr=days($prm,$prd,$pry); $dayyv=days($yvm,$yvd,$yvy);
$rezlt = '<div class="maintxt">Яндекс ТИЦ: ' .$cy .$daycy .'</br>
Google PR: ' .$pr .$daypr .'</br>
Яндекс выдача: ' .$yv .$dayyv .'</div>';
return $rezlt;
}
?>