Mass update
This commit is contained in:
+3167
-3770
File diff suppressed because it is too large
Load Diff
@@ -8,7 +8,7 @@
|
||||
* 11. ???
|
||||
*/
|
||||
|
||||
use Insallah\Db;
|
||||
use Core\Db;
|
||||
|
||||
class Chat
|
||||
{
|
||||
|
||||
@@ -4,13 +4,27 @@ namespace Core;
|
||||
|
||||
class Config
|
||||
{
|
||||
private static self $instance;
|
||||
private function __construct()
|
||||
{
|
||||
error_reporting(E_ALL ^ E_NOTICE);
|
||||
setlocale(LC_CTYPE, "ru_RU.CP1251");
|
||||
|
||||
ini_set('display_errors', 'Off');
|
||||
ini_set('default_charset', 'windows-1251');
|
||||
ini_set('date.timezone', 'Europe/Moscow');
|
||||
|
||||
header('Cache-Control: no-cache, no-store, must-revalidate');
|
||||
header('Pragma: no-cache');
|
||||
header('Expires: 0');
|
||||
}
|
||||
|
||||
public static function get(?string $key = null)
|
||||
{
|
||||
$c['ver'] = '1.8.3.7';
|
||||
/* Конфигурации игры */
|
||||
$c['name'] = 'Бойцовский Клуб';
|
||||
$c['title'] = '«' . $c['name'] . '» - Бесплатная,браузерная онлайн игра'; //Название игры
|
||||
$c['title'] = 'Новый «' . $c['name'] . '» - Бесплатная,браузерная онлайн игра'; //Название игры
|
||||
$c['title2'] = ' - Бесплатная, онлайн игра посвященная сражениям и магии!';
|
||||
$c['title3'] = $c['name'];
|
||||
$c['keys'] = $c['name'] . ', combats.com, ' . $c['name'] . ' игра, ' . $c['name'] . ' играть, игра ' . $c['name'] . ', старый ' . $c['name'] . ', ' . $c['name'] . ' онлайн игра, ' . $c['name'] . ' браузерная игра, играть в ' . $c['name'] . ', игра бк, бк игра, старый бк, играть в бк, бк онлайн игра, новый бк, Легендарный ' . $c['name'] . ', легендарный бк, combats, комбатс, combats ru, combats com, OldBK, oldbk ru, oldbk com, олдбк, old bk, олд бк, mycombats, rebk, recombats, oldcombats, obk2'; //Ключевые слова META
|
||||
@@ -23,7 +37,8 @@ class Config
|
||||
$c['thiscity'] = 'capitalcity';
|
||||
$c['capitalcity'] = $c['host'];
|
||||
$c['abandonedplain'] = $c['host'];
|
||||
$c['exit'] = '<script>top.location="https://' . $c['host'] . '/";</script>';
|
||||
$c['https'] = 'https://' . $c['host'] . DIRECTORY_SEPARATOR;
|
||||
$c['exit'] = '<script>top.location="' . $c['https'] . '";</script>';
|
||||
|
||||
//Валюта
|
||||
$c['curency_name'] = 'RUB';
|
||||
@@ -68,20 +83,17 @@ class Config
|
||||
$c['securetime'] = 0; //Время последнего возможного взлома персов (подбор пароля по базам данных других игр)
|
||||
|
||||
$c['copyright'] = 'Copyright © ' . date('Y') . ' « Новый Бойцовский Клуб »';
|
||||
$c['db_user'] = 'newcom1_abk';
|
||||
$c['db_name'] = 'newcom1_abk';
|
||||
$c['db_password'] = '4nWYsIM[c?}P';
|
||||
return $c[$key] ?? $c;
|
||||
}
|
||||
|
||||
public static function init(): void
|
||||
public static function init(): Config
|
||||
{
|
||||
error_reporting(E_ALL ^ E_NOTICE);
|
||||
setlocale(LC_CTYPE, "ru_RU.CP1251");
|
||||
|
||||
ini_set('display_errors', 'Off');
|
||||
ini_set('default_charset', 'windows-1251');
|
||||
ini_set('date.timezone', 'Europe/Moscow');
|
||||
|
||||
header('Cache-Control: no-cache, no-store, must-revalidate');
|
||||
header('Pragma: no-cache');
|
||||
header('Expires: 0');
|
||||
if (!isset(self::$instance)) {
|
||||
self::$instance = new static();
|
||||
}
|
||||
return self::$instance;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,34 +1,44 @@
|
||||
<?php
|
||||
|
||||
# Let's hope it will work.
|
||||
|
||||
namespace Core;
|
||||
|
||||
use PDO;
|
||||
|
||||
class Database
|
||||
{
|
||||
private const DB = 'newcom1_abk';
|
||||
private const USER = 'newcom1_abk';
|
||||
private const PASSWORD = '4nWYsIM[c?}P';
|
||||
private const DSN = 'mysql:host=localhost;dbname=' . self::DB;
|
||||
private static self $instance;
|
||||
protected static PDO $db;
|
||||
|
||||
//todo: remove PDO from files and connect through new pdoinit().
|
||||
public static function init(): PDO
|
||||
{
|
||||
|
||||
mysql_select_db(self::DB, mysql_connect('localhost', self::USER, self::PASSWORD));
|
||||
/**
|
||||
* Singleton.
|
||||
*/
|
||||
private function __construct() {
|
||||
mysql_select_db(Config::get('db_name'), mysql_connect('localhost', Config::get('db_user'), Config::get('db_password')));
|
||||
mysql_query('SET NAMES cp1251');
|
||||
|
||||
return self::pdoinit();
|
||||
}
|
||||
|
||||
/**
|
||||
* Для совместимости со старыми функциями mysql_*.
|
||||
* @return Database
|
||||
*/
|
||||
public static function init(): Database
|
||||
{
|
||||
if (!isset(self::$instance)) {
|
||||
self::$instance = new static();
|
||||
}
|
||||
return self::$instance;
|
||||
}
|
||||
|
||||
/**
|
||||
* Новое подключение к БД.
|
||||
* @return PDO
|
||||
*/
|
||||
public static function pdoinit(): PDO
|
||||
{
|
||||
return new PDO(
|
||||
self::DSN,
|
||||
self::USER,
|
||||
self::PASSWORD,
|
||||
'mysql:host=localhost;dbname=' . Config::get('db_name'),
|
||||
Config::get('db_user'),
|
||||
Config::get('db_password'),
|
||||
[
|
||||
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
|
||||
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
|
||||
|
||||
@@ -0,0 +1,144 @@
|
||||
<?php
|
||||
|
||||
namespace Core;
|
||||
|
||||
use Exception;
|
||||
use PDO;
|
||||
use PDOException;
|
||||
use PDOStatement;
|
||||
|
||||
class Db
|
||||
{
|
||||
|
||||
private static PDO $db;
|
||||
private static self $instance;
|
||||
|
||||
/**
|
||||
* DB constructor.
|
||||
* @throws Exception
|
||||
*/
|
||||
public function __construct()
|
||||
{
|
||||
try {
|
||||
self::$db = Database::pdoinit();
|
||||
} catch (PDOException $e) {
|
||||
throw new Exception($e->getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
private static function init(): void
|
||||
{
|
||||
self::$instance ??= new self();
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string $stmt
|
||||
* @return PDOStatement
|
||||
*/
|
||||
private static function query(string $stmt): PDOStatement
|
||||
{
|
||||
self::init();
|
||||
return self::$db->query($stmt);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string $stmt
|
||||
* @return PDOStatement
|
||||
*/
|
||||
public static function prepare(string $stmt): PDOStatement
|
||||
{
|
||||
self::init();
|
||||
return self::$db->prepare($stmt);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string $query
|
||||
* @return int
|
||||
*/
|
||||
static public function exec(string $query): int
|
||||
{
|
||||
self::init();
|
||||
return self::$db->exec($query);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
*/
|
||||
static public function lastInsertId(): string
|
||||
{
|
||||
self::init();
|
||||
return self::$db->lastInsertId();
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string $query
|
||||
* @param array $args
|
||||
* @return PDOStatement
|
||||
*/
|
||||
public static function run(string $query, array $args = []): PDOStatement
|
||||
{
|
||||
try {
|
||||
if (!$args) {
|
||||
return self::query($query);
|
||||
}
|
||||
$stmt = self::prepare($query);
|
||||
$stmt->execute($args);
|
||||
return $stmt;
|
||||
} catch (PDOException $e) {
|
||||
throw new PDOException($e->getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string $query
|
||||
* @param array $args
|
||||
* @return mixed
|
||||
*/
|
||||
public static function getRow(string $query, array $args = [])
|
||||
{
|
||||
return self::run($query, $args)->fetch();
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string $query
|
||||
* @param array $args
|
||||
* @return array
|
||||
*/
|
||||
public static function getRows(string $query, array $args = []): array
|
||||
{
|
||||
return self::run($query, $args)->fetchAll();
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string $query
|
||||
* @param array $args
|
||||
* @return mixed
|
||||
*/
|
||||
public static function getValue(string $query, array $args = [])
|
||||
{
|
||||
$result = self::getRow($query, $args);
|
||||
if (!empty($result)) {
|
||||
$result = array_shift($result);
|
||||
}
|
||||
return $result;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string $query
|
||||
* @param array $args
|
||||
* @return array
|
||||
*/
|
||||
public static function getColumn(string $query, array $args = []): array
|
||||
{
|
||||
return self::run($query, $args)->fetchAll(PDO::FETCH_COLUMN);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param string $query
|
||||
* @param array $args
|
||||
*/
|
||||
public static function sql(string $query, array $args = [])
|
||||
{
|
||||
self::run($query, $args);
|
||||
}
|
||||
}
|
||||
@@ -1,18 +1,19 @@
|
||||
<?php
|
||||
|
||||
use Insallah\Db;
|
||||
use Core\Config;
|
||||
use Core\Db;
|
||||
|
||||
class FightRequest
|
||||
{
|
||||
private $z1n = [4 => 'ãðóïïîâûå', 5 => 'õàîòè÷íûå'];
|
||||
private $z2n = [4 => 'ãðóïïîâîãî', 5 => 'õàîòè÷íîãî'];
|
||||
private $backTest = false; // Äëÿ ïðîâåðîê õàîòè÷åñêèõ ïîåäèíêîâ.
|
||||
private static $bcktst;
|
||||
/**@var User $u */
|
||||
private $u;
|
||||
private $zv_see;
|
||||
public $test_s = '';
|
||||
public $error = '';
|
||||
private array $z1n = [4 => 'ãðóïïîâûå', 5 => 'õàîòè÷íûå'];
|
||||
private array $z2n = [4 => 'ãðóïïîâîãî', 5 => 'õàîòè÷íîãî'];
|
||||
private bool $backTest = false; // Äëÿ ïðîâåðîê õàîòè÷åñêèõ ïîåäèíêîâ.
|
||||
private static bool $bcktst;
|
||||
|
||||
private User $u;
|
||||
private ?int $zv_see = null;
|
||||
public string $test_s = '';
|
||||
public string $error = '';
|
||||
|
||||
/**
|
||||
* Çàÿâêè íà áîé.
|
||||
@@ -46,7 +47,7 @@ class FightRequest
|
||||
if (!$eff['id2']) {
|
||||
return;
|
||||
}
|
||||
Db::run(
|
||||
Db::sql(
|
||||
'insert into eff_users (overType, id_eff, uid, name, timeUse, data) values (?,?,?,?,unix_timestamp(),?)',
|
||||
[$eff['oneType'], $eff['id2'], $uid, $eff['mname'], $eff['mdata']]
|
||||
);
|
||||
@@ -98,10 +99,8 @@ class FightRequest
|
||||
}
|
||||
if ($pl['users_in'] > 1) {
|
||||
//Íà÷àëî òóðíèðà
|
||||
mysql_query(
|
||||
'UPDATE `turnirs` SET `time` = "' . (time(
|
||||
) + $pl['time3']) . '",`status` = "1" WHERE `id` = "' . $pl['id'] . '" LIMIT 1'
|
||||
);
|
||||
Db::sql('update turnirs set time = unix_timestamp() + ?, status = 1 where id = ?', [$pl['time3'], $pl['id']]);
|
||||
|
||||
$usp = mysql_query(
|
||||
'SELECT * FROM `users` WHERE `inTurnirnew` = "' . $pl['id'] . '" LIMIT ' . $pl['users_in']
|
||||
);
|
||||
@@ -1567,20 +1566,86 @@ class FightRequest
|
||||
echo '<br><br><br><b><font color="black"><center>Ïðèíèìàòü ó÷àñòèå â òóðíèðå òîëüêî ñ ïåðâîãî óðîâíÿ.</center></font></b>';
|
||||
$this->zv_see = 0;
|
||||
} elseif ($r == 10) {
|
||||
|
||||
/** Òóðíèðû by Insallah*/
|
||||
# Çàùèòà îò F5
|
||||
if (!isset($_SESSION['bypass'])) {
|
||||
$_SESSION['bypass'] = mt_rand();
|
||||
}
|
||||
if ($_SERVER['REQUEST_METHOD'] === 'POST' && $_POST['key'] == $_SESSION['bypass']) {
|
||||
unset($_SESSION['bypass']);
|
||||
if (array_key_exists('tournament_start', $_POST)) {
|
||||
(new Insallah\Tournaments\Tournament())->join($this->u->info['id']);
|
||||
if (\Insallah\Tournament::IS_ENABLED) {
|
||||
/** Òóðíèðû by Insallah*/
|
||||
# Çàùèòà îò F5
|
||||
if (!isset($_SESSION['bypass'])) {
|
||||
$_SESSION['bypass'] = mt_rand();
|
||||
}
|
||||
if ($_SERVER['REQUEST_METHOD'] === 'POST' && $_POST['key'] == $_SESSION['bypass']) {
|
||||
unset($_SESSION['bypass']);
|
||||
if (array_key_exists('tournament_start', $_POST)) {
|
||||
(new \Insallah\Tournament())->join($this->u->info['id']);
|
||||
}
|
||||
}
|
||||
##
|
||||
# Ôîðìèðóåì ñïèñîê èäóùèõ òóðíèðîâ.
|
||||
$tournamentsList = Db::getRows('select * from tournaments');
|
||||
$tournaments = '<ul>';
|
||||
foreach ($tournamentsList as $tournament) {
|
||||
$time = $tournament['start_time'] === -1 ? 'Òóðíèð óæå íà÷àëñÿ!' : date(
|
||||
'G:i', $tournament['start_time']
|
||||
);
|
||||
$tournament_members_id = \Insallah\TournamentModel::getFreeFighters($tournament['tid']);
|
||||
$members = [];
|
||||
foreach ($tournament_members_id as $member) {
|
||||
$members[] = \Insallah\TournamentModel::uidToLogin($member);
|
||||
}
|
||||
$tournaments .= sprintf(
|
||||
"<li>Òóðíèð äëÿ %d óðîâíåé.<br>Âðåìÿ ïîäà÷è çàÿâêè: %s<br>Ó÷àñòíèêè: %s</li>",
|
||||
$tournament['tid'], $time, implode(', ', $members)
|
||||
);
|
||||
}
|
||||
$tournaments .= '</ul>';
|
||||
?>
|
||||
<div>
|
||||
<strong style="color: red;">Âíèìàíèå!</strong>
|
||||
<ul>
|
||||
<li style="color: blue;"> ñëó÷àå ñîçäàíèÿ ëèáî ïðèñîåäèíåíèÿ ê Òóðíèðó, ïîêèíóòü åãî -
|
||||
<u>íåâîçìîæíî</u>!
|
||||
</li>
|
||||
<?php if (\Insallah\TournamentModel::isEkrOverpriced($this->u->info['id'])): ?>
|
||||
<li>Ñòîèìîñòü ïðåäìåòîâ, îäåòûõ íà âàñ íå äîëæíà
|
||||
ïðåâûøàòü <?= \Insallah\Tournament::ekrOverpriceFormula(
|
||||
$this->u->info['level']
|
||||
) ?> åâðîêðåäèòîâ.
|
||||
</li>
|
||||
<?php endif; ?>
|
||||
<?php if ($this->u->info['exp'] < \Insallah\Tournament::MIN_EXP): ?>
|
||||
<li>Ó âàñ äîëæíî áûòü íå ìåíåå <?= \Insallah\Tournament::MIN_EXP ?> îïûòà.</li>
|
||||
<?php endif; ?>
|
||||
<li style="color: blue;">Òóðíèð íà÷í¸òñÿ, êîãäà â çàÿâêå
|
||||
íàáåð¸òñÿ <?= \Insallah\Tournament::START_TOURNAMENT ?> ÷åëîâåê.
|
||||
</li>
|
||||
<li style="color: blue;">Èãðîêè çàíÿâøèå 1, 2 è 3 ìåñòà ïîëó÷àò 25, 15, 5 Ðåëèêâèé
|
||||
Àíãåëà, à òàê æå çàäåðæêè íà ó÷àñòèå â òóðíèðå 12 ÷àñîâ, 6 è 3 ÷àñà ñîîòâåòñòâåííî!
|
||||
</li>
|
||||
</ul>
|
||||
</div>
|
||||
<?php if (!empty($tournamentsList)): ?>
|
||||
<div>
|
||||
<strong>Àêòèâíûå òóðíèðû.</strong><br>
|
||||
<?= $tournaments ?>
|
||||
</div>
|
||||
<?php endif; ?>
|
||||
<?php if (!\Insallah\TournamentModel::getTournamentIdByUserId(
|
||||
$this->u->info['id']
|
||||
) || !\Insallah\TournamentModel::isStarted($this->u->info['level'])): ?>
|
||||
<form method="post">
|
||||
<input type="submit" name="tournament_start" value="Ïðèíÿòü ó÷àñòèå â òóðíèðå">
|
||||
<input type="hidden" name="key" value="<?= $_SESSION['bypass'] ?>">
|
||||
</form>
|
||||
<?php else: ?>
|
||||
Âû ó÷àâñòâóåòå.
|
||||
<?php endif; ?>
|
||||
<?php
|
||||
} else {
|
||||
?>
|
||||
<div>
|
||||
<strong style="color: crimson;">Â äàííûé ìîìåíò òóðíèðû íå ïðîâîäÿòñÿ!</strong>
|
||||
</div>
|
||||
<?php
|
||||
}
|
||||
$tlist = new \Insallah\Tournaments\View\TList($this->u);
|
||||
echo $tlist; # Ôîðìèðóåì ñïèñîê èäóùèõ òóðíèðîâ.
|
||||
/** Êîíåö òóðíèðîâ îò Insallah. */
|
||||
} elseif ($this->u->info['zv'] > 0 && $this->u->info['battle'] == 0 && $r != 8) {
|
||||
if ($zi['razdel'] == 1 || $zi['razdel'] == 2 || $zi['razdel'] == 3) {
|
||||
@@ -2268,7 +2333,7 @@ function MM_jumpMenu(targ,selObj,restore){ //v3.0
|
||||
|
||||
public function seeZv()
|
||||
{
|
||||
global $c, $code, $zi;
|
||||
global $code, $zi;
|
||||
if (isset($_GET['r']) && $this->zv_see == 1) {
|
||||
$r = round(intval($_GET['r']));
|
||||
if ($r >= 1 && $r <= 5) {
|
||||
@@ -2592,7 +2657,7 @@ function MM_jumpMenu(targ,selObj,restore){ //v3.0
|
||||
)
|
||||
);
|
||||
$d1 = '';
|
||||
if ($uz['id'] == $this->u->info['id'] || $uze['id'] == $this->u->info['id'] || $this->u->info['level'] <= $c['bot_level']) {
|
||||
if ($uz['id'] == $this->u->info['id'] || $uze['id'] == $this->u->info['id'] || $this->u->info['level'] <= Config::get('bot_level')) {
|
||||
$d1 = 'disabled="disabled"';
|
||||
}
|
||||
if (!isset($uze['id']) || $this->u->info['zv'] == $pl['id']) {
|
||||
@@ -2652,7 +2717,7 @@ function MM_jumpMenu(targ,selObj,restore){ //v3.0
|
||||
<input class="btn" style="margin-top:1px;" type="submit" value="Ïðèíÿòü ó÷àñòèå â ìÿñîðóáêå" /></form></div>';
|
||||
}
|
||||
} else {
|
||||
if ($zvb != '' && $this->u->info['level'] > $c['bot_level']) {
|
||||
if ($zvb != '' && $this->u->info['level'] > Config::get('bot_level')) {
|
||||
echo '<div style="float:left;"><form method="post" style="margin:0px;padding:0px;" action="main.php?zayvka=1&r=' . $r . '&rnd=' . $code . '"><br><input class="btn" name="" type="submit" value="Ïðèíÿòü âûçîâ" /><br>' . $zvb . '<input class="btn" style="margin-top:1px;" type="submit" value="Ïðèíÿòü âûçîâ" /></form></div>';
|
||||
} else {
|
||||
echo '<div style="float:left;">' . $zvb . '</div>';
|
||||
|
||||
@@ -2,11 +2,14 @@
|
||||
|
||||
namespace Insallah;
|
||||
|
||||
use Core\Db;
|
||||
use User;
|
||||
|
||||
class Achievements
|
||||
{
|
||||
private $user;
|
||||
private User $user;
|
||||
private $info;
|
||||
private $data = [
|
||||
private array $data = [
|
||||
'zb' => [
|
||||
'questname' => 'Åæåäí.Çàäàíèÿ',
|
||||
'quest' => 'Âûïîëíèòü çàäàíèÿ áàáêè.',
|
||||
@@ -93,41 +96,51 @@ class Achievements
|
||||
],
|
||||
];
|
||||
|
||||
public function __construct(\User $user)
|
||||
public function __construct(User $user)
|
||||
{
|
||||
$this->user = $user;
|
||||
$this->info = Db::getRow('select * from users_achiv where id = ?', [$user->info['id']]);
|
||||
}
|
||||
|
||||
private function prizeName($int, $string)
|
||||
//fixme: ñþäà èíîãäà ïðèõîäèò (NULL, NULL).
|
||||
private function prizeName(?int $int, ?string $string): string
|
||||
{
|
||||
return in_array($string, ['åêð.', 'êð.']) ? $int . ' ' . $string : $string . ' ' . $int;
|
||||
}
|
||||
|
||||
private function drawSunduk($nagr, $whatInside, $tier)
|
||||
private function drawSunduk($nagr, $whatInside, $tier): string
|
||||
{
|
||||
return vsprintf('<img onclick="%s" onmouseover="%s" onmouseout="%s" onmousedown="%s" class="cp" src="%s" alt="Ñóíäóê">',
|
||||
return vsprintf(
|
||||
'<img onclick="%s" onmouseover="%s" onmouseout="%s" onmousedown="%s" class="cp" src="%s" alt="Ñóíäóê">',
|
||||
[
|
||||
"location.href='\main.php?titul&nagr=$nagr'",
|
||||
"top.hi(this, '<b>Ñóíäóê $tier ðàíãà<hr>Ñîäåðæèò:<hr> $whatInside</b>', event, 2, 0, 1, 1, 'max-width:307px')",
|
||||
"top.hic();",
|
||||
"top.hic();",
|
||||
"https://img.new-combats.com/i/titul/nagr$tier.gif"
|
||||
]);
|
||||
]
|
||||
);
|
||||
}
|
||||
|
||||
public function getList()
|
||||
public function getList(): string
|
||||
{
|
||||
$string = '';
|
||||
$this->calculateCurrent(1);
|
||||
|
||||
foreach ($this->data as $key => $value) {
|
||||
|
||||
//Áëÿ, êàêóþ õåðíþ ïðèõîäèòñÿ ãîðîäèòü!
|
||||
//Ïåðâîå ÷èñëî = òðåáîâàíèå ñëåäóþùåãî òèðà ìèíóñ òðåáîâàíèå òåêóùåãî òèðà (íàäî íàáðàòü)
|
||||
//Âòîðîå ÷èñëî = êîëè÷åñòâî äîñòèæåíèé ìèíóñ òðåáîâàíèå òåêóùåãî òèðà (íàáðàë)
|
||||
//Òðåáîâàíèÿ òåêóùåãî òèðà îòíèìàþòñÿ ÷òîáû êàæäûé òèð íà÷èíàë ñ÷èòàòü ïðîöåíò ñ 0.
|
||||
//Ïèçäû äàòü òîìó, êòî òàê óåáàíñêè íàçûâàåò ïåðåìåííûå, ÷òî íóæíî ïîëäíÿ âúåçæàòü ÷òî ïðîèñõîäèò.
|
||||
//È õåð ïîìåíÿåøü - âñ¸ ñëîìàåòñÿ. FFUUUUUUUUUUUUUU!!! Ins.
|
||||
|
||||
if (!is_numeric($value['check'][$this->info['klas' . $key]])) {
|
||||
// Ïîòîìû ÷òî ïåðâûé ýëåìåíò ìàññèâà - ñëîâî. Â ÐÍÐ5.4 ïðîêàòûâàëî, â ÐÍÐ7.4 - íåò.
|
||||
$value['check'][$this->info['klas' . $key]] = 0;
|
||||
}
|
||||
|
||||
$percentToSuccess = Math::get100Percentage(
|
||||
$value['check'][$this->info['klas' . $key] + 1] - $value['check'][$this->info['klas' . $key]],
|
||||
$this->info[$key] - $value['check'][$this->info['klas' . $key]]
|
||||
@@ -136,7 +149,8 @@ class Achievements
|
||||
$string .= '<h4>' . $questname . '</h4>';
|
||||
$string .= '<strong>' . $value['quest'] . '</strong><br>';
|
||||
$string .= 'Òåêóùèé Ðàíã: <strong>' . $this->info['klas' . $key] . '</strong> ';
|
||||
$string .= 'Êîëè÷åñòâî ' . mb_strtolower($value['check'][0]) . ': <strong>' . $this->info[$key] . ' =' . $percentToSuccess . '%</strong>';
|
||||
$string .= 'Êîëè÷åñòâî ' . mb_strtolower($value['check'][0]) . ': <strong>' . $this->info[$key] . ' = ' . $percentToSuccess . '%</strong>';
|
||||
//$string .= '<progress value="' . $percentToSuccess . '" max="100" style="accent-color:green; appearance: none;">' . $percentToSuccess . '</progress>';
|
||||
|
||||
$string .= Table::get([
|
||||
['Ðàíãè', 1, 2, 3, 4, 5],
|
||||
@@ -182,6 +196,10 @@ class Achievements
|
||||
continue;
|
||||
}
|
||||
|
||||
if (is_null($this->info[$k])) {
|
||||
$this->info[$k] = 0;
|
||||
}
|
||||
|
||||
$this->info["klas$k"] = 0;
|
||||
$this->info["name$k"] = $this->data[$k]['questname'];
|
||||
$this->info["klasP$k"] = Math::get100Percentage($this->data[$k]['check'][1], $this->info[$k]);
|
||||
@@ -203,10 +221,10 @@ class Achievements
|
||||
}
|
||||
}
|
||||
|
||||
public function getInfo($user_id = null)
|
||||
public function getInfo(?int $uid = null)
|
||||
{
|
||||
if (!is_null($user_id)) {
|
||||
$this->info = Db::getRow('select * from users_achiv where id = ?', [$user_id]);
|
||||
if (!is_null($uid)) {
|
||||
$this->info = \Core\Db::getRow('select * from users_achiv where id = ?', [$uid]);
|
||||
}
|
||||
$this->calculateCurrent();
|
||||
return $this->info;
|
||||
@@ -220,7 +238,7 @@ class Achievements
|
||||
|
||||
private function addOne($name)
|
||||
{
|
||||
Db::sql("update users_achiv set $name = $name + 1 where id = ?", [$this->user->info['id']]);
|
||||
\Core\Db::sql("update users_achiv set $name = $name + 1 where id = ?", [$this->user->info['id']]);
|
||||
}
|
||||
|
||||
public function updateTier($name)
|
||||
@@ -240,12 +258,12 @@ class Achievements
|
||||
/**
|
||||
* @return array[]
|
||||
*/
|
||||
public function getData()
|
||||
public function getData(): array
|
||||
{
|
||||
return $this->data;
|
||||
}
|
||||
|
||||
public function hasNoTier4Access($nagr)
|
||||
public function hasNoTier4Access($nagr): bool
|
||||
{
|
||||
return $this->user->info['level'] < 9 && in_array($nagr, [14, 15, 24, 25, 34, 35, 44, 45, 54, 55, 64, 65, 74, 75, 84, 85, 94, 95, 104, 105]);
|
||||
}
|
||||
@@ -257,7 +275,7 @@ class Achievements
|
||||
}
|
||||
}
|
||||
|
||||
public function getTypes()
|
||||
public function getTypes(): array
|
||||
{
|
||||
return array_keys($this->data);
|
||||
}
|
||||
|
||||
@@ -1,7 +1,16 @@
|
||||
<?php
|
||||
|
||||
//use Insallah\Tournament;
|
||||
|
||||
//require_once 'Core/Db.php';
|
||||
require_once 'Core/Math.php';
|
||||
require_once 'Core/Table.php';
|
||||
require_once 'Runes/Runes.php';
|
||||
//require_once 'Tournament/Tournament.php';
|
||||
//require_once 'Tournament/TournamentModel.php';
|
||||
require_once 'Achievements.php';
|
||||
|
||||
//Âìåñòî êðîíà äëÿ òóðíèðà.
|
||||
//if (Tournament::IS_ENABLED) {
|
||||
// (new Tournament())->startAllBattles();
|
||||
//}
|
||||
@@ -2,14 +2,14 @@
|
||||
|
||||
namespace Insallah;
|
||||
|
||||
use Core\Database;
|
||||
//use Core\Database;
|
||||
use Exception;
|
||||
use http\Message;
|
||||
//use http\Message;
|
||||
use PDO;
|
||||
use PDOException;
|
||||
use PDOStatement;
|
||||
|
||||
class Db
|
||||
class DbOld
|
||||
{
|
||||
/**
|
||||
* Íàñòðîéêè ïîäêëþ÷åíèÿ
|
||||
@@ -5,19 +5,30 @@ namespace Insallah;
|
||||
/** All raw mathematics in one place. */
|
||||
class Math
|
||||
{
|
||||
public static function getPercentage($total, $number)
|
||||
/**
|
||||
* @param float|int $total
|
||||
* @param int|null $number
|
||||
* @return float
|
||||
*/
|
||||
public static function getPercentage($total, ?int $number): float
|
||||
{
|
||||
if (is_null($number)) {
|
||||
return 0;
|
||||
}
|
||||
return $total > 0 ? round(($number * 100) / $total, 2) : 0;
|
||||
}
|
||||
|
||||
|
||||
public static function get100Percentage($total, $number)
|
||||
public static function get100Percentage($total, ?int $number)
|
||||
{
|
||||
if (is_null($number)) {
|
||||
return 0;
|
||||
}
|
||||
return min(self::getPercentage($total, $number), 100);
|
||||
}
|
||||
|
||||
/** Number-20% and Number+20% */
|
||||
public static function get20PercentRange($number)
|
||||
public static function get20PercentRange($number): array
|
||||
{
|
||||
return [
|
||||
'min' => $number * ((100 - 20) / 100),
|
||||
|
||||
@@ -0,0 +1,37 @@
|
||||
<?php
|
||||
|
||||
namespace Insallah;
|
||||
|
||||
/** All raw mathematics in one place. */
|
||||
class Math
|
||||
{
|
||||
/**
|
||||
* @param float|int $total
|
||||
* @param int|null $number
|
||||
* @return float
|
||||
*/
|
||||
public static function getPercentage($total, int $number): float
|
||||
{
|
||||
return $total > 0 ? round(($number * 100) / $total, 2) : 0;
|
||||
}
|
||||
|
||||
|
||||
public static function get100Percentage($total, int $number)
|
||||
{
|
||||
return min(self::getPercentage($total, $number), 100);
|
||||
}
|
||||
|
||||
/** Number-20% and Number+20% */
|
||||
public static function get20PercentRange($number): array
|
||||
{
|
||||
return [
|
||||
'min' => $number * ((100 - 20) / 100),
|
||||
'max' => $number * ((100 + 20) / 100),
|
||||
];
|
||||
}
|
||||
|
||||
public static function addPercent($num, $percent)
|
||||
{
|
||||
return $num + (($percent / 100) * $num);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,22 @@
|
||||
<?php
|
||||
|
||||
namespace Insallah;
|
||||
|
||||
class Table
|
||||
{
|
||||
public static function get($rows, $class = '', $fill = false)
|
||||
{
|
||||
$c = '';
|
||||
$max_rows = sizeof(max($rows));
|
||||
|
||||
|
||||
foreach ($rows as $row) {
|
||||
if ($fill && sizeof($row) < $max_rows) {
|
||||
$row = array_merge($row, array_fill(0, $max_rows - sizeof($row), ''));
|
||||
}
|
||||
$c .= '<tr><td>' . implode('</td><td>', $row) . '</td></tr>';
|
||||
}
|
||||
|
||||
return (!empty($class) ? "<table class='$class'>" : '<table>') . $c . '</table>' . PHP_EOL;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,141 @@
|
||||
<?php
|
||||
|
||||
namespace Insallah;
|
||||
|
||||
class Tournament
|
||||
{
|
||||
const IS_ENABLED = true;
|
||||
private const SEND_CHAT_MESSAGE = 3;
|
||||
private const START_TOURNAMENT = 5;
|
||||
private const PRIZE1 = 25;
|
||||
private const PRIZE2 = 10;
|
||||
private const PRIZE3 = 5;
|
||||
const MIN_EXP = 175000;
|
||||
private const CHAT_MESSAGE = 'Âíèìàíèå! Òóðíèð äëÿ %d óðîâíÿ îòêðûò! Ïîñïåøèòå ïðèíÿòü ó÷àñòèå â Çàëå Âîèíîâ!';
|
||||
private const VICTORY_MESSAGE = 'Òóðíèð äëÿ %d óðîâíåé çàâåðø¸í! Ïåðâîå ìåñòî: %s. Âòîðîå ìåñòî: %s. Òðåòüå ìåñòî: %s.';
|
||||
private const DELAY1 = '+12hour';
|
||||
private const DELAY2 = '+6hour';
|
||||
private const DELAY3 = '+3hour';
|
||||
|
||||
/** Ôîðìóëà ðàññ÷¸òà ðàçðåø¸ííîé ñòîèìîñòè îäåòûõ ïðåäìåòîâ.
|
||||
*
|
||||
* @param int $int
|
||||
*
|
||||
* @return float|int
|
||||
*/
|
||||
public static function ekrOverpriceFormula(int $int): int
|
||||
{
|
||||
return ($int - 7) * 151;
|
||||
}
|
||||
|
||||
/**
|
||||
* Ïðîâåðÿåì ìîæåò ëè èãðîê ó÷àâñòâîâàòü â òóðíèðå è ëèáî ïðèñîåäèíÿåì åãî, ëèáî îáëàìûâàåì.
|
||||
*
|
||||
* @param int $uid
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function join(int $uid): void
|
||||
{
|
||||
/** Âîçâðàùàåò level, èëè 0 åñëè ïðîâàëåíû ïðîâåðêè. */
|
||||
$userLevel = TournamentModel::getUserLevel($uid);
|
||||
if (
|
||||
$userLevel === 0 ||
|
||||
TournamentModel::isEkrOverpriced($uid, $userLevel) ||
|
||||
!TournamentModel::isEnoughExperience($uid) ||
|
||||
TournamentModel::isRestrictedToJoin($uid) ||
|
||||
TournamentModel::isStarted($uid)
|
||||
) {
|
||||
return;
|
||||
}
|
||||
|
||||
$mq = TournamentModel::getWaitingMembersQuantity($userLevel);
|
||||
if (empty($mq)) {
|
||||
TournamentModel::createTournament($userLevel);
|
||||
}
|
||||
|
||||
TournamentModel::joinTournament($uid, $userLevel);
|
||||
$mq++;
|
||||
|
||||
if ($mq == self::SEND_CHAT_MESSAGE) {
|
||||
TournamentModel::sysMessage(sprintf(self::CHAT_MESSAGE, $userLevel));
|
||||
}
|
||||
|
||||
if ($mq == self::START_TOURNAMENT) {
|
||||
TournamentModel::startTournament($userLevel);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Ïðîâåðêà äëÿ êðîíà\êîíôèãà. Âûáèâàåò ïðîèãðàâøèõ è ïåðåçàïóñêàåò ïîåäèíêè âî âñåõ òóðíèðàõ.
|
||||
* @return void
|
||||
*/
|
||||
public function startAllBattles(): void
|
||||
{
|
||||
$db = new Db();
|
||||
$db::sql(
|
||||
'delete from tournaments where start_time + date_add(start_time,interval 30 minute) < unix_timestamp()'
|
||||
);
|
||||
TournamentModel::removeFighter(TournamentModel::getLooser());
|
||||
$tournamentLevels = $db::getColumn('select tid from tournaments where start_time = -1');
|
||||
foreach ($tournamentLevels as $level) {
|
||||
$aliveFighters = TournamentModel::getFreeFighters($level);
|
||||
if (count($aliveFighters) > 1) {
|
||||
shuffle($aliveFighters);
|
||||
$this->startBattle($aliveFighters);
|
||||
} elseif (count($aliveFighters) === 1) {
|
||||
TournamentModel::removeFighter($aliveFighters[0], true);
|
||||
$this->victory($level);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Ïîëó÷àåì ïàðû áîéöîâ è íà÷èíàåì èõ ïîåäèíêè.
|
||||
*
|
||||
* @param array $fightersList
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
private function startBattle(array $fightersList): void
|
||||
{
|
||||
$teams = TournamentModel::getFightersTeams($fightersList);
|
||||
foreach ($teams as $team) {
|
||||
if (count($team) === 2) {
|
||||
TournamentModel::startBattle($team[0], $team[1]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Íàãðàæäàåì ïîáåäèòåëåé òóðíèðà, ÷èñòèì áàçó.
|
||||
*
|
||||
* @param int $tid
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
private function victory(int $tid): void
|
||||
{
|
||||
$winners = TournamentModel::getWinners($tid);
|
||||
sleep(1);
|
||||
TournamentModel::givePrizeItems($winners[1], self::PRIZE1);
|
||||
TournamentModel::givePrizeItems($winners[2], self::PRIZE2);
|
||||
TournamentModel::givePrizeItems($winners[3], self::PRIZE3);
|
||||
sleep(1);
|
||||
TournamentModel::giveDelay($winners[1], strtotime(self::DELAY1));
|
||||
TournamentModel::giveDelay($winners[2], strtotime(self::DELAY2));
|
||||
TournamentModel::giveDelay($winners[3], strtotime(self::DELAY3));
|
||||
sleep(1);
|
||||
TournamentModel::sysMessage(
|
||||
sprintf(
|
||||
self::VICTORY_MESSAGE,
|
||||
$tid,
|
||||
TournamentModel::uidToLogin($winners[1]),
|
||||
TournamentModel::uidToLogin($winners[2]),
|
||||
TournamentModel::uidToLogin($winners[3])
|
||||
)
|
||||
);
|
||||
sleep(3);
|
||||
TournamentModel::destroyTournament($tid);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,358 @@
|
||||
<?php
|
||||
|
||||
namespace Insallah;
|
||||
|
||||
class TournamentModel
|
||||
{
|
||||
|
||||
/**
|
||||
* ïðîâåðêà óðîâíÿ, ñòîèìîñòè ýêâèïà, ïðî÷èå ïðîâåðêè, ÷òî ïåðñîíàæ ñâîáîäåí
|
||||
* òàéìåð îæèäàíèÿ 30 ìèíóò
|
||||
*
|
||||
* @param int $uid
|
||||
*
|
||||
* @return int
|
||||
*/
|
||||
public static function getUserLevel(int $uid): int
|
||||
{
|
||||
$db = new Db();
|
||||
$level = $db::getValue('select level from users where id = ? and level between 8 and 12 and battle = 0', [$uid]);
|
||||
return $level ?: 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $uid
|
||||
* @param int|null $level
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public static function isEkrOverpriced(int $uid, ?int $level = null): bool
|
||||
{
|
||||
$db = new Db();
|
||||
if (is_null($level)) {
|
||||
$level = $db::getValue('select level from users where id = ?', [$uid]);
|
||||
}
|
||||
$wearedItemsEkrPrice = $db::getValue('select sum(2price) from items_users where inOdet > 0 and uid = ?', [$uid]);
|
||||
return $wearedItemsEkrPrice > Tournament::ekrOverpriceFormula($level);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $uid
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public static function isEnoughExperience(int $uid): bool
|
||||
{
|
||||
$db = new Db();
|
||||
return $db::getValue('select exp from stats where id = ?', [$uid]) >= Tournament::MIN_EXP;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $uid
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public static function isRestrictedToJoin(int $uid): bool
|
||||
{
|
||||
$db = new Db();
|
||||
return $db::getValue('select count(*) from eff_users where uid = ? and id_eff = 486 and `delete` = 0', [$uid]);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param int $tid
|
||||
*
|
||||
* @return bool
|
||||
*/
|
||||
public static function isStarted(int $tid): bool
|
||||
{
|
||||
$db = new Db();
|
||||
return $db::getValue('select count(*) from tournaments where start_time = -1 and tid = ?', [$tid]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Ñ÷èòàåì ñêîëüêî èãðîêîâ æäóò â çàÿâêå íà òóðíèð.
|
||||
*
|
||||
* @param int $tid
|
||||
*
|
||||
* @return int
|
||||
*/
|
||||
public static function getWaitingMembersQuantity(int $tid): int
|
||||
{
|
||||
$db = new Db();
|
||||
return $db::getValue('select count(*) from tournaments_users where tid = ?', [$tid]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Ñîçäàíèå íîâîãî òóðíèðà.
|
||||
*
|
||||
* @param int $tid
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public static function createTournament(int $tid): void
|
||||
{
|
||||
$db = new Db();
|
||||
$db::sql('insert into tournaments (tid) values (?)', [$tid]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Èãðîê ïðèñîåäèíÿåòñÿ ê òóðíèðó è òåëåïîðòèðóåòñÿ â òóðíèðíóþ êîìíàòó.
|
||||
*
|
||||
* @param int $uid
|
||||
* @param int $tid
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public static function joinTournament(int $uid, int $tid): void
|
||||
{
|
||||
/** Êàñòîìíûå êîìíàòû 25008 - 25012. */
|
||||
$roomId = 25000 + $tid;
|
||||
$db = new Db();
|
||||
$db::sql('insert into tournaments_users (tid, uid) values (?, ?)', [$tid, $uid]);
|
||||
self::teleport($uid, $roomId);
|
||||
}
|
||||
|
||||
/**
|
||||
* Ñòàðò òóðíèðà.
|
||||
*
|
||||
* @param int $tid
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public static function startTournament(int $tid): void
|
||||
{
|
||||
$db = new Db();
|
||||
$db::sql('update tournaments set start_time = -1 where tid = ?', [$tid]);
|
||||
}
|
||||
|
||||
/**
|
||||
* ×èñòèì áàçû îò ïðîøåäøåãî òóðíèðà.
|
||||
*
|
||||
* @param int $tid
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public static function destroyTournament(int $tid): void
|
||||
{
|
||||
$db = new Db();
|
||||
//Óáåäèòüñÿ ÷òî â áàçå íàñòðîåí foreign_keys è ïîñëåäóåò àâòîî÷èñòêà tournaments_users !!!
|
||||
$db::sql('delete from tournaments where tid = ?', [$tid]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Ïîëó÷àåì ñïèñîê áîéöîâ è áü¸ì èõ íà ïàðû. Âîçâðàùàåì ñïèñêè ïàð + 1 ïîñëåäíèé áåç ïàðû åñëè åñòü.
|
||||
*
|
||||
* @param array $fightersList
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
public static function getFightersTeams(array $fightersList): array
|
||||
{
|
||||
$db = new Db();
|
||||
$query = sprintf("select id from users where battle = 0 and id in (%s)", implode(', ', $fightersList));
|
||||
return array_chunk($db::getColumn($query), 2);
|
||||
}
|
||||
|
||||
/**
|
||||
* Âûáèðàåì æèâûõ áîéöîâ íå ñðàæàþùèõñÿ â äàííûé ìîìåíò.
|
||||
*
|
||||
* @param int $tid
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
public static function getFreeFighters(int $tid): array
|
||||
{
|
||||
$db = new Db();
|
||||
return $db::getColumn('select uid from tournaments_users where tid = ? and death_time = 0 order by uid', [$tid]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Âûáèðàåì ïîáåäèòåëåé. Ñìåùàåì ìàññèâ, ÷òîáû âîçâðàò ø¸ë ñ åäèíèöû.
|
||||
*
|
||||
* @param int $tid
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
public static function getWinners(int $tid): array
|
||||
{
|
||||
$db = new Db();
|
||||
$winners = $db::getColumn('select uid from tournaments_users where tid = ? order by death_time desc limit 3', [$tid]);
|
||||
return [
|
||||
1 => $winners[0],
|
||||
2 => $winners[1],
|
||||
3 => $winners[2]
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* Ïðîáóåì âûêóñèòü ïðîèãðàâøåãî â ïîñëåäíåé òóðíèðíîé áèòâå è óäàëèòü ýòó ñàìóþ áèòâó âî èçáåæàíèå.
|
||||
* @return mixed
|
||||
*/
|
||||
public static function getLooser()
|
||||
{
|
||||
$query = '
|
||||
select uid, battle
|
||||
from
|
||||
battle_users,
|
||||
(select id, team_win
|
||||
from battle
|
||||
where
|
||||
team_win > 0 and
|
||||
typeBattle = 25000
|
||||
order by time_over desc
|
||||
limit 1) as last_battle
|
||||
where
|
||||
battle_users.battle = last_battle.id and
|
||||
battle_users.team != last_battle.team_win and
|
||||
battle_users.uid in (select uid from tournaments_users where death_time = 0)';
|
||||
|
||||
$query2 = 'select bu.uid from battle b
|
||||
inner join battle_users bu on b.team_win != bu.team and b.id = bu.battle
|
||||
inner join tournaments_users tu on bu.uid = tu.uid
|
||||
where typeBattle = 25000 and death_time = 0 order by b.time_start desc limit 1';
|
||||
$db = new Db;
|
||||
$row = $db::getRow($query);
|
||||
return $row['uid'] ?? 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* Âûáûâøèé èç òóðíèðà ïîêèäàåò êîìíàòó è ïîëó÷àåò âðåìÿ ñìåðòè.
|
||||
*
|
||||
* @param int $uid
|
||||
* @param bool $winner
|
||||
* @return void
|
||||
*/
|
||||
public static function removeFighter(int $uid, bool $winner = false): void
|
||||
{
|
||||
if (!$uid) {
|
||||
return;
|
||||
}
|
||||
//$winner_timer_add = $winner? 500 : 0; # Ïîñëåäíûé ÄÎËÆÅÍ áûòü ïîñëåäíèì.
|
||||
$db = new Db();
|
||||
$db::sql('update tournaments_users set death_time = unix_timestamp() + 500 where death_time = 0 and uid = ?', [$uid]);
|
||||
self::teleport($uid, 9);
|
||||
//fixme: Êëàññû íå ïîäêëþ÷àþòñÿ äðóã ê äðóãó. Íóæíî ìåíÿòü àðõèòåêòóðó èãðû. :(
|
||||
Db::sql("update users_achiv set trn = trn + 1 where id = ?", [$uid]);
|
||||
//(new Achievements(\user::start()))->updateCounter('trn');
|
||||
}
|
||||
|
||||
/**
|
||||
* Óçíà¸ì id òóðíèðà ïî id èãðîêà.
|
||||
*
|
||||
* @param int $uid
|
||||
*
|
||||
* @return mixed
|
||||
*/
|
||||
public static function getTournamentIdByUserId(int $uid)
|
||||
{
|
||||
$db = new Db();
|
||||
return $db::getValue('select tid from tournaments_users where uid = ?', [$uid]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Ïîïðîáóåì ñòàðòîíóòü ïîåäèíîê.
|
||||
* 25000 - Óíèêàëüíûé id ïîåäèíêà ïîä òóðíèðû.
|
||||
* noinc - çàïðåò íà âìåøàòåëüñòâî
|
||||
* invis - íåâèäèìûé áîé
|
||||
*
|
||||
* @param int $uid1
|
||||
* @param int $uid2
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public static function startBattle(int $uid1, int $uid2): void
|
||||
{
|
||||
$db = new Db();
|
||||
$check = Db::getValue('select count(*) from users where id in (?, ?) and battle = 0', [$uid1, $uid2]);
|
||||
if ($check !== 2) {
|
||||
return;
|
||||
}
|
||||
|
||||
$db::exec('insert into battle (city, time_start, timeout, type, invis, noinc, travmChance, typeBattle)
|
||||
values (\'capitalcity\', unix_timestamp(), 60, 0, 1, 1, 0, 25000)');
|
||||
$bid = $db::lastInsertId(); // ÂÀÆÍÎ!
|
||||
$db::sql('update stats set team = 1, hpNow = hpAll, mpNow = mpAll where id = ?', [$uid1]);
|
||||
$db::sql('update stats set team = 2, hpNow = hpAll, mpNow = mpAll where id = ?', [$uid2]);
|
||||
$db::sql('update users set battle = ? where id in (?, ?)', [$bid, $uid1, $uid2]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Óçíà¸ì ëîãèí ïåðñîíàæà ïî åãî id.
|
||||
*
|
||||
* @param int $uid
|
||||
*
|
||||
* @return mixed
|
||||
*/
|
||||
public static function uidToLogin(int $uid)
|
||||
{
|
||||
$db = new Db();
|
||||
return $db::getValue('select login from users where id = ?', [$uid]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Òåëåïîðò ïî êîìíàòàì.
|
||||
*
|
||||
* @param int $uid
|
||||
* @param int $roomId
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
private static function teleport(int $uid, int $roomId): void
|
||||
{
|
||||
$db = new Db();
|
||||
$db::sql('update users set room = ? where id = ?', [$roomId, $uid]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Íåò ïðîâåðîê $message ïîòîìó ÷òî îíî âñåãäà çàäà¸òñÿ â êîäå è èãðîê íà íåãî íå âëèÿåò.
|
||||
*
|
||||
* @param string $message
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public static function sysMessage(string $message): void
|
||||
{
|
||||
if (!empty($message)) {
|
||||
$db = new Db();
|
||||
$message = "<span style='font-weight: bold; color: forestgreen;'>$message</span>";
|
||||
$db::sql('insert into chat (time, type, text, new, da) values (unix_timestamp(), 6, ?, 1, 1)', [$message]);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Ãåíåðèðóåò ìíîæåñòâåííûé çàïðîñ ñðàçó íà $quantity îäíîòèïíûõ ïðåäìåòîâ â èíâåíòàðü ïîëüçîâàòåëÿ $uid.
|
||||
*
|
||||
* @param int $uid
|
||||
* @param int $quantity
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public static function givePrizeItems(int $uid, int $quantity): void
|
||||
{
|
||||
$query = 'insert into items_users (item_id, uid, data, iznosMAX, lastUPD, time_create)
|
||||
values (4754, :uid, :data, 1, unix_timestamp(), unix_timestamp())';
|
||||
$args = [
|
||||
'uid' => $uid,
|
||||
'data' => 'nosale=1|musor=1|sudba=' . self::uidToLogin($uid) . '|lvl=8|tr_s1=0|tr_s2=0|tr_s3=0|tr_s4=0'
|
||||
];
|
||||
$db = new Db();
|
||||
$stmt = $db::prepare($query);
|
||||
for ($i = 0; $i < $quantity; $i++) {
|
||||
$stmt->execute($args);
|
||||
}
|
||||
}
|
||||
|
||||
/** Ýôôåêò-îãðàíè÷èòåëü íà ó÷àñòèå â òóðíèðå.
|
||||
* @param int $uid
|
||||
* @param int $unixtime
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public static function giveDelay(int $uid, int $unixtime): void
|
||||
{
|
||||
$db = new Db();
|
||||
$query = 'insert into eff_users (id_eff, uid, name, timeUse) VALUES (?,?,?,?)';
|
||||
$args = [486, $uid, 'Ïðèç¸ð ãîðîäñêîãî òóðíèðà!', $unixtime];
|
||||
$db::sql($query, $args);
|
||||
}
|
||||
}
|
||||
@@ -31,11 +31,9 @@ class TList
|
||||
$this->str .= '<li>Ó âàñ äîëæíî áûòü íå ìåíåå ' . Config::MIN_EXP . ' îïûòà.</li>';
|
||||
}
|
||||
$this->str .= '<li>Òóðíèð íà÷í¸òñÿ, êîãäà â çàÿâêå
|
||||
íàáåð¸òñÿ ' . Config::START_TOURNAMENT . ' ÷åëîâåê.</li>';
|
||||
$this->str .= '<li>Èãðîêè çàíÿâøèå 1, 2 è 3 ìåñòà ïîëó÷àò ' . Config::PRIZE1 . ', ' . Config::PRIZE2 . ',
|
||||
' . Config::PRIZE3 . ' Ðåëèêâèé Àíãåëà, à òàê æå çàäåðæêè íà ó÷àñòèå â òóðíèðå
|
||||
12 ÷àñîâ, 6 è 3 ÷àñà ñîîòâåòñòâåííî!</li>';
|
||||
$this->str .= '</ul></div>';
|
||||
íàáåð¸òñÿ ' . Config::START_TOURNAMENT . ' ÷åëîâåê.</li>
|
||||
</ul>
|
||||
</div>';
|
||||
$this->str .= $tournamentstatus->getList();
|
||||
if (!User::getTournamentIdByUserId($user->info['id']) || !$tournamentstatus->isStarted($user->info['level'])) {
|
||||
$this->str .= '<form method="post">
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
<?php
|
||||
|
||||
use Insallah\Db;
|
||||
use Core\Db;
|
||||
|
||||
class Learming
|
||||
{
|
||||
|
||||
@@ -1604,7 +1604,7 @@ class Magic
|
||||
|
||||
private static function getDressedEkrTotalPrice($uid)
|
||||
{
|
||||
return \Insallah\Db::getValue('select sum(2price) from items_users where inOdet > 0 and uid = ?', [$uid]);
|
||||
return \Core\Db::getValue('select sum(2price) from items_users where inOdet > 0 and uid = ?', [$uid]);
|
||||
}
|
||||
|
||||
private static function canAttack8Level($attacker, $target)
|
||||
|
||||
@@ -0,0 +1,17 @@
|
||||
<?php
|
||||
|
||||
class PassGen
|
||||
{
|
||||
public static function new($length = 8)
|
||||
{
|
||||
return substr(
|
||||
preg_replace(
|
||||
"/[^a-zA-Z0-9]/",
|
||||
"",
|
||||
base64_encode(openssl_random_pseudo_bytes($length + 1))
|
||||
),
|
||||
0,
|
||||
$length
|
||||
);
|
||||
}
|
||||
}
|
||||
@@ -1,6 +1,6 @@
|
||||
<?php
|
||||
|
||||
use Insallah\Db;
|
||||
use Core\Db;
|
||||
use Insallah\Math;
|
||||
|
||||
/*
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
<?php
|
||||
|
||||
use Insallah\Db;
|
||||
use Core\Db;
|
||||
|
||||
class Season
|
||||
{
|
||||
|
||||
@@ -1,14 +1,13 @@
|
||||
<?php
|
||||
if (!defined('GAME')) {
|
||||
die();
|
||||
}
|
||||
|
||||
use Core\Db;
|
||||
|
||||
class Tournir
|
||||
{
|
||||
private $u;
|
||||
private $info;
|
||||
private $user;
|
||||
private $name = [0 => 'Âûæèòü ëþáîé öåíîé', 1 => 'Êàæäûé ñàì çà ñåáÿ', 2 => 'Çàõâàò êëþ÷à',];
|
||||
private User $u;
|
||||
private array $info;
|
||||
private array $user;
|
||||
private array $name = [0 => 'Âûæèòü ëþáîé öåíîé', 1 => 'Êàæäûé ñàì çà ñåáÿ', 2 => 'Çàõâàò êëþ÷à',];
|
||||
|
||||
public function __construct()
|
||||
{
|
||||
@@ -19,24 +18,24 @@ class Tournir
|
||||
|
||||
private function start()
|
||||
{
|
||||
$this->info = mysql_fetch_array(mysql_query('SELECT * FROM `turnirs` WHERE `id` = "' . $this->u->info['inTurnirnew'] . '" LIMIT 1'));
|
||||
$this->user = mysql_fetch_array(mysql_query('SELECT * FROM `users_turnirs` WHERE `turnir` = "' . $this->u->info['inTurnirnew'] . '" AND `bot` = "' . $this->u->info['id'] . '" LIMIT 1'));
|
||||
$this->info = Db::getRow('select * from turnirs where id = ?', [$this->u->info['inTurnirnew']]);
|
||||
$this->user = Db::getRow('select * from users_turnirs where turnir = ? and bot = ?', [$this->u->info['inTurnirnew'], $this->u->info['id']]);
|
||||
}
|
||||
|
||||
private function startTurnir()
|
||||
{
|
||||
$row = mysql_fetch_array(mysql_query('SELECT COUNT(*) FROM `users` WHERE `win` = "0" AND `lose` = "0" AND `nich` = "0"'));
|
||||
if ($row[0] <= 0 || $this->info['status'] == 3) {
|
||||
$row = Db::getValue('select count(*) from users where win = 0 and lose = 0 and nich = 0');
|
||||
if (!$row || $this->info['status'] == 3) {
|
||||
if ($this->info['status'] == 3) {
|
||||
$this->finishTurnir();
|
||||
}
|
||||
} else {
|
||||
mysql_query('UPDATE `turnirs` SET `status` = "3" WHERE `id` = "' . $this->info['id'] . '" LIMIT 1');
|
||||
Db::sql('update turnirs set status = 3 where id = ?', [$this->info['id']]);
|
||||
//Ñîçäàíèå ïîåäèíêà
|
||||
mysql_query('INSERT INTO `battle` (`city`,`time_start`,`timeout`,`type`,`turnir`) VALUES ("' . $this->u->info['city'] . '","' . time() . '","60","1","' . $this->info['id'] . '")');
|
||||
$uri = mysql_insert_id();
|
||||
Db::sql('insert into battle (city, time_start, timeout, type, turnir) values (?,unix_timestamp(),60,1,?)', [$this->u->info['city'], $this->info['id']]);
|
||||
$uri = Db::lastInsertId();
|
||||
//Çàêèäûâàåì ïåðñîíàæåé â ïîåäèíîê
|
||||
mysql_query('UPDATE `users` SET `battle` = "' . $uri . '" WHERE `inUser` = "0" AND `inTurnirnew` = "' . $this->info['id'] . '"');
|
||||
Db::sql('update users set battle = ? where inUser = 0 and inTurnirnew = ?', [$uri, $this->info['id']]);
|
||||
//Îáîçíà÷àåì çàâåðøåíèå òóðíèðà ïðè âûõîäå
|
||||
die('Ïåðåéòèäå â ðàçäåë "ïîåäèíêè"...');
|
||||
}
|
||||
@@ -62,9 +61,6 @@ class Tournir
|
||||
}
|
||||
|
||||
if ($pl['team'] == $this->info['winner'] && $this->info['winner'] != 0) {
|
||||
|
||||
$inf['add_expn'] = 3000;
|
||||
|
||||
$inf['add_expp'] = [0, 1, 5, 10, 15, 25, 35, 70, 100, 150, 200, 300, 500, 700, 1000];
|
||||
|
||||
//ïîëó÷àåì îïûò (ñ 0 ïî 12 ëâë)
|
||||
@@ -82,7 +78,6 @@ class Tournir
|
||||
mysql_query('UPDATE `users` SET `lose` = `lose` + 1,`lose_t` = `lose_t` + 1 WHERE `id` = "' . $inf['id'] . '" LIMIT 1');
|
||||
|
||||
$lose .= '<b>' . $inf['login'] . '</b>, ';
|
||||
|
||||
} else {
|
||||
mysql_query('UPDATE `users` SET `nich` = `nich` + 1 WHERE `id` = "' . $inf['id'] . '" LIMIT 1');
|
||||
}
|
||||
@@ -172,7 +167,6 @@ class Tournir
|
||||
}
|
||||
|
||||
if ($addi == 1) {
|
||||
|
||||
$i = 0;
|
||||
while ($i <= 17) {
|
||||
if ($i == 10) {
|
||||
@@ -468,7 +462,6 @@ class Tournir
|
||||
}
|
||||
$i++;
|
||||
}
|
||||
|
||||
}
|
||||
$r .= '<div align="left" style="height:1px; width:100%; margin:10px 0 10px 0; border-top:1px solid #999999;"></div>';
|
||||
$r .= '<table style="border:1px solid #99cccc" width="700" bgcolor="#bbdddd" border="0" align="center" cellpadding="5" cellspacing="0">
|
||||
|
||||
+2896
-1591
File diff suppressed because it is too large
Load Diff
@@ -1,28 +1,116 @@
|
||||
<?php
|
||||
|
||||
use Core\Db;
|
||||
|
||||
class UserRegister
|
||||
{
|
||||
|
||||
public function __construct()
|
||||
public function hasMixedLatCur(string $txt): bool
|
||||
{
|
||||
if (!empty($_SERVER['HTTP_CLIENT_IP'])) {
|
||||
$ip = $_SERVER['HTTP_CLIENT_IP'];
|
||||
} elseif (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])) {
|
||||
$ip = $_SERVER['HTTP_X_FORWARDED_FOR'];
|
||||
} else {
|
||||
$ip = $_SERVER['REMOTE_ADDR'];
|
||||
}
|
||||
define('IP', $ip);
|
||||
if ($_SERVER['HTTP_REFERER'] == 'https://new-combats.com/' && $_COOKIE['acomb1'] != '2') {
|
||||
setcookie('acomb1', '1', time() + 60 * 60 * 24 * 3);
|
||||
}
|
||||
}
|
||||
|
||||
public function en_ru($txt)
|
||||
{
|
||||
$en = preg_match("/^(([0-9A-z _-])+)$/i", $txt);
|
||||
$en = preg_match("/^(([0-9A-z -])+)$/i", $txt);
|
||||
$ru = preg_match("/^(([0-9À-ÿ _-])+)$/i", $txt);
|
||||
return ($ru && $en) || (!$ru && !$en);
|
||||
}
|
||||
|
||||
public function hasGoodLogin(string $login): string
|
||||
{
|
||||
$isRestricted = in_array(
|
||||
$login,
|
||||
[
|
||||
'àíãåë', 'angel', 'àäìèíèñòðàöèÿ', 'administration', 'Êîììåíòàòîð',
|
||||
'Ìèðîçäàòåëü', 'Ìóñîðùèê', 'Ïàäàëüùèê', 'Ïîâåëèòåëü',
|
||||
'Àðõèâàðèóñ', 'Ïåðåñìåøíèê', 'Âîëûíùèê', 'Ëîðä Ðàçðóøèòåëü',
|
||||
'Ìèëîñåðäèå', 'Ñïðàâåäëèâîñòü', 'Èñêóøåíèå', 'Âîçíåñåíèå',
|
||||
]
|
||||
);
|
||||
$isRegistered = Db::getValue('select count(*) from users where login = ?', [$login]);
|
||||
//Áûâøèå â óïîòðåáëåíèè ëîãèíû. Äè÷ü, íî ëàäíî.
|
||||
$wasRegistered = Db::getValue('select count(*) from lastnames where login = ?', [$login]);
|
||||
|
||||
$login = str_replace(' ', ' ', $login);
|
||||
//Ëîãèí îò 4 äî 20 ñèìâîëîâ
|
||||
if (strlen($login) > 20) {
|
||||
$error = 'Ëîãèí äîëæåí ñîäåðæàòü íå áîëåå 20 ñèìâîëîâ.';
|
||||
}
|
||||
if (strlen($login) < 4) {
|
||||
$error = 'Ëîãèí äîëæåí ñîäåðæàòü íå ìåíåå 4 ñèìâîëîâ.';
|
||||
}
|
||||
if ($this->hasMixedLatCur($login)) {
|
||||
$error = 'Â ëîãèíå ðàçðåøåíî èñïîëüçîâàòü òîëüêî áóêâû îäíîãî àëôàâèòà ðóññêîãî èëè àíãëèéñêîãî. Íåëüçÿ ñìåøèâàòü.';
|
||||
}
|
||||
//Ðàçäåëèòåëè
|
||||
if (substr_count($login, ' ') + substr_count($login, '-') + substr_count($login, '_') > 2) {
|
||||
$error = 'Íå áîëåå äâóõ ðàçäåëèòåëåé îäíîâðåìåííî (ïðîáåë, òèðå, íèæíåå ïîä÷åðêèâàíèå).';
|
||||
}
|
||||
if (!empty($error)) {
|
||||
$error .= '<br> Ïðèìåð ïðàâèëüíîãî íèêíåéìà: Ïåòÿ Óáèâàòîð, Êîëÿ, xalop. <br> Ïðèìåð íåïðàâèëüíîãî íèêíåéìà: )))), kolÿ)=-/.';
|
||||
|
||||
}
|
||||
if ($isRegistered || $wasRegistered || $isRestricted) {
|
||||
$error = 'Ëîãèí ' . $login . ' óæå çàíÿò, âûáåðèòå äðóãîé.';
|
||||
}
|
||||
|
||||
return $error ?? '';
|
||||
}
|
||||
|
||||
public function hasGoodEmail(string $email): string
|
||||
{
|
||||
$isRegistered = Db::getValue('select count(*) from users where mail = ?', [$email]);
|
||||
$isBlocked = Db::getValue('select count(*) from ban_email where email = ?', [$email]);
|
||||
if (!filter_var($email, FILTER_VALIDATE_EMAIL) || $isRegistered) {
|
||||
$error = 'Íåïðàâèëüíûé email.';
|
||||
}
|
||||
if ($isBlocked) {
|
||||
$error = 'Àäðåñ çàáëîêèðîâàí.';
|
||||
}
|
||||
|
||||
$allowedDomains = Db::getColumn('select email from trust_email');
|
||||
$domain = explode('@', $email)[1];
|
||||
|
||||
if (!in_array($domain, $allowedDomains)) {
|
||||
$error = 'Äàííûé ïî÷òîâûé ñåðâèñ èñïîëüçîâàòü íåëüçÿ.';
|
||||
}
|
||||
|
||||
return $error ?? '';
|
||||
}
|
||||
|
||||
public function hasGoodEmailCode(string $email, int $code): string
|
||||
{
|
||||
$check = Db::getValue('select code from secure_code where email = ?', [$email]);
|
||||
if ($code !== $check) {
|
||||
return 'Íåâåðíûé ïðîâåðî÷íûé êîä.';
|
||||
}
|
||||
return '';
|
||||
}
|
||||
|
||||
public function hasGoodPassword(string $password1, string $password2): string
|
||||
{
|
||||
if ($password1 !== $password2) {
|
||||
$error = 'Ïàðîëè íå ñîâïàäàþò';
|
||||
}
|
||||
if (strlen($password1 < 8)) {
|
||||
$error = 'Ïàðîëü äîëæåí áûòü áîëüøå 8 ñèìâîëîâ';
|
||||
$error .= 'Ìîæåòå èñïîëüçîâàòü ñãåíåðèðîâàííûé ïàðîëü: ' . PassGen::new();
|
||||
}
|
||||
return $error ?? '';
|
||||
}
|
||||
|
||||
public static function new(string $login, string $password, string $email, $ref, $birthday, $sex): string
|
||||
{
|
||||
Db::sql(
|
||||
'insert into users (users.real,login,host_reg,pass,ip,ipreg,room,timereg,activ,mail,bithday,sex,fnq,design,molch2,level,hobby,clan_zv) values (1,?,?,?,?,?,9,unix_timestamp(),0,?,?,?,0,1,unix_timestamp() + 86400,8,\'\',0)',
|
||||
[
|
||||
$login,
|
||||
(int)$ref,
|
||||
md5($password),
|
||||
UserIp::get(),
|
||||
UserIp::get(),
|
||||
$email,
|
||||
date('d.m.Y', strtotime($birthday)),
|
||||
$sex - 10,
|
||||
]
|
||||
);
|
||||
|
||||
return Db::lastInsertId();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,25 +1,25 @@
|
||||
<?php
|
||||
|
||||
use Insallah\Db;
|
||||
use Core\Db;
|
||||
|
||||
class UserStats
|
||||
{
|
||||
/**
|
||||
* Ñîáèðàåò ñóììû âñåõ áîíóñîâ ñ îäåòûõ ïðåäìåòîâ è àêòèâíûõ ýôåêòîâ.
|
||||
* @param $userId
|
||||
* @param int $userId
|
||||
* @param bool $showAll
|
||||
* @return array
|
||||
*/
|
||||
public static function getAllBonuses($userId, $showAll = false)
|
||||
public static function getAllBonuses(int $userId, bool $showAll = false): array
|
||||
{
|
||||
require_once '_incl_data/class/Insallah/Core/Db.php';
|
||||
$db = new Db();
|
||||
|
||||
$q = 'select data from items_users where uid = ? and inOdet > 0 and `delete` = 0
|
||||
union all select data from eff_users where uid = ? and `delete` = 0';
|
||||
$iData = $db::getColumn($q, [$userId, $userId]);
|
||||
$iData = Db::getColumn($q, [$userId, $userId]);
|
||||
$params = [];
|
||||
foreach ($iData as $datum) {
|
||||
foreach (explode('|', $datum) as $inner) {
|
||||
list($a, $b) = explode('=', $inner);
|
||||
[$a, $b] = explode('=', $inner);
|
||||
if (strpos($a, 'add') !== false || strpos($a, 'sv') !== false || $showAll) {
|
||||
if (isset($params[$a])) {
|
||||
$params[$a] += $b;
|
||||
|
||||
@@ -11,10 +11,8 @@ $db = [
|
||||
];
|
||||
$dsn = 'mysql:host=' . $db['s'] . ';dbname=' . $db['d'];
|
||||
|
||||
include './_incl_data/mysql_override.php';
|
||||
include_once dirname(__DIR__) . DIRECTORY_SEPARATOR . 'mysql_override.php';
|
||||
|
||||
$dbgo = mysql_connect($db['s'], $db['u'], $db['p']);
|
||||
mysql_select_db($db['d'], $dbgo);
|
||||
mysql_query('SET NAMES cp1251');
|
||||
|
||||
$pdo = new PDO($dsn, $db['u'], $db['p'], [PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES cp1251"]);
|
||||
|
||||
@@ -60,7 +60,11 @@ if( isset($pr_used_this) && isset($pr_moment) ) {
|
||||
mysql_query('UPDATE `eff_users` SET `data` = "'.$pvr['redata'].'" WHERE `id` = "'.$btl->stats[$btl->uids[$u1]]['effects'][$prv['j_priem']]['id'].'" LIMIT 1');
|
||||
//
|
||||
$pvr['hp'] = floor($pvr['hp']);
|
||||
|
||||
/*$pvr['hp'] = $priem->magatack( $u2, $u1, $pvr['hp'], 'âîäŕ', 0 );
|
||||
$pvr['promah_type'] = $pvr['hp'][3];
|
||||
$pvr['promah'] = $pvr['hp'][2];
|
||||
$pvr['krit'] = $pvr['hp'][1];
|
||||
$pvr['hp'] = $pvr['hp'][0];*/
|
||||
$pvr['hpSee'] = '--';
|
||||
$pvr['hpNow'] = floor($btl->stats[$btl->uids[$u1]]['hpNow']);
|
||||
$pvr['hpAll'] = $btl->stats[$btl->uids[$u1]]['hpAll'];
|
||||
|
||||
@@ -108,5 +108,4 @@ if (
|
||||
$this->mintr($pl);
|
||||
}
|
||||
unset($pvr);
|
||||
?>
|
||||
?>
|
||||
@@ -2,8 +2,8 @@
|
||||
|
||||
/**
|
||||
* Ïðèåì: Öåëü {ñòèõèÿ}
|
||||
* @var $this Priems
|
||||
* @var $btl Battle
|
||||
* @var $this priems
|
||||
* @var $btl battleClass
|
||||
* @var $id
|
||||
* @var $pl
|
||||
*/
|
||||
|
||||
@@ -41,12 +41,32 @@ if( isset($pr_used_this) && isset($pr_moment) ) {
|
||||
$pvr['promah'] = $pvr['hp'][2];
|
||||
$pvr['krit'] = $pvr['hp'][1];
|
||||
$pvr['hp'] = $pvr['hp'][0];
|
||||
|
||||
/*//
|
||||
$pvr['data'] = $priem->lookStatsArray($btl->stats[$btl->uids[$u1]]['effects'][$prv['j_priem']]['data']);
|
||||
$pvr['di'] = 0;
|
||||
$pvr['dc'] = count($pvr['data']['atgm']);
|
||||
$pvr['rd'] = 0;
|
||||
$pvr['redata'] = '';
|
||||
while( $pvr['di'] < 4 ) {
|
||||
if( isset($pvr['data']['atgm'][($pvr['dc']-$pvr['di'])]) ) {
|
||||
if( $pvr['rd'] < 3 ) {
|
||||
$pvr['hp'] += $pvr['data']['atgm'][($pvr['dc']-$pvr['di'])];
|
||||
$pvr['redata'] = 'atgm='.$pvr['data']['atgm'][($pvr['dc']-$pvr['di'])].'|'.$pvr['redata'];
|
||||
$pvr['rd']++;
|
||||
}
|
||||
}
|
||||
$pvr['di']++;
|
||||
}*/
|
||||
//
|
||||
$btl->stats[$btl->uids[$u1]]['effects'][$prv['j_priem']]['data'] = $pvr['redata'];
|
||||
mysql_query('UPDATE `eff_users` SET `data` = "'.$pvr['redata'].'" WHERE `id` = "'.$btl->stats[$btl->uids[$u1]]['effects'][$prv['j_priem']]['id'].'" LIMIT 1');
|
||||
//
|
||||
$pvr['hp'] = floor($pvr['hp']);
|
||||
|
||||
/*$pvr['hp'] = $priem->magatack( $u2, $u1, $pvr['hp'], 'âîäà', 0 );
|
||||
$pvr['promah_type'] = $pvr['hp'][3];
|
||||
$pvr['promah'] = $pvr['hp'][2];
|
||||
$pvr['krit'] = $pvr['hp'][1];
|
||||
$pvr['hp'] = $pvr['hp'][0];*/
|
||||
$pvr['hpSee'] = '--';
|
||||
$pvr['hpNow'] = floor($btl->stats[$btl->uids[$u1]]['hpNow']);
|
||||
$pvr['hpAll'] = $btl->stats[$btl->uids[$u1]]['hpAll'];
|
||||
|
||||
@@ -57,7 +57,11 @@ if( isset($pr_used_this) && isset($pr_moment) ) {
|
||||
mysql_query('UPDATE `eff_users` SET `data` = "'.$pvr['redata'].'" WHERE `id` = "'.$btl->stats[$btl->uids[$u1]]['effects'][$prv['j_priem']]['id'].'" LIMIT 1');
|
||||
//
|
||||
$pvr['hp'] = floor($pvr['hp']);
|
||||
|
||||
/*$pvr['hp'] = $priem->magatack( $u2, $u1, $pvr['hp'], 'âîäŕ', 0 );
|
||||
$pvr['promah_type'] = $pvr['hp'][3];
|
||||
$pvr['promah'] = $pvr['hp'][2];
|
||||
$pvr['krit'] = $pvr['hp'][1];
|
||||
$pvr['hp'] = $pvr['hp'][0];*/
|
||||
$pvr['hpSee'] = '--';
|
||||
$pvr['hpNow'] = floor($btl->stats[$btl->uids[$u1]]['hpNow']);
|
||||
$pvr['hpAll'] = $btl->stats[$btl->uids[$u1]]['hpAll'];
|
||||
|
||||
@@ -59,7 +59,11 @@ if( isset($pr_used_this) && isset($pr_moment) ) {
|
||||
mysql_query('UPDATE `eff_users` SET `data` = "'.$pvr['redata'].'" WHERE `id` = "'.$btl->stats[$btl->uids[$u1]]['effects'][$prv['j_priem']]['id'].'" LIMIT 1');
|
||||
//
|
||||
$pvr['hp'] = floor($pvr['hp']);
|
||||
|
||||
/*$pvr['hp'] = $priem->magatack( $u2, $u1, $pvr['hp'], 'âîäŕ', 0 );
|
||||
$pvr['promah_type'] = $pvr['hp'][3];
|
||||
$pvr['promah'] = $pvr['hp'][2];
|
||||
$pvr['krit'] = $pvr['hp'][1];
|
||||
$pvr['hp'] = $pvr['hp'][0];*/
|
||||
$pvr['hpSee'] = '--';
|
||||
$pvr['hpNow'] = floor($btl->stats[$btl->uids[$u1]]['hpNow']);
|
||||
$pvr['hpAll'] = $btl->stats[$btl->uids[$u1]]['hpAll'];
|
||||
|
||||
@@ -56,6 +56,7 @@ if( isset($pr_used_this) && isset($pr_moment) && !isset($btl->info['id']) && !is
|
||||
mysql_query('UPDATE `eff_users` SET `data` = "'.$pvr['redata'].'" WHERE `id` = "'.$btl->stats[$btl->uids[$u1]]['effects'][$prv['j_priem']]['id'].'" LIMIT 1');
|
||||
//
|
||||
$pvr['hp'] = floor($pvr['hp']);
|
||||
//$pvr['hp'] = $priem->magatack( $u2, $u1, $pvr['hp'], 'âîäà', 0 );
|
||||
$pvr['promah_type'] = 0;
|
||||
$pvr['promah'] = false;
|
||||
$pvr['krit'] = false;
|
||||
|
||||
@@ -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]);
|
||||
}
|
||||
@@ -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');
|
||||
@@ -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);
|
||||
|
||||
@@ -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();
|
||||
@@ -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>",
|
||||
]
|
||||
);
|
||||
@@ -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> [$level]
|
||||
<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);
|
||||
}
|
||||
@@ -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']]);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -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
|
||||
@@ -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
|
||||
);
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -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']]);
|
||||
}
|
||||
@@ -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']]);
|
||||
}
|
||||
@@ -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');
|
||||
@@ -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'],
|
||||
]
|
||||
);
|
||||
}
|
||||
@@ -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');
|
||||
@@ -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-å ìåñòî â ðåéòèíãå!',
|
||||
]
|
||||
);
|
||||
@@ -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'
|
||||
]);
|
||||
@@ -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
@@ -57,6 +57,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
* @param $username
|
||||
* @param $password
|
||||
* @return mysqli|null
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_connect($server, $username, $password, $new_link = false, $client_flags = 0)
|
||||
{
|
||||
@@ -73,6 +74,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
* @param $username
|
||||
* @param $password
|
||||
* @return mysqli|null
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_pconnect($server, $username, $password, $new_link = false, $client_flags = 0)
|
||||
{
|
||||
@@ -85,6 +87,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
/**
|
||||
* @param $databaseName
|
||||
* @return bool
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_select_db($databaseName)
|
||||
{
|
||||
@@ -97,6 +100,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
* @param $query
|
||||
* @param mysqli $mysqli
|
||||
* @return bool|mysqli_result
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_query($query, mysqli $mysqli = null)
|
||||
{
|
||||
@@ -107,6 +111,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
* @param $string
|
||||
* @param mysqli $mysqli
|
||||
* @return string
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_real_escape_string($string, mysqli $mysqli = null)
|
||||
{
|
||||
@@ -116,6 +121,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
/**
|
||||
* @param mysqli_result $result
|
||||
* @return bool|array
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_fetch_assoc(mysqli_result $result)
|
||||
{
|
||||
@@ -144,6 +150,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
/**
|
||||
* @param mysqli_result $result
|
||||
* @return bool|int
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_num_rows(mysqli_result $result)
|
||||
{
|
||||
@@ -172,6 +179,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
/**
|
||||
* @param mysqli $mysqli
|
||||
* @return int
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_affected_rows(mysqli $mysqli = null)
|
||||
{
|
||||
@@ -189,6 +197,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
/**
|
||||
* @param mysqli $mysqli
|
||||
* @return bool
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_close(mysqli $mysqli = null)
|
||||
{
|
||||
@@ -207,6 +216,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
/**
|
||||
* @param mysqli $mysqli
|
||||
* @return int
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_errno(mysqli $mysqli = null)
|
||||
{
|
||||
@@ -229,6 +239,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
/**
|
||||
* @param mysqli $mysqli
|
||||
* @return string
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_error(mysqli $mysqli = null)
|
||||
{
|
||||
@@ -239,6 +250,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
* @param mysqli_result $result
|
||||
* @param $result_type
|
||||
* @return void
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_fetch_array(mysqli_result $result, $result_type = MYSQL_BOTH)
|
||||
{
|
||||
@@ -257,6 +269,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
/**
|
||||
* @param $query
|
||||
* @param mysqli $mysqli
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_unbuffered_query($query, mysqli $mysqli = null)
|
||||
{
|
||||
@@ -265,6 +278,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
|
||||
/**
|
||||
* @return string
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_get_client_info()
|
||||
{
|
||||
@@ -274,6 +288,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
/**
|
||||
* @param mysqli_result $result
|
||||
* @return void
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_free_result(mysqli_result $result)
|
||||
{
|
||||
@@ -379,6 +394,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
*
|
||||
* @param null $mysqli
|
||||
* @return bool|string
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_get_proto_info(mysqli $mysqli = null)
|
||||
{
|
||||
@@ -414,6 +430,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
*
|
||||
* @param null $mysqli
|
||||
* @return int|string
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_insert_id(mysqli $mysqli = null)
|
||||
{
|
||||
@@ -427,6 +444,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
* @param $row
|
||||
* @param int $field
|
||||
* @return mixed
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_result($result, $row, $field = 0)
|
||||
{
|
||||
@@ -444,6 +462,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
*
|
||||
* @param mysqli_result $result
|
||||
* @return int
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_num_fields(mysqli_result $result)
|
||||
{
|
||||
@@ -472,6 +491,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
* @param mysqli_result $result
|
||||
* @param int $field_offset
|
||||
* @return bool|object
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_fetch_field(mysqli_result $result, $field_offset = 0)
|
||||
{
|
||||
@@ -488,6 +508,7 @@ if (!extension_loaded('mysql') && !function_exists('mysql_connect')) {
|
||||
* @param mysqli_result $result
|
||||
* @param int $field_offset
|
||||
* @return bool
|
||||
* @deprecated
|
||||
*/
|
||||
function mysql_field_len(mysqli_result $result, $field_offset = 0)
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user