Вход Регистрация
Файл: sys/inc/fnc.php
Строк: 242
<?php 

function my_esc($str)
{
      return 
mysql_real_escape_string($str);
}

/**
* Резервная функция мультиязычности
* @return string
*/
function __($str)
{
      return 
$str;
}


// Защита от частых запросов с одного IP
if ($set['antidos']) {
    
$antidos[] = array('time' => $time);
    
$k_loads 0;
    
    if (
is_file(H.'sys/tmp/antidos_'.$iplong.'.dat')) {
        
$antidos_dat unserialize(file_get_contents(H.'sys/tmp/antidos_'.$iplong.'.dat'));
        
        for (
$i 0$i 150 && $i sizeof($antidos_dat); $i++) {
            if(
$antidos_dat[$i]['time'] > $time 5) {
                
$k_loads++;
                
$antidos[] = $antidos_dat[$i];
            }
        }
    }
    
    if (
$k_loads>100)
    {
        if (
mysql_result(mysql_query("SELECT COUNT(*) FROM `ban_ip` WHERE `min` <= '$iplong' AND `max` >= '$iplong'"), 0) == 0)
            
mysql_query("INSERT INTO `ban_ip` (`min`, `max`, `prich`) values('$iplong', '$iplong', 'AntiDos')");
    }
    @
file_put_contents(H.'sys/tmp/antidos_'.$iplong.'.dat'serialize($antidos));
    @
chmod(H.'sys/tmp/antidos_'.$iplong.'.dat'0777);
}

// антимат сделает автоматическое предупреждение, а затем бан
function antimat($str)
{
    global 
$user$time$set;
    if (
$set['antimat']) {
        
$antimat $_SESSION['antimat'];
        
        include_once 
H.'sys/inc/censure.php';
        
        
$censure censure($str);
        
        if (
$censure) {
            
$antimat[$censure] = $time;
            
            if (
count($antimat) > && isset($user) && $user['level']) {
                
$prich "Обнаружен мат: $censure";
                
$timeban $time 60 60
                
mysql_query("INSERT INTO `ban` (`id_user`, `id_ban`, `prich`, `time`) VALUES ('$user[id]', '0', '$prich', '$timeban')");
                
admin_log('Пользователи''Бан'"Бан пользователя '[url=/amd_panel/ban.php?id=$user[id]]$user[nick][/url]' (id#$user[id]) до ".vremja($timeban)." по причине '$prich'");
                
header('Location: /ban.php?'.SID);
                exit;
            }
            return 
$censure;
        }
        else return 
false;
    }
    else return 
false;
}

