Mass update

This commit is contained in:
2022-12-30 21:03:37 +02:00
parent 7a5dfd22a7
commit e9ec7eb2f2
172 changed files with 14838 additions and 35914 deletions
@@ -0,0 +1,101 @@
<?php
use Core\Config;
use Core\Db;
require_once dirname(__DIR__) . DIRECTORY_SEPARATOR . 'autoload.php';
/**
* Îáíîâëåíèå äàííûõ î êóðñàõ âàëþò èç Öåíòðîáàíêà ÐÔ.
* Ðàç â äåíü â ÷àñ íî÷è.
*/
// Îáíóëåíèå(?!) ïåðåäà÷ ðàç â ñóòêè
Db::sql('update stats set transfers = 100 where transfers < 200');
function getCurs()
{
// ñîçäàåì îáúåêò äëÿ ðàáîòû ñ XML
$xml = new DOMDocument();
// ññûëêà íà ñàéò áàíêà
$url = 'https://www.cbr.ru/scripts/XML_daily.asp?date_req=' . date('d.m.Y');
// ïîëó÷àåì xml ñ êóðñàìè âñåõ âàëþò
if (!$xml->load($url)) {
// åñëè íå ïîëó÷èëè xml âîçâðàùàåì false
return false;
}
// ìàññèâ äëÿ õðàíåíèÿ êóðñîâ âàëþò
$result = [];
// ðàçáèðàåì xml
$root = $xml->documentElement;
// áåðåì âñå òåãè 'Valute' è èõ ñîäåðæèìîå
$items = $root->getElementsByTagName('Valute');
// ïåðåáåðåì òåãè 'Valute' ïî îäíîìó
foreach ($items as $item) {
// ïîëó÷àåì êîä âàëþòû
$code = $item->getElementsByTagName('CharCode')->item(0)->nodeValue;
// ïîëó÷àåì çíà÷åíèå êóðñà âàëþòû, îòíîñèòåëüíî ðóáëÿ
$value = $item->getElementsByTagName('Value')->item(0)->nodeValue;
// íîìèíàë
$nominal = $item->getElementsByTagName('Nominal')->item(0)->nodeValue;
// çàïèñûâàåì â ìàññèâ, ïðåäâàðèòåëüíî çàìåíèâ çàïÿòóþ íà òî÷êó
$result[$code] = round(str_replace(',', '.', $value), 5) / $nominal;
}// âîçâðàùàåì çíà÷åíèå êóðñà, äëÿ çàïðîøåííîé âàëþòû
return $result;
}
$get = getCurs();
if (Config::get('curency_name') === 'RUB') {
$curency = Config::get('curency_value');
} else {
$curency = round($get[Config::get('curency_name')] * Config::get('curency_value'), 4);
}
if ($get['USD'] > 0) {
$price = [
'AUD',
'AZN',
'AMD',
'BYR',
'BGN',
'BRL',
'HUF',
'KRW',
'DKK',
'USD',
'EUR',
'INR',
'KZT',
'CAD',
'KGS',
'CNY',
'LVL',
'LTL',
'MDL',
'RON',
'TMT',
'NOK',
'PLN',
'XDR',
'SGD',
'TJS',
'TRY',
'UZS',
'UAH',
'GBP',
'CZK',
'SEK',
'CHF',
'ZAR',
'JPY',
];
$r = '';
foreach ($price as $value) {
if (!$get[$value]) {
continue;
}
$r .= ',`' . $value . '`="' . $get[$value] . '"';
}
Db::sql('insert into bank_table set time = unix_timestamp(), cur = ?, data = ?', [$curency, date('d.m.Y') . $r]);
}
+19
View File
@@ -0,0 +1,19 @@
<?php
use Core\Db;
require_once dirname(__DIR__) . DIRECTORY_SEPARATOR . 'autoload.php';
/**
* ×èñòêà è ñáðîñ ñ÷åò÷èêîâ ïðè îòñóòñòâèè áîåâ ÷òîá íå ëàìàëñÿ ëîã.
* Çàïóñê êàæäûå òðè ÷àñà â Õ ÷àñîâ 20 ìèíóò?
*/
Db::sql('delete from battle_end where time < unix_timestamp() - 24 * 60 * 60');
Db::sql('delete from battle_last where time < unix_timestamp() - 24 * 60 * 60');
Db::sql('delete from battle_out where time < unix_timestamp() - 24 * 60 * 60');
Db::sql('delete from battle_stat where time < unix_timestamp() - 24 * 60 * 60');
Db::sql('delete from battle_logs where time < unix_timestamp() - 24 * 60 * 60');
Db::sql('delete from battle_logs_save where time < unix_timestamp() - 24 * 60 * 60');
Db::sql('delete from battle_users where time_enter between 1 and unix_timestamp() - 24 * 60 * 60');
Db::sql('delete from battle where time_over between 1 and unix_timestamp() - 24 * 60 * 60');
+101
View File
@@ -0,0 +1,101 @@
<?php
use Core\Db;
require_once dirname(__DIR__) . DIRECTORY_SEPARATOR . 'autoload.php';
/* CRON Çàâåðøåíèå ïîåäèíêà è óäàëåíèå èç çàÿâîê */
# Çàïóñê ðàç â ìèíóòó.
function getIds($query): string
{
return implode(',', Db::getColumn($query));
}
# HOUR = 1800
Db::sql(
'update users
left join battle on users.battle = battle.id
left join battle_logs on battle_logs.id = battle.id
set
users.battle = 0,
battle.team_win = 0,
battle.time_over = unix_timestamp()
where
battle.team_win = -1 and
battle.time_start < unix_timestamp() - 1800 * 2 and
battle_logs.time < unix_timestamp() - 1800 *2'
);
$bid = Db::getColumn('select id from battle where time_start < unix_timestamp() - 180 and team_win = -1 and typeBattle = 9');
foreach ($bid as $item) {
$count = Db::getValue('select count(*) from users where battle = ?', [$item]);
if ($count < 8) {
$timeout = 60;
} elseif ($count < 12) {
$timeout = 120;
} else {
$timeout = 180;
}
Db::sql('update battle set timeout = ? where id = ?', [$timeout, $item]);
}
unset($bid);
Db::sql('delete from battle_cache where time < unix_timestamp() - 3600');
//$bid = getIds('select id from battle where type = 33 and (time_over < unix_timestamp() - 120 or time_over > unix_timestamp() - 360)');
////äè÷ü, íåâûïîëíèìîå óñëîâèå: `time_over` < "'.(time()-120).'" AND `time_over` > "'.(time() - 360).'" AND `time_over` != 0
//// óòî÷íèòü ðåàëèçàöèþ
//âûòàñêèâàåì ïåðñîâ èç ïðèç õàîòà åñëè çàñòðßëè (1-5 ìèíóò îêîí÷àíèå)
//$sp = mysql_fetch_array(mysql_query('SELECT * FROM `battle` WHERE `type` = 33 AND `time_over` < "'.(time()-120).'" AND `time_over` > "'.(time() - 360).'" AND `time_over` != 0 ORDER BY `battle`.`time_over` DESC LIMIT 1'));
//if (isset($sp['id']))
// {
// mysql_query('UPDATE `battle` SET `time_over` = `time_over` - 300 WHERE `id` = "'.$sp['id'].'" LIMIT 1');
// $sps = mysql_query('SELECT * FROM `users` WHERE `mail` LIKE "haot@new-combats.com" AND `battle` = 0');
// while( $pl = mysql_fetch_array($sps))
// {
// if (isset($pl['id']))
// {
// mysql_query('UPDATE `users` SET `inUser` = "0" WHERE `inUser` = "'.$pl['id'].'" LIMIT 1');
// mysql_query('DELETE FROM `users` WHERE `id` = "'.$pl['id'].'" LIMIT 1');
// mysql_query('DELETE FROM `stats` WHERE `id` = "'.$pl['id'].'" LIMIT 1');
// mysql_query('DELETE FROM `items_users` WHERE `uid` = "'.$pl['id'].'" LIMIT 100');
// mysql_query('DELETE FROM `eff_users` WHERE `uid` = "'.$pl['id'].'" LIMIT 100');
// }
// }
// }
//‚ûòàñêèâàåì ïåðñîâ åñëè çàñòðßëè â áîßõ
//todo, âñ¸, íè÷åãî íå ñîîáðàæàþ. äîäåëàòü çàïðîñ, ÷òîáû îí ó÷èòûâàë: || !isset($test['id']
//'update users
// left join stats on users.id = stats.id
// left join battle on users.id = battle.id
//set
// users.battle = 0,
// stats.battle_yron = 0
//where
// users.battle > 0 and
// battle.time_over between 1 and unix_timestamp() - 600';
$sps = mysql_query('SELECT * FROM `users` WHERE `battle` > 0');
while( $pl = mysql_fetch_array($sps))
{
if (isset($pl['id']))
{
$test = mysql_fetch_array(mysql_query('SELECT * FROM `battle` WHERE `id` = "'.$pl['battle'].'" LIMIT 1'));
if (($test['time_over'] < (time()-600) && $test['time_over'] !=0) || !isset($test['id']))
{
mysql_query('UPDATE `users` SET `battle`= 0 WHERE `id` = "'.$pl['id'].'" LIMIT 1');
mysql_query('UPDATE `stats` SET `battle_yron` = 0 WHERE `id` = "'.$pl['id'].'" LIMIT 1');
}
}
}
//÷èñòèì ïàìßòü
unset($sp,$sps,$pl,$test);
+16
View File
@@ -0,0 +1,16 @@
<?php
use Insallah\Tournaments\Tournament;
require_once dirname(__DIR__) . DIRECTORY_SEPARATOR . 'autoload.php';
/**
* Проверяем и стартуем турниры (старые), групповые и хаотические поединки.
* Дописал сюда и новые турниры тоже.
*
* Запускается каждые 10 милисекунд!!!
* 5 раз в секунду с таймером в 10 милисекунд.
*/
(new FightRequest())->testCronZv();
Tournament::startAllBattles();
+49
View File
@@ -0,0 +1,49 @@
<?php
use Core\Db;
require_once dirname(__DIR__) . DIRECTORY_SEPARATOR . 'autoload.php';
/**
* Çàïóñê ïðèçîâîãî õàîòà.
* Çàïóñê êàæäûé ÷àñ â Õ ÷àñîâ 10 ìèíóò ñ 8 óòðà äî 2 íî÷è.
* Î_Î
*/
//Ïîäàåì òóðíèð (õàîò) äëÿ 8-11 óðîâíåé
Db::sql(
'insert into zayvki (
comment,
arand,
noatack,
city,
creator,
type,
time_start,
timeout,
min_lvl_1,
min_lvl_2,
max_lvl_1,
max_lvl_2,
noinc,
razdel,
time,
fastfight,
priz,
maxplayers,
tm1max,
tm2max
)
values (?,1,1,\'capitalcity\',0,33,300,180,8,8,12,12,1,5,unix_timestamp(),1,1,40,0,0)',
[
"<i style='color: green;'>Àâòîçàÿâêà! <b>Òåñò ïðîøó íå çàõîäèòü</b></i>", 'capitalcity',
]
);
Db::sql(
'insert into chat (`text`,`type`,`new`,`time`) values (?,6,1,unix_timestamp())',
[
"<span style='color: red'>Âíèìàíèå!!!</span> <span style='color:#cb0000'><b>Ãåðîè÷åñêîå Ñðàæåíèå</b> íà÷àëîñü.</span>",
]
);
+109
View File
@@ -0,0 +1,109 @@
<?php
/**
* Âûçîâ áîòîâ â èãðîâûå êîìíàòû.
*
* Çàïóñê ðàç â ìèíóòó.
*/
use Core\Db;
require_once dirname(__DIR__) . DIRECTORY_SEPARATOR . 'autoload.php';
function makeLogin(int $id, string $login, int $level): string
{
return <<<HTML
<strong>$login</strong>&nbsp;[$level]&nbsp;
<a target='_blank' href='inf.php?$id'>
<img src=https://img.new-combats.com/i/inf_capitalcity.gif alt='inf'>
</a>
HTML;
}
function testMonster(array $mon): bool // ×ÒÎ ÒÛ ÁËßÒÜ ÒÀÊÎÅ? ×ÒÎ ÒÛ ÏÐÎÂÅÐßÅØÜ? ÊÀÊ ÒÛ ÐÀÁÎÒÀÅØÜ?
{
return
(
$mon['back_day'] === -1 ||
(
$mon['back_day'] === 7 ||
$mon['back_day'] === idate('w')
) &&
$mon['back_day'] === 7
) &&
(
$mon['back_dd'] === -1 ||
$mon['back_dd'] === idate('j')
) &&
(
$mon['back_mm'] === -1 ||
$mon['back_mm'] === idate('n')
) &&
(
$mon['back_hh'] === -1 ||
$mon['back_hh'] === idate('H') &&
(
$mon['back_min'] === -1 ||
$mon['back_min'] >= idate('i')
)
);
}
$rows = Db::getRows('select * from users left join stats on users.id = stats.id where no_ip = \'trupojor\' limit 100');
foreach ($rows as $row) {
$act = 0;
if ($row['online'] < time() - 60) {
$row['online'] = time();
Db::sql('update users set online = ? where id = ?', [$row['online'], $row['id']]);
}
$mon = Db::getRow('select * from aaa_monsters where uid = ?', [$row['id']]);
if ($row['res_x'] < time()) {
if (isset($mon['id'])) { //åñëè áîò â ñïåöèàëüíîì ñïèñêå
// åñëè áîò ñïðÿòàí â äîìèêå (303) - âûïóñêàåì è ëå÷èì åãî
if (testMonster($mon) && $row['room'] == 303) {
Db::sql('update users set room = ? where id = ?', [$mon['start_room'], $row['id']]);
Db::sql('update stats set hpNow = hpAll, mpNow = mpAll where id = ?', [$row['id']]);
if ($mon['start_text']) {
$str = '<span style="color: red">Âíèìàíèå!</span> ';
$str .= str_replace('{b}', makeLogin($row['id'], $row['login'], $row['level']), $mon['start_text']);
Db::sql(
'insert into chat (text, city, type, new, time) values (?,?,6,1,unix_timestamp())',
[$str, $row['city']]
);
}
$act = 1;
}
} else {
//+1hour
Db::sql('update stats set res_x = unix_timestamp() + 3600 where id = ?', [$row['id']]);
}
}
if (
$act == 0 &&
$row['room'] != 303 &&
$row['battle'] == 0 &&
isset($mon['id']) &&
testMonster($mon)
) {
// åñëè áîò íå â äîìèêå, îòïðàëÿåì â äîìèê (303).
Db::sql('update users set room = 303 where id = ?', [$row['id']]);
if ($mon['back_text']) {
$str = '<span style="color: red">Âíèìàíèå!</span> ';
$str .= str_replace('{b}', makeLogin($row['id'], $row['login'], $row['level']), $mon['back_text']);
Db::sql(
'insert into chat (text, city, type, new, time)
values
(?,?,6,1,unix_timestamp()),
(?,?,1,1,unix_timestamp())',
[$str, $row['city'], $str, $row['city']]
);
}
$act = 2;
}
sleep(1);
}
+60
View File
@@ -0,0 +1,60 @@
<?php
use Core\Db;
require_once dirname(__DIR__) . DIRECTORY_SEPARATOR . 'autoload.php';
# Êàêèå-òî îïåðàöèè íàä áîòàìè.
## Ýòîò ôàéë óïðàâëÿåò âñåé ëîãèêîé âñåõ áîòîâ âåçäå.
## BotLogic::start - î÷åíü òÿæåëûé íà çàïðîñû êëàññ.
# ðàç â ìèíóòó
# Ðàíüøå â êðîíå áûë äîïîëíèòåëüíûé òàéìåð íà îáíîâëåíèå êàæäûå 4 ñåêóíäû.
# Åñëè áîòàì áóäåò ìàëî ìèíóòû, èãðàòüñÿ òàéìåðîì.
$uids = implode(
',',
Db::getColumn('select id from users where no_ip = ? or pass = ?', ['trupojor', 'saintlucia'])
);
Db::sql("update stats left join users on stats.id = users.id set exp = 400000 where exp > 400000 and level = 8 and stats.id in ($uids)");
Db::sql("update stats left join users on stats.id = users.id set exp = 3500000 where exp > 3500000 and level = 9 and stats.id in ($uids)");
Db::sql("update stats left join users on stats.id = users.id set exp = 48000000 where exp > 48000000 and level = 10 and stats.id in ($uids)");
Db::sql("update stats left join users on stats.id = users.id set exp = 148000000 where exp > 148000000 and level = 11 and stats.id in ($uids)");
Db::sql("update stats left join users on stats.id = users.id set exp = 400000000 where exp > 400000000 and level = 12 and stats.id in ($uids)");
Db::sql("update users set online = unix_timestamp() where timereg != 0 and id in ($uids)");
Db::sql("update users set timereg = unix_timestamp() where timereg = 0 and id in ($uids)");
Db::sql("update stats set bot = 2 where bot = 0 and id in ($uids)");
Db::sql("update stats set nextAct = unix_timestamp() where id in ($uids)");
# ×ÒÎ ÒÛ ÒÀÊÎÅ ÁËßÒÜ?!
$btltest = [];
$data = Db::getRows('select zv, stats.id, battle from users left join stats on users.id = stats.id where no_ip = ? or pass = ? order by nextAct', ['trupojor', 'saintlucia']);
foreach ($data as $row) {
if ($row['zv']) {
$zv = Db::getValue('select razdel from zayvki where id = ? and btl_id = 0 and razdel != 5', [$row['zv']]);
if ($zv) {
Db::sql('update stats set zv = 0 where id = ?', [$row['id']]);
$row['zv'] = 0;
}
}
if ($row['battle']=== -1) {
Db::sql('update users left join stats on users.id = stats.id set battle = 0, ipreg = 0, zv = 0 where users.id = ?', [$row['id']]);
$row['battle'] = 0;
}
if (in_array(idate('i'), [5, 6, 15, 16, 25, 26, 35, 36, 45]) && $row['zv'] === 0) {
Db::sql('update users set ipreg = 0 where id = ?', [$row['id']]);
}
if ($row['zv'] === 0 && ($row['battle'] === 0 || empty($btltest[$row['battle']]) || $btltest[$row['battle']] < 1)) {
$btltest[$row['battle']]++;
Db::sql('update users set online = unix_timestamp(), afk = ? where id = ?', ['', $row['id']]);
BotLogic::start($row['id']);
} else {
Db::sql('update users set online = unix_timestamp() where id = ?', [$row['id']]);
}
}
+18
View File
@@ -0,0 +1,18 @@
* * * * * /usr/local/bin/php -f /home/newcom1/public_html/cron_tower.php;
0 0 * * * /usr/local/bin/php -f /home/newcom1/public_html/cron/clear.php;
* * * * * /usr/local/bin/php -f /home/newcom1/public_html/cron_dungeon_goBots.php
0 1 * * * /usr/local/bin/php /home/newcom1/public_html/_incl_data/crons/bank_updateExchangeRares.php
20 */3 * * * /usr/local/bin/php /home/newcom1/public_html/_incl_data/crons/battle_clear.php
* * * * * /usr/local/bin/php /home/newcom1/public_html/_incl_data/crons/battle_finish.php
* * * * * /usr/local/bin/php /home/newcom1/public_html/_incl_data/crons/battle_start.php
10 1,2,8-23 * * * /usr/local/bin/php /home/newcom1/public_html/_incl_data/crons/battle_startPrizhaot.php
* * * * * /usr/local/bin/php /home/newcom1/public_html/_incl_data/crons/bot_calls.php
* * * * * /usr/local/bin/php /home/newcom1/public_html/_incl_data/crons/bot_core.php
0 12 * * 1 /usr/local/bin/php /home/newcom1/public_html/_incl_data/crons/cshop_returnToOwner.php
0 */6 * * * /usr/local/bin/php /home/newcom1/public_html/_incl_data/crons/cshop_sellToShop.php
0 */1 * * * /usr/local/bin/php /home/newcom1/public_html/_incl_data/crons/dungeon_clear.php
0 3 */1 * * /usr/local/bin/php /home/newcom1/public_html/_incl_data/crons/game_clear.php
0 */1 * * * /usr/local/bin/php /home/newcom1/public_html/_incl_data/crons/quests.php
0 0 * * * /usr/local/bin/php /home/newcom1/public_html/_incl_data/crons/rating_clans.php
0 0 * * * /usr/local/bin/php /home/newcom1/public_html/_incl_data/crons/rating_pers.php
*/15 * * * * /usr/local/bin/php /home/newcom1/public_html/_incl_data/crons/rupor.php
+98
View File
@@ -0,0 +1,98 @@
<?php
use Core\Db;
require_once dirname(__DIR__) . DIRECTORY_SEPARATOR . 'autoload.php';
/** Îïòèìèçèðîâàíî. Íî êàê-òî õåðîâàòî. Íàäî îòêàçàòüñÿ îò âûçîâà $u. È çàïðîñû êàêèå-òî âðàçíîáîé, íàäî ðàçáèðàòüñÿ.
* CRON Êîìèññèîííîãî ìàãàçèíà
* Åñëè ïðåäìåò âèñèò óæå 2 è áîëåå íåäåëü, ïðîäàâàòü ïðåäìåò çà 50% îò åãî ñòîèìîñòè ñ ó÷åòîì èçíîñà.
* Äåíüãè îòñûëàþòñÿ íà ïî÷òó.
* @author Insallah
* @todo ïðîâåðèòü íà êîíôëèêòû ñ cshop_sellToShop.
*/
# Êàæäûé ïîíåäåëüíèê â 12 äíÿ.
const RETURN_GROUP = '"<span style="color: #C65F00;">Shop.capitalcity</span>": Âîçâðàò èç êîìèññèîííîãî ìàãàçèíà ïðåäìåò: [id="%s"/ Íàçâàíèå : "%s"/ Öåíà : "%s"/ Ãðóïïèðîâêà : "$s"].';
const RETURN_ONE = '"<span style="color: #C65F00;">Shop.capitalcity</span>": Âîçâðàò èç êîìèññèîííîãî ìàãàçèíà ïðåäìåò: [id="%s"/ Íàçâàíèå : "%s"/ Öåíà : "%s"].';
const SHOP_TYPE = 'Shop.comission';
$u = User::start();
$q = 'select
items_main.id,
uid,
inGroup,
item_id,
price1,
name
from
items_users
left join items_main on items_main.id = item_id
where inShop = 30 and `delete` = 0';
foreach (Db::getRows($q) as $row) {
if ($row['inGroup']) {
$col = $u->itemsX($row['id']);
if ($col > 1) {
$stmt = Db::prepare('
update items_users set inShop = 0, 1price = ?
where
item_id = ? and
inShop = 30 and
uid = ? and
inGroup = ?
limit ' . $col);
if ($stmt->execute([$row['price1'], $row['item_id'], $row['uid'], $row['inGroup']])) {
$ld = $u->addDelo(
1,
$row['uid'],
sprintf(RETURN_GROUP, $row['item_id'], $row['name'], $row['price1'], $row['inGroup'] . '+1'),
time(),
$u->info['city'],
SHOP_TYPE,
0,
0
);
}
} else {
$stmt = Db::prepare('
update items_users set inShop = 0, 1price = ?
where
uid = ? and
id = ? and
inOdet = 0 and
`delete` = 0 and
inShop = 30
');
if ($stmt->execute([$row['price1'], $row['uid'], $row['id']])) {
$ld = $u->addDelo(
1,
$row['uid'],
sprintf(RETURN_ONE, $row['item_id'], $row['name'], $row['price1']),
time(),
$u->info['city'],
SHOP_TYPE,
0,
0
);
}
}
} else {
$stmt = Db::prepare('update items_users set inShop = 0, 1price = ? where id = ? and inShop = 30');
if ($stmt->execute([$row['price1'], $row['id']])) {
$ld = $u->addDelo(
1,
$row['uid'],
sprintf(RETURN_ONE, $row['item_id'], $row['name'], $row['price1']),
time(),
$u->info['city'],
SHOP_TYPE,
0,
0
);
}
}
}
+59
View File
@@ -0,0 +1,59 @@
<?php
use Core\Db;
require_once dirname(__DIR__) . DIRECTORY_SEPARATOR . 'autoload.php';
/**
* CRON Êîìèññèîííîãî ìàãàçèíà
* Åñëè ïðåäìåò âèñèò óæå 2 è áîëåå íåäåëü, ïðîäàâàòü ïðåäìåò çà 50% îò åãî ñòîèìîñòè ñ ó÷åòîì èçíîñà.
* Äåíüãè îòñûëàþòñÿ íà ïî÷òó.
*
* Ïðèìåðíî âîò òàê äîëæåí âûãëÿäåòü íîðìàëüíûé êðîí. Ìåíüøå ëåâûõ çàâèñèìîñòåé, íåò ïîäòÿãèâàíèþ ïîëîâèíû äâèæêà.
* Âñ¸ åù¸ íå èäåàëüíî, íî óæå íåïëîõî.
*
* Çàïóñê ðàç â ìèíóòó.
*
* @author Ivor Barhansky <me@lopar.space>
* @todo ïðîâåðèòü íà êîíôëèêòû ñ cshop_returnToOwner.
* @todo Âåðíóòü çàïðîñû âçàä è âûâåñòè èõ èç öèêëîâ. "íîðìàëüíûé êðîí", ¸ïò, ïîä êàêèìè âåùåñòâàìè ÿ ýòî äåëàë?
*/
const TIME_LAST = 86400; // 1 day
const AUC = '<span style="color: #009966;">Ôèëèàë Àóêöèîíà</span>';
const AUC_WIN = 'Âû âûèãðàëè òîðãè. Ïðåäìåò "%s" çà <b>%s êð.</b> áûë äîáàâëåí ê âàì â èíâåíòàðü.';
const AUC_SELL = 'Ïðåäìåò "%s" áûë ïðîäàí íà òîðãàõ, <b>%s</b> êð. çà òîâàð îòïðàâëåíû âàì ïî ïî÷òå.';
const AUC_SELL_LOG = 'Ôèëèàë Àóêöèîíà: Ïðåäìåò "%s" áûë ïðîäàí çà <b>%s êð</b>.';
const AUC_NOT_SELL = 'Ïðåäìåò "%s" íå áûë ïðîäàí, îí âîçâðàùåí âàì â èíâåíòàðü.';
$query = [ //all queries
'insert into chat (new, login, `to`, text, time, type) values (1, ?, ?, ?, unix_timestamp(), 6)',
'select * from items_auc where time_end = 0 and time < unix_timestamp() - ? order by user_buy',
'select login from users where id = ?',
'select count(*) from users where id = ?',
'update items_users set uid = ?, lastUPD = unix_timestamp() where (id = ? or inGroup = ?) and uid = 0',
'insert into items_users (`delete`, item_id, 1price, uid, lastUPD, `data`) values (0, 1220, ?, ?, unix_timestamp(), ?)',
'insert into post (uid, sender_id, time, money, text) values (?, 0, unix_timestamp(), ?, ?)',
'update items_auc set time_end = unix_timestamp() where id = ?',
];
$sp = Db::getRow($query[1], [TIME_LAST]);
foreach ($sp as $pl) {
if ($pl['x'] > 0) {
$pl['name'] .= ' (x' . $pl['x'] . ')';
}
$userLogin = Db::getValue($query[2], [$pl['uid']]);
if ($pl['user_buy'] && Db::getValue($query[3], [$pl['user_buy']])) {
Db::sql($query[4], [$pl['user_buy'], $pl['item_id'], $pl['item_id']]);
Db::sql($query[0], [AUC, $pl['user_buy'], sprintf(AUC_WIN, $pl['name'], $pl['price'])]);
if ($userLogin) {
Db::sql($query[0], [AUC, $userLogin, sprintf(AUC_SELL, $pl['name'], $pl['price'])]);
Db::sql($query[5], [$pl['price'], '-51' . $pl['uid'], '']);
Db::sql($query[6], [$pl['uid'], $pl['price'], sprintf(AUC_SELL_LOG, $pl['name'], $pl['price'])]);
}
} elseif ($userLogin) {
Db::sql($query[4], [$pl['uid'], $pl['item_id'], $pl['item_id']]);
Db::sql($query[0], [AUC, $userLogin, sprintf(AUC_NOT_SELL, $pl['name'])]);
}
Db::sql($query[7], [$pl['id']]);
}
+80
View File
@@ -0,0 +1,80 @@
<?php
use Core\Db;
require_once dirname(__DIR__) . DIRECTORY_SEPARATOR . 'autoload.php';
/**
* Ñêðèïò îòâå÷àåò çà ÷èñòêó ïåùåð êîòîðûå íå èñïîëüçóþòñÿ èãðîêîì â òå÷åíèè 3 ÷àñîâ
* ïðè ó÷åòå ÷òî ïåùåðå áîëüøå 5 ÷àñîâ îò âðåìåíè ñîçäàíèÿ.
*
* Çàïóñê ðàç â ìèíóòó.
* (3 ÷àñà îôôëàéíà íà 5 ÷àñîâ ñóùåñòâîâàíèÿ, çà÷åì òóò ïîìèíóòêà?)
*/
# Âûáèðàåì ïåùåðó (ÈÄ, ÃÎÐÎÄ), ãäå:
# Èãðîê â ïåùåðå
# Èãðîê îôôëàéí áîëåå 3õ ÷àñîâ
# Ïåùåðà çàïóùåíà áîëåå 3õ ÷àñîâ íàçàä
# Âðåìÿ ïåùåðû âûøëî (?!)
# ??? bsid
$dungeons = Db::getRows(
'
select
dungeon_now.city,
dungeon_now.id as did
from
dungeon_now
left join users on dungeon_now.id = users.id
left join stats on dungeon_now.id = stats.id
where
stats.dnow > 0 and
users.online < unix_timestamp() - 10800 and
dungeon_now.time_start < unix_timestamp() - 10800 and
dungeon_now.time_finish = 0 and
dungeon_now.bsid = 0
group by dungeon_now.id order by dungeon_now.id desc
'
);
foreach ($dungeons as $dungeon) {
if (!$dungeon['did'] || $dungeon['did'] === 15) {
continue;
}
# [1] Âûêèäûâàåì èãðîêîâ ñ ïîäçåìåëüÿ è ïåðåìåùàåì åãî â `382` ïîäâàëüíîå ïîìåùåíèå
$podvalRoom = 382;
if ($dungeon['city'] === 'capitalcity') {
$podvalRoom = 321;
} elseif ($dungeon['city'] === 'angelscity') {
$podvalRoom = 242;
}
Db::sql('update stats set dnow = 0 where id in (select id from stats where dnow = ? limit 10)', [$dungeon['did']]);
# Âûáðîñèëè èãðîêà ñ ïîäçåìåëüÿ è ïåðåìåñòèëè â ïîäâàëüíîå ïîìåùåíèå
Db::sql(
'update users set room = ? where id in (select id from stats where dnow = ? limit 10)',
[$podvalRoom, $dungeon['did']]
);
# Âûáðàñûâàåì ïåùåðíûå ïðåäìåòû ó èãðîêà
Db::sql(
'update items_users set `delete` = unix_timestamp() where dn_delete = 1 and uid in (select id from stats where dnow = ? limit 10)',
[$dungeon['did']]
);
# [2] Óäàëÿåì îáúåêòû.
Db::sql('delete from dungeon_obj where for_dn = 0 and dn = ?', [$dungeon['did']]);
# [3] Óäàëÿåì ìîíñòðîâ.
Db::sql('delete from dungeon_bots where for_dn = 0 and dn = ?', [$dungeon['did']]);
# [4] Óäàëÿåì ïðåäìåòû.
Db::sql('delete from dungeon_items where for_dn = 0 and dn = ?', [$dungeon['did']]);
# [5] Óäàëÿåì äåéñòâèÿ (actions)
Db::sql('delete from dungeon_actions where dn = ?', [$dungeon['did']]);
# [6] Çàêðûâàåì Ïîäçåìåëüå Dungeon_Now - time_finish = time();
Db::sql('update dungeon_now set time_finish = unix_timestamp() where id = ?', [$dungeon['did']]);
}
+78
View File
@@ -0,0 +1,78 @@
<?php
use Core\Db;
require_once dirname(__DIR__) . DIRECTORY_SEPARATOR . 'autoload.php';
/**
* CRON Очистки сервера от ненужной информации
* Каждый день в 3 часа 15 минут.
*/
# DAY: 86400
function getIds($query): string
{
return implode(',', Db::getColumn($query));
}
// Заявки в клан
Db::sql('update users set clan_zv = 0 where clan_zv > 0');
// Очистка чата, остается 30 минут.
Db::sql('delete from chat where time < unix_timestamp() - 1800');
Db::sql('delete from chat_system where time < unix_timestamp() - 1800');
// Очистка заявок в поединки
Db::sql('delete from zayvki where start > 0 or cancel > 0 or time < unix_timestamp() - 43200');
// Очистка заявок в пещеры
Db::sql('delete from dungeon_zv where `delete` > 0 or time < unix_timestamp() - 43200');
// Очистка походов
$uids = getIds('select id from dungeon_now where time_start < unix_timestamp() - 43200 or time_finish > 0');
Db::sql('delete from dungeon_actions where dn in (?)', [$uids]);
Db::sql('delete from dungeon_bots where dn in (?)', [$uids]);
Db::sql('delete from dungeon_items where dn in (?)', [$uids]);
Db::sql('delete from dungeon_obj where dn in (?)', [$uids]);
Db::sql('delete from dungeon_now where id in (?)', [$uids]);
unset($uids);
// Очистка банов (10 дней) и отсутствующих (30 дней) и "явных ботов"
$uids = getIds(
'select id from users where
banned between 1 and unix_timestamp() - 86400 * 10 or
level < 10 and admin = 0 and online between 1 and unix_timestamp() - 86400 * 30 or
ip = 0 and online = 0 and battle = 0
'
);
Db::sql('delete from items_users where uid in (?)', [$uids]);
Db::sql('delete from eff_users where uid in (?)', [$uids]);
Db::sql('delete from users where id in (?)', [$uids]);
Db::sql('delete from rep where id in (?)', [$uids]);
Db::sql('delete from stats where id in (?)', [$uids]);
Db::sql('delete from online where uid in (?)', [$uids]);
Db::sql('delete from actions where uid in (?)', [$uids]);
unset($uids);
// Прочее
$uids = getIds('select id from users');
Db::sql('delete from items_users where uid > 0 and uid not in (?)', [$uids]);
Db::sql('delete from eff_users where uid > 0 and uid not in (?)', [$uids]);
Db::sql('delete from users_achiv where id > 0 and id not in (?)', [$uids]);
Db::sql('delete from aaa_bonus where uid > 0 and uid not in (?)', [$uids]);
Db::sql('delete from users_delo where uid > 0 and uid not in (?) or time < unix_timestamp() - 86400 * 10', [$uids]);
Db::sql('delete from users_reting where uid > 0 and uid not in (?)', [$uids]);
Db::sql('delete from aaa_reting_list where uid > 0 and uid not in (?)', [$uids]);
Db::sql('delete from rep where id > 0 and id not in (?)', [$uids]);
Db::sql('delete from aaa_znahar where uid > 0 and uid not in (?)', [$uids]);
Db::sql('delete from user_operation where uid > 0 and uid not in (?)', [$uids]);
Db::sql(
'delete from actions where
uid > 0 and uid not in (?) or
vars = ? or
vals = ? or
vars != ? and time < unix_timestamp() - 86400 * 60',
[$uids, 'day_quest', 'loto', 'read']
);
unset($uids);
// Голосовые сообщения
Db::sql('delete from uploads where id > 0');
+80
View File
@@ -0,0 +1,80 @@
<?php
use Core\Db;
require_once dirname(__DIR__) . DIRECTORY_SEPARATOR . 'autoload.php';
/**
* Что-то для квестов.
* Вызов раз в час
*/
$data = Db::getRows('select id, battle, room from users where `real` = 1');
foreach ($data as $row) {
$bot_kill = [];
$delete = '';
$qp = Db::getColumn(
'select vars from actions where uid = ? and vars like ? and vals = ?',
[
$row['id'],
'%start_quest%',
'go',
]
);
foreach ($qp as $item) {
$qst_id = str_replace('start_quest', '', $item);
$qst = Db::getValue('select act_date from quests where id = ?', [$qst_id]);
if (!$qst) {
continue;
}
$act = explode(':|:', $qst);
foreach ($act as $item2) {
$act2 = explode(':=:', $item2);
$bots = explode(',', $act2[1]);
foreach ($bots as $item3) {
$bot = explode('=', $item3);
$bot_kill[$bot[0]] = true;
}
}
}
$wp = Db::getRows(
'select id, vars from actions where uid = ? and (vars like ? or vars like ? or vars like ?)',
[
$row['id'],
'win_bot_%',
'lose_bot_%',
'nich_bot_%',
]
);
foreach ($wp as $item) {
$wlb = str_replace(['win_bot_', 'lose_bot_', 'nich_bot_',], '', $item);
if ($bot_kill[$wlb]) {
continue;
}
$delete .= "or id = $item";
}
$delete = ltrim($delete, 'or ');
if (!empty($delete)) {
$query = 'delete from actions where ' . $delete;
Db::sql($query);
}
if ($row['battle'] !== 0) {
continue;
}
Db::sql(
'delete from actions where uid = ? and (vars like ? or vars like ? or vars like ? and room != ?)',
[
$row['id'],
'%use_priem_%',
'%animal_use%',
'%takeit_%',
$row['room'],
]
);
}
+126
View File
@@ -0,0 +1,126 @@
<?php
use Core\Db;
require_once dirname(__DIR__) . DIRECTORY_SEPARATOR . 'autoload.php';
/**
* Îáíîâèòü ðåéòèíã êëàíîâ.
* Ðàç â äåíü.
*/
$add_exp_list = [];
$all_exp_list = [];
$exp_list = [];
$win_list = [];
$lose_list = [];
$nich_list = [];
$xu_list = [];
$level_list = [];
$log_list = [];
$clans = Db::getRows(
'
select
clan.id as cid,
clan.level,
clan.name,
count(*) as ucount,
clan.exp,
stats.id as sid,
sum(users.win) as win,
sum(users.lose) as lose,
sum(users.nich) as nich,
aaa_clan_reting_list.global
from
clan
left join users on clan.id = users.clan
left join stats on users.id = stats.id
left join aaa_clan_reting_list on aaa_clan_reting_list.clan = clan.id
where clan.id not in (62, 93) and users.admin = 0 and users.`real` = 1
'
);
foreach ($clans as $clan) {
$add_exp = 0;
$add_exp_list[$clan['cid']] = 0;
$all_exp_list[$clan['cid']] = 0;
$log_list[$clan['cid']] = $clan['name'];
$level_list[$clan['cid']] = $clan['level'];
$xu_list[$clan['cid']] = $clan['ucount'];
$exp_list[$clan['cid']] = $clan['exp'];
$win_list[$clan['cid']] = $clan['win'];
$lose_list[$clan['cid']] = $clan['lose'];
$nich_list[$clan['cid']] = $clan['nich'];
$clanMemberStats = Db::getRows(
'select
stats.id,
repexp
from
stats
left join users on users.id = stats.id
where clan = ?',
[$clan['cid']]
);
foreach ($clanMemberStats as $stat) {
$add_exp += $stat['repexp'];
Db::sql('update stats set repexp = 0 where id = ?', [$stat['id']]);
}
$global_exp = idate('d') != 1 ? round($clan['global']) : 0;
if ($clan['ucount'] > 0) {
$add_exp_list[$clan['cid']] = $add_exp; //çàïèñûâàåì ñêîëüêî îïûòà ïîëó÷èë çà ñåãîäíÿ
$all_exp_list[$clan['cid']] = $global_exp + $add_exp; //çàïèñûâàåì ñêîëüêî îïûòà ïîëó÷èë âñåãî + ñåãîäíÿøíèé
}
}
arsort($all_exp_list);
$keys = array_keys($all_exp_list);
$i = 0;
foreach ($keys as $key) {
$i++;
if (!$key) {
continue;
}
Db::sql(
'insert into aaa_clan_reting_list (level, xu, win, lose, nich, exp_real, clan, pos, global, exp, date, time) values (?,?,?,?,?,?,?,?,?,?,?,unix_timestamp())',
[
$level_list[$key],
$xu_list[$key],
$win_list[$key],
$lose_list[$key],
$nich_list[$key],
$exp_list[$key],
$key,
$i,
$all_exp_list[$key],
$add_exp_list[$key],
date('dmY'),
]
);
}
$stmt = Db::prepare('update clan set money2 = money2 + ? where id = ?');
$stmt->execute([$xu_list[0] * 0.3, $keys[0]]);
$stmt->execute([$xu_list[1] * 0.2, $keys[1]]);
$stmt->execute([$xu_list[2] * 0.1, $keys[2]]);
Db::sql(
'insert into chat (text, city, type, new, time) values
(?,\'capitalcity\',6,1,unix_timestamp()),
(?,\'capitalcity\',6,1,unix_timestamp()),
(?,\'capitalcity\',6,1,unix_timestamp()),
(?,\'capitalcity\',6,1,unix_timestamp())',
[
'<span style="color: red; font-weight: bold;">Ðåéòèíã êëàíîâ ' . date('d-m-Y') . ' </span>',
'Êëàí ' . $log_list[0] . ' ïîëó÷àåò ' . $xu_list[0] * 0.3 . ' Åêð. â êàçíó êëàíà çà 1-å ìåñòî â ðåéòèíãå!',
'Êëàí ' . $log_list[1] . ' ïîëó÷àåò ' . $xu_list[1] * 0.2 . ' Åêð. â êàçíó êëàíà çà 2-å ìåñòî â ðåéòèíãå!',
'Êëàí ' . $log_list[2] . ' ïîëó÷àåò ' . $xu_list[2] * 0.1 . ' Åêð. â êàçíó êëàíà çà 3-å ìåñòî â ðåéòèíãå!',
]
);
Db::sql('update stats set repexp = 0 where repexp > 0');
+133
View File
@@ -0,0 +1,133 @@
<?php
use Core\Db;
require_once dirname(__DIR__) . DIRECTORY_SEPARATOR . 'autoload.php';
/**
* Îáíîâèòü ðåéòèíã èãðîêîâ.
* Ðàç â äåíü.
*/
//Ðåéòèíã ïî âêëàäàì
$ub = [];
$ui = [];
$payOperations = Db::getRows('select * from pay_operation where good > 0 order by id desc');
foreach ($payOperations as $operation) {
if (!isset($ub[$operation['uid']])) {
$ui[] = $operation['uid'];
}
$ub[$operation['uid']][date('d.m.Y', $operation['good'])] = $operation['ekr'];
}
// ×ÒÎ ÒÛ ÁËßÒÜ ÒÀÊÎÅ?!
foreach ($ui as $item) {
if (!$item) {
continue;
}
$k = 0;
$nj = 0;
for ($i = 0; $i <= 1000; $i++) {
$date = date('d.m.Y', time() - (86400 * $i));
if (isset($ub[$item][$date])) {
$k++;
$nj = 0;
} elseif ($i > 0 && $nj >= 6) {
$j = 1000;
} else {
$nj++;
}
}
Db::sql('replace into users_paybonus (id, level) values (?,?)', [$item, $k]);
}
$log_list = [];
$add_exp_list = [];
$all_exp_list = [];
$exp_list = [];
$win_list = [];
$global_exp = 0;
Db::sql('delete from aaa_reting_list where date = ?', [date('dmY')]);
$users = Db::getRows(
'
select
stats.id,
login,
users.win as uwin,
stats.exp as sexp,
repexp,
aaa_reting_list.exp as aexp,
global,
exp_real
from users
left join stats on stats.id = users.id
left join aaa_reting_list on users.id = uid
where `real` = 1 and admin = 0 and bot = 0
'
);
foreach ($users as $user) {
$exp_list[$user['id']] = $user['sexp'];
$win_list[$user['id']] = $user['uwin'];
$log_list[$user['id']] = $user['login'];
$add_exp = $user['sexp'];
if (idate('d') !== 1) { //çíà÷åíèå ðåéòèíãà îáíóëÿåòñÿ 1ãî ÷èñëà
$global_exp = round($user['global']);
}
$global_exp = $global_exp + round($user['repexp']);
$add_exp_list[$user['id']] = $add_exp; //çàïèñûâàåì ñêîëüêî îïûòà ïîëó÷èë çà ñåãîäíÿ
$all_exp_list[$user['id']] = $global_exp;// + $add_exp; //çàïèñûâàåì ñêîëüêî îïûòà ïîëó÷èë âñåãî + ñåãîäíÿøíèé
}
arsort($all_exp_list);
$keys = array_keys($all_exp_list);
$i = 0;
foreach ($keys as $key) {
if (!$key) {
continue;
}
$i++;
Db::sql(
'insert into aaa_reting_list (uid, pos, global, exp, exp_real, date, time, win) values (?,?,?,?,?,?,unix_timestamp(),?)',
[
$key,
$i,
$all_exp_list[$key],
$add_exp_list[$key],
$exp_list[$key],
date('dmY'),
$win_list[$key],
]
);
}
$stmt = Db::prepare('update users set money2 = money2 + ? where id = ?');
$stmt->execute([1, $keys[0]]);
$stmt->execute([0.75, $keys[1]]);
$stmt->execute([0.5, $keys[2]]);
$stmt->execute([0.25, $keys[3]]);
$stmt->execute([0.15, $keys[4]]);
Db::sql(
'insert into chat (text, city, type, new, time) values
(?,\'capitalcity\',6,1,unix_timestamp()),
(?,\'capitalcity\',6,1,unix_timestamp()),
(?,\'capitalcity\',6,1,unix_timestamp()),
(?,\'capitalcity\',6,1,unix_timestamp()),
(?,\'capitalcity\',6,1,unix_timestamp()),
(?,\'capitalcity\',6,1,unix_timestamp())',
[
'<span style="color: red; font-weight: bold;">Ðåéòèíã èãðîêîâ ' . date('d-m-Y') . ' </span>',
'Èãðîê ' . $log_list[0] . ' ïîëó÷àåò 1 Åêð. çà 1-å ìåñòî â ðåéòèíãå!',
'Èãðîê ' . $log_list[1] . ' ïîëó÷àåò 0.75 Åêð. çà 2-å ìåñòî â ðåéòèíãå!',
'Èãðîê ' . $log_list[2] . ' ïîëó÷àåò 0.5 Åêð. çà 3-å ìåñòî â ðåéòèíãå!',
'Èãðîê ' . $log_list[3] . ' ïîëó÷àåò 0.25 Åêð. çà 4-å ìåñòî â ðåéòèíãå!',
'Èãðîê ' . $log_list[4] . ' ïîëó÷àåò 0.15 Åêð. çà 5-å ìåñòî â ðåéòèíãå!',
]
);
+28
View File
@@ -0,0 +1,28 @@
<?php
use Core\Db;
require_once dirname(__DIR__) . DIRECTORY_SEPARATOR . 'autoload.php';
/**
* Кричалка в чат.
* Раз в 15 минут.
*/
$rupor = [
'Открыв новости, справа можно найти игровые статьи, которые помогут Вам разобраться в игре и сделать её в разы проще.',
'Раз в сутки, Вы можете покрутить бесплатную рулетку с крутыми призами на Центральной Площади, в здании Лото!',
'С каждого доната Вашего реферала, Вы, будете получать 10% от чистой суммы покупки еврокредитов.',
'Наша задача, предоставить игрокам комфорт в игре, а так же поднять онлайн свыше 100 человек.',
'Общие турниры могут быть запущены любым игроком! Не стесняйтесь, учавствуйте в турнирах!',
'По новому балансу: Критоуворот убивает - Танка, Топора и с 50% вероятностью Уворота/Крита/Мага ( в зависимости от распределенных статов )!',
'По новому балансу: Маг убивает - Уворота, Танка, Топора и с 50% вероятностью Критоуворота ( в зависимости от распределенных статов )!',
'В нашей игре только один игровой уровень, открытие следующего 9-го уровня возможно в случае, если среднесуточный онлайн будет на уровне 100 человек.',
];
shuffle($rupor);
Db::sql('insert into chat (new, text, time, type, da, color) values (1, ?, unix_timestamp(), 6, 1, ?)', [
'Администрация: ' . $rupor[0],
'#F00'
]);
+168
View File
@@ -0,0 +1,168 @@
<?php
# Êàæäóþ ïîëíî÷ü
const GAME = true;
include('/home/newcom1/public_html/_incl_data/class/__db_connect.php');
if( isset($_GET['actions']) ) {
//
$data = array();
//
$sp = mysql_query('SELECT * FROM `actions`');
while( $pl = mysql_fetch_array($sp) ) {
$pl['vars'] = str_replace(0,'%',$pl['vars']);
$pl['vars'] = str_replace(1,'%',$pl['vars']);
$pl['vars'] = str_replace(2,'%',$pl['vars']);
$pl['vars'] = str_replace(3,'%',$pl['vars']);
$pl['vars'] = str_replace(4,'%',$pl['vars']);
$pl['vars'] = str_replace(5,'%',$pl['vars']);
$pl['vars'] = str_replace(6,'%',$pl['vars']);
$pl['vars'] = str_replace(7,'%',$pl['vars']);
$pl['vars'] = str_replace(8,'%',$pl['vars']);
$pl['vars'] = str_replace(9,'%',$pl['vars']);
$data[$pl['vars']]++;
}
//
print_r($data);
//
die();
}
/*
CRON Î÷èñòêè ñåðâåðà îò íåíóæíîé èíôîðìàöèè
Äåéñòâèÿ:
1. Î÷èñòêà ÷àòà
2. Î÷èñòêà çàÿâîê â ïîåäèíêè
3. Î÷èñòêà çàÿâîê â ïåùåðû
4. Î÷èñòêà ïîõîäîâ
*/
// ÅÁÈÈÈÈÈÈÈ×ÅÑÊÀß ÑÈÈÈÈËÀ!!!!! (ñ) Èíñ.
// forign_keys! Íèêòî íå çíàåò ïðî foreign_keys!
function delete_user_all( $uid , $login ) {
mysql_query('DELETE FROM `aaa_birthday` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `aaa_bonus` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `aaa_dialog_vars` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `aaa_znahar` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `actions` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `add_smiles` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `an_data` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `a_com_act` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `a_noob` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `a_system` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `a_vaucher` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `a_vaucher_active` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `bandit` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `bank` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `bank_alh` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `battle_act` WHERE `uid1` = "'.$uid.'" OR `uid2` = "'.$uid.'"');
mysql_query('DELETE FROM `battle_actions` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `battle_cache` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `battle_last` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `battle_stat` WHERE `uid1` = "'.$uid.'" OR `uid2` = "'.$uid.'"');
mysql_query('DELETE FROM `battle_users` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `bid` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `bs_actions` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `bs_zv` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `building` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `buy_ekr` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `chat_ignore` WHERE `uid` = "'.$uid.'" OR `login` = "'.$login.'"');
mysql_query('DELETE FROM `complects_priem` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `dialog_act` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `dump` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `dungeon_actions` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `eff_users` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `ekr_sale` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `feerverks` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `fontan` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `fontan_hp` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `fontan_text` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `friends` WHERE `user` = "'.$uid.'"
OR `friend` = "'.$uid.'"
OR `enemy` = "'.$uid.'"
OR `notinlist` = "'.$uid.'"
OR `ignor` = "'.$uid.'"
OR `login_ignor` = "'.$login.'"
OR `user_ignor` = "'.$login.'"');
mysql_query('DELETE FROM `house` WHERE `owner` = "'.$uid.'"');
mysql_query('DELETE FROM `items_img` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `items_users` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `izlom_rating` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `laba_act` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `laba_itm` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `lastnames` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `logs_auth` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `loto_win` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `mults` WHERE `uid` = "'.$uid.'" OR `uid2` = "'.$uid.'"');
mysql_query('DELETE FROM `notepad` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `obraz` WHERE `uid` = "'.$uid.'" OR `login` = "'.$login.'"');
mysql_query('DELETE FROM `online` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `pirogi` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `post` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `reimage` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `rep` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `repass` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `ruletka_coin` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `save_com` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `stats` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `transfers` WHERE `uid1` = "'.$uid.'" OR `uid2` = "'.$uid.'"');
mysql_query('DELETE FROM `users` WHERE `id` = "'.$uid.'"');
mysql_query('DELETE FROM `stats` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `users_delo` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `users_animal` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `users_gifts` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `users_ico` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `users_reputation` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `users_turnirs` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `users_twink` WHERE `uid` = "'.$uid.'"');
mysql_query('DELETE FROM `zayavki` WHERE `creator` = "'.$uid.'"');
mysql_query('DELETE FROM `_clan` WHERE `uid` = "'.$uid.'"');
}
//1. Î÷èñòêà ÷àòà, îñòàåòñÿ ÷àò òîëüêî çà ïîñëåäíèå 3 äíÿ
mysql_query('DELETE FROM `chat` WHERE `time` < '.(time()-86400*3).'');
//2. Î÷èñòêà çàÿâîê â ïîåäèíêè
mysql_query('DELETE FROM `zayvki` WHERE `start` > 0 OR `cancel` > 0 OR `time` < "'.(time()-86400*1).'"');
//3. Î÷èñòêà çàÿâîê â ïåùåðû
mysql_query('DELETE FROM `dungeon_zv` WHERE `delete` > 0 OR `time` < "'.(time()-86400*1).'"');
//4. Î÷èñòêà ïîõîäîâ
$sp = mysql_query('SELECT * FROM `dungeon_now` WHERE `time_start` < "'.(time()-86400*1).'" OR `time_finish` > 0');
while( $pl = mysql_fetch_array($sp) ) {
mysql_query('DELETE FROM `dungeon_actions` WHERE `dn` = "'.$pl['id'].'"');
mysql_query('DELETE FROM `dungeon_bots` WHERE `dn` = "'.$pl['id'].'"');
mysql_query('DELETE FROM `dungeon_items` WHERE `dn` = "'.$pl['id'].'"');
mysql_query('DELETE FROM `dungeon_obj` WHERE `dn` = "'.$pl['id'].'"');
mysql_query('DELETE FROM `dungeon_now` WHERE `id` = "'.$pl['id'].'"');
}
//5. Î÷èñòêà ìîíñòðîâ
$i = 0;
$sp = mysql_query('SELECT * FROM `users` WHERE `real` = 0 ORDER BY `id` ASC LIMIT 100');
while( $pl = mysql_fetch_array($sp) ) {
$btl = mysql_fetch_array(mysql_query('SELECT * FROM `battle` WHERE `id` = "'.$pl['battle'].'" LIMIT 1'));
$clon = mysql_fetch_array(mysql_query('SELECT `id` FROM `users` WHERE `inUser` = "'.$pl['id'].'" LIMIT 1'));
if( (!isset($btl['id']) || $btl['team_win'] >= 0) && !isset($clon['id']) ) {
//Î÷èùàåì áîòà
delete_user_all( $pl['id'] , $pl['login'] );
$i++;
}
}
$x = mysql_fetch_array(mysql_query('SELECT COUNT(*) FROM `users` WHERE `real` = 0 LIMIT 1'));
$x = $x[0];
mysql_query('DELETE FROM `stats` WHERE `id` NOT IN (SELECT `id` FROM `users`);');
mysql_query('DELETE FROM `items_users` WHERE `delete` > `time_create` AND `delete` > 0');
//6. Î÷èñòêà ëè÷íîãî äåëà
mysql_query('DELETE FROM `users_delo` WHERE `time` < "'.(time()-86400*30).'" LIMIT 1000');
//7. ñáðîñ ñ÷åò÷èêà æåòîíîâ
mysql_query('UPDATE `users` SET `ang_g` = 0 WHERE `ang_g` > 0');
@@ -0,0 +1,494 @@
<?php
/**
* Ñêðèïò îòâå÷àåò çà ïåðåìåùåíèÿ áîòîâ ïî ïåùåðå è íàïåäåíèÿ, êîãäà èãðîê ðÿäîì.
*
* Çàïóñê ðàç â ìèíèòó
*/
require_once dirname(__DIR__) . DIRECTORY_SEPARATOR . 'autoload.php';
//todo: IN PROGRESS
# Ñîâåðøàåì äåéñòâèå -> Íàïàäåíèå íà èãðîêà.
function botAttack($bot, $user)
{
if ($user['userBattle'] > 0) {
$battleID = mysql_fetch_array(
mysql_query(
'SELECT `id` FROM `battle` WHERE `id` = "' . $user['userBattle'] . '" AND `team_win` = "-1" LIMIT 1'
)
);
}
if (!isset($battleID['id'])) { //Ñîçäàåì ïîåäèíîê
$btl_id = 0;
$expB = 0;
$btl = ['players' => '', 'timeout' => 180, 'type' => 0, 'invis' => 0, 'noinc' => 0, 'travmChance' => 0, 'typeBattle' => 0, 'addExp' => $expB, 'money' => 0];
$ins = mysql_query(
'INSERT INTO `battle`
(`dungeon`,`dn_id`,`x`,`y`,`city`,`time_start`,`players`,`timeout`,`type`,`invis`,`noinc`,`travmChance`,`typeBattle`,`addExp`,`money`)
VALUES (
"' . $bot['dn_id'] . '",
"' . $bot['this_dn'] . '",
"' . $bot['x'] . '",
"' . $bot['y'] . '",
"' . $bot['userCity'] . '",
"' . time() . '",
"' . $btl['players'] . '",
"' . $btl['timeout'] . '",
"' . $btl['type'] . '",
"' . $btl['invis'] . '",
"' . $btl['noinc'] . '",
"' . $btl['travmChance'] . '",
"' . $btl['typeBattle'] . '",
"' . $btl['addExp'] . '",
"' . $btl['money'] . '"
)'
);
$btl_id = mysql_insert_id();
if ($btl_id > 0) { //Äîáàâëÿåì áîòîâ
$j = 0;
$logins_bot = [];
mysql_query(
'UPDATE `dungeon_bots` SET `inBattle` = "' . $btl_id . '" WHERE `id2` = "' . $bot['id2'] . '" LIMIT 1'
);
$jui = 1;
while ($jui <= $bot['colvo']) {
$k = botAddBattle($bot, $logins_bot);
$logins_bot = $k['logins_bot'];
if ($k != false) {
$upd = mysql_query(
'UPDATE `users` SET `battle` = "' . $btl_id . '" WHERE `id` = "' . $k['id'] . '" LIMIT 1'
);
if ($upd) {
$upd = mysql_query('UPDATE `stats` SET `team` = "2" WHERE `id` = "' . $k['id'] . '" LIMIT 1');
if ($upd) {
$j++;
}
}
}
$jui++;
}
unset($logins_bot);
if ($j > 0) {
mysql_query(
'UPDATE `users` SET `battle` = "' . $btl_id . '" WHERE `id` = "' . $user['userId'] . '" LIMIT 1'
);
mysql_query('UPDATE `stats` SET `team` = "1" WHERE `id` = "' . $user['userId'] . '" LIMIT 1');
}
}
} else { # Âìåøèâàåìñÿ â ïîåäèíîê.
$j = 0;
$logins_bot = [];
$logins_bot_text = [];
$logins_bot_vars = ['time1=' . time() . ''];
$logins_bot_inBattle = mysql_query(
'SELECT SUBSTRING_INDEX(`login`, " (", 1) as login2, count(`login`) as count, `login` FROM `battle_users` WHERE `battle` = "' . $battleID['id'] . '" AND `team`=2 GROUP BY `login2`'
);
while ($row = mysql_fetch_array($logins_bot_inBattle)) {
$logins_bot[$row['login2']] = (int)$row['count'];
}
mysql_query(
'UPDATE `dungeon_bots` SET `inBattle` = "' . $battleID['id'] . '" WHERE `id2` = "' . $bot['id2'] . '" LIMIT 1'
);
$jui = 1;
while ($jui <= $bot['colvo']) {
$k = botAddBattle($bot, $logins_bot);
$logins_bot = $k['logins_bot'];
$logins_bot_text[] = ' <strong>' . $k['login'] . '</strong>';
if ($k != false) {
$upd = mysql_query(
'UPDATE `users` SET `battle` = "' . $battleID['id'] . '" WHERE `id` = "' . $k['id'] . '" LIMIT 1'
);
if ($upd) {
$upd = mysql_query('UPDATE `stats` SET `team` = "2" WHERE `id` = "' . $k['id'] . '" LIMIT 1');
if ($upd) {
$j++;
}
}
}
$jui++;
}
if ($j > 0) {
$logins_bot_text = '{tm1} Â ïîåäèíîê âìåøàëèñü: ' . implode(', ', $logins_bot_text) . '.';
$logins_bot_vars = implode('||', $logins_bot_vars);
$battle_log = mysql_fetch_array(
mysql_query(
'SELECT * FROM `battle_logs` WHERE `battle`=' . $battleID['id'] . ' ORDER BY `id_hod` DESC LIMIT 1'
)
);
if ($battle_log['id_hod'] > 0) {
mysql_query(
'INSERT INTO `battle_logs` (`time`,`battle`,`id_hod`,`text`,`vars`,`zona1`,`zonb1`,`zona2`,`zonb2`,`type`) VALUES ("' . time(
) . '","' . $battleID['id'] . '","' . ($battle_log['id_hod'] + 1) . '","' . $logins_bot_text . '","' . $logins_bot_vars . '","","","","",1)'
);
}
}
unset($logins_bot);
if ($j > 0) {
mysql_query(
'UPDATE `users` SET `battle` = "' . $battleID['id'] . '" WHERE `id` = "' . $user['id'] . '" LIMIT 1'
);
mysql_query('UPDATE `stats` SET `team` = "1" WHERE `id` = "' . $user['id'] . '" LIMIT 1');
}
unset($logins_bot_inBattle);
}
}
# Ñîâåðøàåì íàïàäåíèå -> Äîáàâëÿåì Áîòîâ â ïîåäèíîê
function botAddBattle($bot, $logins_bot)
{
$add_bot = mysql_fetch_array(
mysql_query(
'SELECT
`id`, `login`, `stats`, `obraz`, `level`, `sex`, `name`, `deviz`, `hobby`, `type`, `itemsUse`, `priemUse`, `align`, `clan`, `align_zvanie`, `bonus`, `clan_zvanie`, `time_reg`, `city_reg`, `upLevel`, `active`, `expB`, `p_items`, `agressor`, `priems`, `priems_z`, `award`
FROM `test_bot`
WHERE `id` = "' . $bot['id_bot'] . '"
LIMIT 1'
)
);
if (isset($add_bot['id'])) {
if (isset($logins_bot[$add_bot['login']])) {
$logins_bot[$add_bot['login']]++;
$add_bot['login'] = $add_bot['login'] . ' (' . $logins_bot[$add_bot['login']] . ')';
} else {
$logins_bot[$add_bot['login']] = 1;
}
$ret = true;
if ($add_bot['time_reg'] == 100) {
$add_bot['time_reg'] = time();
}
if ($add_bot['city_reg'] == '{thiscity}') {
$add_bot['city_reg'] = $bot['userCity'];
}
$ins1 = mysql_query(
'INSERT INTO `users` (
`align`,
`login`,
`level`,
`pass`,
`city`,
`cityreg`,
`name`,
`sex`,
`deviz`,
`hobby`,
`timereg`,
`obraz`,
`bot_id`
) VALUES (
"' . $add_bot['align'] . '",
"' . $add_bot['login'] . '",
"' . $add_bot['level'] . '",
"' . md5('bot_pass_' . $add_bot['login'] . '_') . '",
"' . $bot['userCity'] . '",
"' . $add_bot['city_reg'] . '",
"' . $add_bot['name'] . '",
"' . $add_bot['sex'] . '",
"' . $add_bot['deviz'] . '",
"' . $add_bot['hobby'] . '",
"' . $add_bot['time_reg'] . '",
"' . $add_bot['obraz'] . '",
"' . $bot['id_bot'] . '"
)'
);
# Åñëè áîò óñïåøíî ñîçäàí.
if ($ins1) {
$uid = mysql_insert_id();
$ins2 = mysql_query(
'INSERT INTO `stats` (`id`,`stats`,`hpNow`,`upLevel`,`bot`) VALUES ("' . $uid . '","' . $add_bot['stats'] . '","1000000","' . $add_bot['upLevel'] . '","1")'
);
if ($ins2) {
$add_bot['id'] = $uid;
$add_bot['logins_bot'] = $logins_bot;
$ret = $add_bot;
//Âûäàåì ïðåäìåòû
//$this->addItem($item_id,$uid);
$iu = explode(',', $add_bot['itemsUse']);
$i = 0;
$w3b = 0;
while ($i < count($iu)) {
if ($iu[$i] > 0) {
$idiu = botAddItem($iu[$i], $add_bot['id'], $bot['userCity']);
$islot = mysql_fetch_array(
mysql_query('SELECT `id`,`inslot` FROM `items_main` WHERE `id` = "' . $iu[$i] . '" LIMIT 1')
);
if (isset($islot['id'])) {
if ($islot['inslot'] == 3) {
if ($w3b == 1) {
$islot = 14;
} else {
$islot = 3;
$w3b = 1;
}
} else {
$islot = $islot['inslot'];
}
} else {
$islot = 2000;
}
if (isset($idiu, $islot)) {
mysql_query(
'UPDATE `items_users` SET `inOdet` = "' . $islot . '" WHERE `id` = "' . $idiu . '" LIMIT 1'
);
}
}
$i++;
}
} else {
$ret = false;
}
} else {
$ret = false;
}
return $ret;
}
}
#Âûäàåì ïðåäìåòû Áîòó.
function botAddItem($item_id, $bot_uid, $city)
{
$i = mysql_fetch_array(
mysql_query(
'SELECT `im`.`id`,`im`.`name`,`im`.`img`,`im`.`type`,`im`.`inslot`,`im`.`2h`,`im`.`2too`,`im`.`iznosMAXi`,`im`.`inRazdel`,`im`.`price1`,`im`.`price2`,`im`.`pricerep`,`im`.`magic_chance`,`im`.`info`,`im`.`massa`,`im`.`level`,`im`.`magic_inci`,`im`.`overTypei`,`im`.`group`,`im`.`group_max`,`im`.`geni`,`im`.`ts`,`im`.`srok`,`im`.`class`,`im`.`class_point`,`im`.`anti_class`,`im`.`anti_class_point`,`im`.`max_text`,`im`.`useInBattle`,`im`.`lbtl`,`im`.`lvl_itm`,`im`.`lvl_exp`,`im`.`lvl_aexp` FROM `items_main` AS `im` WHERE `im`.`id` = "' . mysql_real_escape_string(
$item_id
) . '" LIMIT 1'
)
);
if (isset($i['id'])) {
$d = mysql_fetch_array(
mysql_query(
'SELECT `id`,`items_id`,`data` FROM `items_main_data` WHERE `items_id` = "' . $i['id'] . '" LIMIT 1'
)
);
//íîâàÿ äàòà
$data = $d['data'];
$ins = mysql_query(
'
INSERT INTO `items_users` (
`overType`,`item_id`,`uid`,`data`,`iznosMAX`,`geniration`,`magic_inc`,`maidin`,`lastUPD`,`time_create`,`dn_delete`
) VALUES (
"' . $i['overTypei'] . '",
"' . $i['id'] . '",
"' . $bot_uid . '",
"' . $data . '",
"' . $i['iznosMAXi'] . '",
"' . $i['geni'] . '",
"' . $i['magic_inci'] . '",
"' . $city . '",
"' . time() . '",
"' . time() . '",
"' . $i['dn_delete'] . '"
)'
);
# Åñëè ïðåäìåò óñïåøíî äîáàâëåí â áàçó äàííûõ.
if ($ins) {
$rt = mysql_insert_id();
# îòêëþ÷åíà çàïèñü ïîëó÷åíèÿ ïðåäìåòà â Äåëî.
} else {
$rt = 0;
}
}
return $rt;
}
function moveBots($direction, $b)
{
$toGoX = 0;
$toGoY = 0;
if (isset($b['noBot']) && $b['noBot'] != '0000') {
if ($b['noBot'][0] != '0') {
$b['goTop'] = 0;
}
if ($b['noBot'][1] != '0') {
$b['goLeft'] = 0;
}
if ($b['noBot'][2] != '0') {
$b['goBottom'] = 0;
}
if ($b['noBot'][3] != '0') {
$b['goRight'] = 0;
}
}
$go = [
1 => ['d' => (int)$b['goTop'], 'go1' => (int)$b['goLeft'], 'go2' => (int)$b['goRight'], 'x' => (int)$b['x'], 'y' => (int)$b['y'], 's' => (int)$b['s']],
2 => ['d' => (int)$b['goLeft'], 'go1' => (int)$b['goBottom'], 'go2' => (int)$b['goTop'], 'x' => (int)$b['x'], 'y' => (int)$b['y'], 's' => (int)$b['s']],
3 => ['d' => (int)$b['goBottom'], 'go1' => (int)$b['goRight'], 'go2' => (int)$b['goLeft'], 'x' => (int)$b['x'], 'y' => (int)$b['y'], 's' => (int)$b['s']],
4 => ['d' => (int)$b['goRight'], 'go1' => (int)$b['goTop'], 'go2' => (int)$b['goBottom'], 'x' => (int)$b['x'], 'y' => (int)$b['y'], 's' => (int)$b['s']],
];
$dir = [
1 => ['moveForward' => ['x' => '0', 'y' => '1'], 'moveBack' => ['x' => '0', 'y' => '-1'], 'moveGo1' => ['x' => '-1', 'y' => '0'], 'moveGo2' => ['x' => '1', 'y' => '0']],
2 => ['moveForward' => ['x' => '-1', 'y' => '0'], 'moveBack' => ['x' => '1', 'y' => '0'], 'moveGo1' => ['x' => '0', 'y' => '-1'], 'moveGo2' => ['x' => '0', 'y' => '1']],
3 => ['moveForward' => ['x' => '0', 'y' => '-1'], 'moveBack' => ['x' => '0', 'y' => '1'], 'moveGo1' => ['x' => '1', 'y' => '0'], 'moveGo2' => ['x' => '-1', 'y' => '0']],
4 => ['moveForward' => ['x' => '1', 'y' => '0'], 'moveBack' => ['x' => '-1', 'y' => '0'], 'moveGo1' => ['x' => '0', 'y' => '1'], 'moveGo2' => ['x' => '0', 'y' => '-1']],
];
$go = $go[$direction];
$dir = $dir[$direction];
if ($go['d'] == 1) {
$toGoY = $dir['moveForward']['y'];
$toGoX = $dir['moveForward']['x'];
if (rand(1, 100) > 66) {
if ($go['go1'] == 1 && $go['go2'] == 0) {
$toGoY = $dir['moveGo1']['y'];
$toGoX = $dir['moveGo1']['x'];
} elseif ($go['go1'] == 0 && $go['go2'] == 1) {
$toGoY = $dir['moveGo2']['y'];
$toGoX = $dir['moveGo2']['x'];
} elseif ($go['go1'] == 1 && $go['go2'] == 1) {
$a = rand(1, 2);
$toGoY = $dir['moveGo' . $a]['y'];
$toGoX = $dir['moveGo' . $a]['x'];
}
} elseif (rand(1, 100) > 96) {
$toGoY = $dir['moveBack']['y'];
$toGoX = $dir['moveBack']['x'];
}
} elseif ($go['d'] == 0) {
if ($go['go1'] == 1 && $go['go2'] == 1) {
if (rand(0, 1) == 1) {
$toGoY = $dir['moveGo1']['y'];
$toGoX = $dir['moveGo1']['x'];
} else {
$toGoY = $dir['moveGo2']['y'];
$toGoX = $dir['moveGo2']['x'];
}
} elseif ($go['go1'] == 1 && $go['go2'] == 0) {
$toGoY = $dir['moveGo1']['y'];
$toGoX = $dir['moveGo1']['x'];
} elseif ($go['go1'] == 0 && $go['go2'] == 1) {
$toGoY = $dir['moveGo2']['y'];
$toGoX = $dir['moveGo2']['x'];
} elseif ($go['go1'] == 0 && $go['go2'] == 0) {
$toGoY = $dir['moveBack']['y'];
$toGoX = $dir['moveBack']['x'];
}
}
unset($dir, $go, $direction, $a);
return ['x' => (int)$toGoX, 'y' => (int)$toGoY];
}
# çàïóñê ñêðèïòà.
function start()
{
# Ñòðàíèöà ñîçäàíà 0.0000
$mtime = microtime();
$mtime = explode(" ", $mtime);
$tstart = $mtime[1] + $mtime[0];
# Âûáèðàåì âñåõ áîòîâ.
#  âûáîðêó âêëþ÷åíî: Ïîçèöèÿ áîòà, Íàïðàâëåíèå êóäà îí ìîæåò èäòè, Ñóùåñòâóåò ëè ðÿäîì Èãðîê, åãî êîîðäèíàòû è â ïîåäèíêå ëè îí.
$query = mysql_query(
"SELECT
`dn`.`id` as `this_dn`, `dn`.`id2` as `dn_id`, `db`.`id2`, `db`.`id_bot`, `tb`.`login` as login, `db`.`colvo`, `db`.`go_bot`, `db`.`x`, `db`.`y`, `db`.`s`, `db`.`atack`, `tb`.`agressor`,
`dm`.`go_1` as `goRight`, `dm`.`go_2` as `goLeft`, `dm`.`go_3` as `goTop`, `dm`.`go_4` as `goBottom`, `dm`.`no_bot` as `noBot`,
`user_info`.`id` as `userId`,
`user_info`.`login` as `userLogin`,
`user_stats`.`hpNow` as `userHP`,
`user_stats`.`x` as `userPosX`,
`user_stats`.`y` as `userPosY`,
`user_info`.`battle` as `userBattle`
FROM `dungeon_now` as `dn`
LEFT JOIN `dungeon_bots` as `db` ON `db`.`dn` = `dn`.`id`
LEFT JOIN `dungeon_map` as `dm` ON ( `dm`.`x` = `db`.`x` AND `dm`.`y` = `db`.`y` AND `dm`.`id_dng` = `dn`.`id2` )
LEFT JOIN `test_bot` AS `tb` ON `db`.`id_bot` = `tb`.`id`
LEFT JOIN `stats` AS `user_stats` ON ( ( `user_stats`.`x`+1 >= `db`.`x` AND `user_stats`.`x`-1 <= `db`.`x` ) AND ( `user_stats`.`y`+1 >= `db`.`y` AND `user_stats`.`y`-1 <= `db`.`y`) AND `user_stats`.`dnow` = `dn`.`id` )
LEFT JOIN `users` AS `user_info` ON ( `user_stats`.`id` = `user_info`.`id` )
WHERE
`dn`.`time_finish` = '0' AND
`db`.`atack` = '0' AND
`db`.`delete` = '0' AND
`db`.`for_dn` = '0' AND
( ( `db`.`go_bot` > '" . (time() - 32400) . "' AND `db`.`go_bot` < '" . (time()) . "') OR `db`.`go_bot`='1') AND
`db`.`inBattle`='0'
GROUP BY `db`.`id2`
ORDER BY `db`.`go_bot` ASC"
);
while ($bot = mysql_fetch_array($query)) {
if ($bot['go_bot'] > 0 && $bot['go_bot'] <= time()) {
$sNext = true;
$sTo = $bot['s'];
$xFrom = $bot['x']; # òåêóùèå êîîðäèíàòû X
$yFrom = $bot['y']; # òåêóùèå êîîðäèíàòû Y
$return = moveBots($bot['s'], $bot);
$xTo = $bot['x'] + $return['x'];
$yTo = $bot['y'] + $return['y'];
# Ïðîâåðÿåì, èìååòñÿ ëè ïåðåõîä ïî êëåòêå.
$inSight = 0;
if (isset($bot['id2'])) {
if ($xFrom == $xTo && $yFrom == $yTo) { # Åñëè îñòàåìñÿ íà ìåñòå.
$inSight = 1;
} elseif (isset($bot['goRight']) && $xFrom == $xTo - 1 && $bot['goRight'] == 1) { //ïðàâî
$sTo = 4;
$inSight = 1;
} elseif (isset($bot['goLeft']) && $xFrom == $xTo + 1 && $bot['goLeft'] == 1) { //ëåâî
$sTo = 2;
$inSight = 1;
} elseif (isset($bot['goTop']) && $yFrom == $yTo - 1 && $bot['goTop'] == 1) { //âåðõ
$sTo = 1;
$inSight = 1;
} elseif (isset($bot['goBottom']) && $yFrom == $yTo + 1 && $bot['goBottom'] == 1) { //íèç
$sTo = 3;
$inSight = 1;
}
}
if (isset($bot['userId'], $bot['userPosY'], $bot['userPosX']) && $bot['userId'] != '' && $bot['agressor'] == 1 && (
($bot['userPosY'] == $bot['y'] + 1 && $bot['userPosX'] == $bot['x']) or
($bot['userPosY'] == $bot['y'] - 1 && $bot['userPosX'] == $bot['x']) or
($bot['userPosY'] == $bot['y'] && $bot['userPosX'] == $bot['x'] - 1) or
($bot['userPosY'] == $bot['y'] && $bot['userPosX'] == $bot['x'] + 1)
)) {
bot['userPosY'] = $yFrom;
$bot['userPosX'] = $xFrom;
mysql_query(
'UPDATE `stats` SET `x` = "' . $xFrom . '" , `y` = "' . $yFrom . '" WHERE `id` = "' . $bot['userId'] . '" LIMIT 1'
);
botAttack($bot, $bot);
} elseif (isset($bot['userId'], $bot['userPosY'], $bot['userPosX']) && $bot['userId'] != '' && $inSight == 1 && $yTo == $bot['userPosY'] && $xTo == $bot['userPosX'] && $bot['atack'] == 1) {
botAttack($bot, $bot);
} elseif ($inSight == 1) { // Ïåðåäâèæåíèå áîòîâ.
$bot['go_bot'] = time() + rand(7, 15);
mysql_query(
'UPDATE `dungeon_bots` SET `x` = "' . $xTo . '",`y` = "' . $yTo . '", `s` = "' . $sTo . '", `go_bot` = "' . $bot['go_bot'] . '" WHERE `id2` = "' . $bot['id2'] . '" LIMIT 1 '
);
}
unset($xFrom, $yFrom, $xTo, $yTo, $inSight, $sNext, $sTo);
}
unset($bot);
}
unset($query, $bot);
$mtime = microtime();
$mtime = explode(" ", $mtime);
$mtime = $mtime[1] + $mtime[0];
$totaltime = ($mtime - $tstart);
printf("Ñòðàíèöà ñãåíåðèðîâàíà çà %f ñåêóíä !", $totaltime);
}
# Çàïóñêàåì âûïîëíåíèå ïðîöåññà.
start();
/* Äëÿ îïòèìèçàöèè çàïðîñà îáíîâëåíèé ïîçèöèé
UPDATE dungeon_bots SET
x = CASE
WHEN id2 = '.$bot['id2'].' THEN "test2"
WHEN id2 = '.$bot['id2'].' THEN "test1" END
WHERE id2 IN ('.$bot['id2'].', 2, 3, 4)
*/
File diff suppressed because it is too large Load Diff