// рекурсивное удаление папки
function delete_dir($dir
{
    if (
is_dir($dir)){
        
$od opendir($dir);
        while (
$rd readdir($od))
        {
            if (
$rd == '.' || $rd == '..'
                continue;
            if (
is_dir("$dir/$rd")) {
                @
chmod("$dir/$rd"0777);
                
delete_dir("$dir/$rd");
            } else {
                @
chmod("$dir/$rd"0777);
                @
unlink("$dir/$rd");
            }
        }
        
closedir($od);
        @
chmod($dir0777);
        return @
rmdir($dir);
    } else {
        @
chmod($dir0777);
        @
unlink($dir);
    }
}


// очистка временной папки
if (!isset($hard_process)) {
    
$q mysql_query("SELECT * FROM `cron` WHERE `id` = 'clear_tmp_dir'");
    if (
mysql_num_rows($q) == 0)
        
mysql_query("INSERT INTO `cron` (`id`, `time`) VALUES ('clear_tmp_dir', '$time')");
    
    
$clear_dir mysql_fetch_assoc($q);
    if (!
$clear_dir['time'] || $clear_dir['time'] < $time 60 60 24){
        
$hard_process true;
        
mysql_query("UPDATE `cron` SET `time` = '$time' WHERE `id` = 'clear_tmp_dir'");


        
$od opendir(H.'sys/tmp/');
        while (
$rd=readdir($od)) 
        {
            if (!
preg_match('#^.#',$rd) && filectime(H.'sys/tmp/'.$rd) < $time 60 60 24){
                @
delete_dir(H.'sys/tmp/'.$rd);
            }
        }
        
closedir($od);
    }
}

// Подведение итогов статистики
if (!isset($hard_process)) {
    
$q mysql_query("SELECT * FROM `cron` WHERE `id` = 'visit' LIMIT 1");
    if (
mysql_num_rows($q) == 0)
        
mysql_query("INSERT INTO `cron` (`id`, `time`) VALUES ('visit', '$time')");
    
    
$visit mysql_fetch_assoc($q);
    if (
$visit['time'] == NULL || $visit['time'] < time() - 60 60 24){
        if (
function_exists('set_time_limit'))
            @
set_time_limit(600); 
            
        
$last_day mktime(000date('m'), date('d') - 1); 
        
$today_time mktime(000);
        
        if (
mysql_result(mysql_query("SELECT COUNT(*) FROM `visit_everyday` WHERE `time` = '$last_day'"),0) == 0) {
            
$hard_process true;
            
            
mysql_query("INSERT INTO `visit_everyday` (`host` , `host_ip_ua`, `hit`, `time`) 
                          VALUES ((SELECT COUNT(DISTINCT `ip`) FROM `visit_today` WHERE `time` < '
$today_time'),
                                (SELECT COUNT(DISTINCT `ip`, `ua`) FROM `visit_today` WHERE `time` < '
$today_time'),
                                (SELECT COUNT(*) FROM `visit_today` WHERE `time` < '
$today_time'),'$last_day')");
            
            
mysql_query('DELETE FROM `visit_today` WHERE `time` < '.$today_time);
        }
    }
}

// запись о переходах на сайт
if (isset($_SERVER['HTTP_REFERER']) && !preg_match('#'.preg_quote($_SERVER['HTTP_HOST']).'#'$_SERVER['HTTP_REFERER']) && 
        
$ref = @parse_url($_SERVER['HTTP_REFERER'])) {
    if (isset(
$ref['host']))
        
$_SESSION['http_referer'] = $ref['host'];
}

function 
br($msg,$br='<br />')
{
      return 
preg_replace("#((<br( ?/?)>)|n|r)+#i",$br$msg);
}

function 
esc($text,$br=NULL) {
    if (
$br!=NULL)
    for (
$i 0$i <= 31$i++)
        
$text=str_replace(chr($i), NULL$text);
    else {
        for (
$i=0;$i<10;$i++)$text=str_replace(chr($i), NULL$text);
        for (
$i=11;$i<20;$i++)$text=str_replace(chr($i), NULL$text);
        for (
$i=21;$i<=31;$i++)$text=str_replace(chr($i), NULL$text);
    }
    return 
$text;
}

// получаем данные пользователя и уровень прав (+ кеширование)
function get_user($user_id 0)
{
    if (
$user_id == 0) {
        
$ank2['id'] = 0;
        
$ank2['nick'] = 'Система';
        
$ank2['level'] = 999;
        
$ank2['pol'] = 1;
        
$ank2['group_name'] = 'Системный робот';
        
$ank2['ank_o_sebe'] = 'Создан для уведомлений';
        return 
$ank2;
    } 
    
    else {
        static 
$users
        
$user_id intval($user_id);
        
$users[0] = false;
        if (!isset(
$users[$user_id])) {
            if (
mysql_result(mysql_query("SELECT COUNT(*) FROM `user` WHERE `id` = '$user_id'"),0)==1)
            {
                
$users[$user_id] = mysql_fetch_assoc(mysql_query("SELECT * FROM `user` WHERE `id` = '$user_id' LIMIT 1"));
                
$tmp_us mysql_fetch_assoc(mysql_query("SELECT `level`,`name` AS `group_name` 
                                                         FROM `user_group` 
                                                         WHERE `id` = '"
.$users[$user_id]['group_access']."' LIMIT 1"));

                if (
$tmp_us['group_name']==null) {
                    
$users[$user_id]['level'] = 0;
                    
$users[$user_id]['group_name']='Пользователь';
                } else {
                    
$users[$user_id]['level']=$tmp_us['level'];
                    
$users[$user_id]['group_name']=$tmp_us['group_name'];
                }
            }
            else 
$users[$user_id] = false;
        }
        return 
$users[$user_id];
    }
}

// определение оператора
function opsos($ips NULL)
{
    global 
$ip;
    if (
$ips == NULL)
        
$ips $ip;
    
$ipl ip2long($ips);
    
    if (
mysql_result(mysql_query("SELECT COUNT(*) FROM `opsos` WHERE `min` <= '$ipl' AND `max` >= '$ipl'"), 0) != 0) {
        
$opsos mysql_fetch_assoc(mysql_query("SELECT opsos FROM `opsos` WHERE `min` <= '$ipl' AND `max` >= '$ipl' LIMIT 1"));
        return 
stripcslashes(htmlspecialchars($opsos['opsos']));
    }
    else return 
false;
}

// вывод времени
function vremja($time=NULL)
{
    global 
$user;
    
    if (
$time == NULL)
        
$time=time();
        
    if (isset(
$user))
        
$time=$time+$user['set_timesdvig']*60*60;
    
    
$timep date("j M Y в H:i"$time);
    
$time_p[0] = date("j n Y"$time);
    
$time_p[1] = date("H:i"$time);
    
    if (
$time_p[0]==date("j n Y"))
        
$timep=date("H:i:s"$time);
        
    if (isset(
$user)) {
        if (
$time_p[0] == date("j n Y"time()+$user['set_timesdvig']*60*60))
            
$timep date("H:i:s"$time);
        if (
$time_p[0] == date("j n Y"time()-60*60*(24-$user['set_timesdvig'])))
            
$timep "Вчера в $time_p[1]";
    } else {
    if (
$time_p[0] == date("j n Y"))
        
$timep=date("H:i:s"$time);
    if (
$time_p[0] == date("j n Y"time()-60*60*24))
        
$timep "Вчера в $time_p[1]";
    }
    
    
$timep str_replace("Jan","Янв"$timep);
    
$timep str_replace("Feb","Фев"$timep);
    
$timep str_replace("Mar","Марта"$timep);
    
$timep str_replace("May","Мая"$timep);
    
$timep str_replace("Apr","Апр"$timep);
    
$timep str_replace("Jun","Июня"$timep);
    
$timep str_replace("Jul","Июля"$timep);
    
$timep str_replace("Aug","Авг"$timep);
    
$timep str_replace("Sep","Сент"$timep);
    
$timep str_replace("Oct","Окт"$timep);
    
$timep str_replace("Nov","Ноября"$timep);
    
$timep str_replace("Dec","Дек"$timep);
    return 
$timep;
}

// только для зарегистрированых
function only_reg($link NULL
{
    global 
$user;
    
    if (!isset(
$user)) {
        if (
$link == NULL)
            
$link '/index.php?'.SID;
        
        
header("Location: $link");
        exit;
    }
}


// только для незарегистрированых
function only_unreg($link NULL
{
    global 
$user;
    
    if (isset(
$user)){
        if (
$link == NULL)
            
$link '/index.php?'.SID;
        
        
header("Location: $link");
        exit;
    }
}


// только для тех, у кого уровень доступа больше или равен $level
function only_level($level=0,$link NULL
{
    global 
$user;
    
    if (!isset(
$user) || $user['level'] < $level) {
        if (
$link==NULL)
            
$link='/index.php?'.SID;
        
        
header("Location: $link");
        exit;
    }
}

if (!isset(
$hard_process)) {
    
$q mysql_query("SELECT * FROM `cron` WHERE `id` = 'everyday'");

    if (
mysql_num_rows($q)==0)
        
mysql_query("INSERT INTO `cron` (`id`, `time`) VALUES ('everyday', '".time()."')");

    
$everyday mysql_fetch_assoc($q);
    if (
$everyday['time'] == NULL || $everyday['time']<time()-60*60*24) {
        
$hard_process true;
        
        if (
function_exists('set_time_limit'))@set_time_limit(600); // Ставим ограничение на 10 минут
        
mysql_query("UPDATE `cron` SET `time` = '".time()."' WHERE `id` = 'everyday'");
        
mysql_query("DELETE FROM `guests` WHERE `date_last` < '".(time()-600)."'");
        
mysql_query("DELETE FROM `chat_post` WHERE `time` < '".(time()-60*60*24)."'"); // удаление старых постов в чате
        
mysql_query("DELETE FROM `user` WHERE `activation` != null AND `time_reg` < '".(time()-60*60*24)."'"); // удаление неактивированных аккаунтов

        // удаляем все контакты, помеченные на удаление более месяца назад
        
$qd mysql_query("SELECT * FROM `users_konts` WHERE `type` = 'deleted' AND `time` < ".($time-60*60*24*30));
        
        while (
$deleted=mysql_fetch_array($qd)) 
        {
            
mysql_query("DELETE FROM `users_konts` WHERE `id_user` = '$deleted[id_user]' AND `id_kont` = '$deleted[id_kont]'");

            if (
mysql_result(mysql_query("SELECT COUNT(*) FROM `users_konts` WHERE `id_kont` = '$deleted[id_user]' AND `id_user` = '$deleted[id_kont]'"),0)==0)
            {
                
// если юзер не находится в контакте у другого, то удаляем и все сообщения
                
mysql_query("DELETE FROM `mail` WHERE `id_user` = '$deleted[id_user]' AND `id_kont` = '$deleted[id_kont]' OR `id_kont` = '$deleted[id_user]' AND `id_user` = '$deleted[id_kont]'");
            }
        }
        
        
$tab mysql_query('SHOW TABLES FROM '.$set['mysql_db_name']);
        for(
$i 0$i mysql_num_rows($tab); $i++)
        {
            
mysql_query("OPTIMIZE TABLE `".mysql_tablename($tab,$i)."`"); // оптимизация таблиц
        
}
    }
}


// вывод ошибок
function err()
{
    global 
$err;
    
    if (isset(
$err)) {
        if (
is_array($err)) {
            foreach (
$err as $key => $value
            {
                echo 
"<div class='err'>$value</div>n";
            }
        }
        else echo 
"<div class='err'>$err</div>n";
    }
}

function 
msg($msg)
{
    echo 
"<div class='msg'>$msg</div>n";
}

// отправка запланированных писем
$q mysql_query("SELECT * FROM `mail_to_send` LIMIT 1");

if (
mysql_num_rows($q) != 0) {
    
$mail mysql_fetch_assoc($q);
    
$adds="From: "admin@$_SERVER[HTTP_HOST]" <admin@$_SERVER[HTTP_HOST]>n";
    
$adds .= "Content-Type: text/html; charset=utf-8n";
    
mail($mail['mail'], '=?utf-8?B?'.base64_encode($mail['them']).'?='$mail['msg'], $adds);
    
mysql_query("DELETE FROM `mail_to_send` WHERE `id` = '$mail[id]'");
}

// сохранение настроек системы
function save_settings($set)
{
    unset(
$set['web']);
    if (
$fopen = @fopen(H.'sys/dat/settings_6.2.dat''w')) {
        @
fputs($fopenserialize($set));
        @
fclose($fopen);
        @
chmod(H.'sys/dat/settings_6.2.dat'0777);
        return 
true;
    } 
    
    else return 
false;
}

// запись действий администрации
function admin_log($mod,$act,$opis)
{
    global 
$user;

    
$q mysql_query("SELECT * FROM `admin_log_mod` WHERE `name` = '".my_esc($mod)."' LIMIT 1");
    
    if (
mysql_num_rows($q)==0)
    {
        
mysql_query("INSERT INTO `admin_log_mod` (`name`) VALUES ('".my_esc($mod)."')");
        
$id_mod mysql_insert_id();
    }
    else 
$id_mod mysql_result($q0);

    
$q2 mysql_query("SELECT * FROM `admin_log_act` WHERE `name` = '".my_esc($act)."' AND `id_mod` = '$id_mod' LIMIT 1");
    if (
mysql_num_rows($q2) == 0)
    {
        
mysql_query("INSERT INTO `admin_log_act` (`name`, `id_mod`) VALUES ('".my_esc($act)."', '$id_mod')");
        
$id_act mysql_insert_id();
    }
    else 
$id_act mysql_result($q20);
    
    
mysql_query("INSERT INTO `admin_log` (`time`, `id_user`, `mod`, `act`, `opis`) 
                  VALUES ('"
.time()."','$user[id]', '$id_mod', '$id_act', '".my_esc($opis)."')");
}

// Загрузка остальных функций из папки "sys/fnc"
$opdirbase opendir(H.'sys/fnc');

while (
$filebase readdir($opdirbase))
{
      if (
preg_match('#.php$#i'$filebase)) {
            include_once(
H.'sys/fnc/'.$filebase);
      }
}

// запись о посещении
mysql_query("INSERT INTO `visit_today` (`ip` , `ua`, `time`) VALUES ('$iplong', '".@my_esc($_SERVER['HTTP_USER_AGENT'])."', '$time')");
Онлайн: 0
Реклама