diff --git a/_incl_data/class/Battle.php b/_incl_data/class/Battle.php
index 795bbda3..2fff39da 100644
--- a/_incl_data/class/Battle.php
+++ b/_incl_data/class/Battle.php
@@ -4527,42 +4527,76 @@ JS;
return '{' . $a . 'x' . $id . 'x' . $rnd . '}';
}
- //Действия бота (атака)
- public function spaCheck($u1): void
+ /**
+ * Свиток спасения.
+ *
+ * Воскрешение мёртвого игрока (hpnow = 0) чтобы он мог продолжать бой.
+ * @param int $u1 id игрока
+ * @return void
+ */
+ public function spaCheck(int $u1): void
{
global $u;
if ($this->stats[$this->uids[$u1]]['hpNow'] >= 1) {
return;
}
- mysql_query('DELETE FROM `battle_act` WHERE `uid1` = "' . $u1 . '" OR `uid2` = "' . $u1 . '"');
+ Db::sql('delete from battle_act where uid1 = ? or uid2 = ?', [$u1, $u1]);
+
if ($this->stats[$this->uids[$u1]]['spasenie'] > 0 && $this->users[$this->uids[$u1]]['tactic7'] >= 25) {
//Свиток спасения
if ($this->stats[$this->uids[$u1]]['s7'] > 49 && $this->stats[$this->uids[$u1]]['s7'] < 75) {
//Даем призрачку
- mysql_query(
- "INSERT INTO `eff_users`
- (`id_eff`, `uid`, `name`, `data`, `overType`, `timeUse`, `timeAce`, `user_use`, `delete`, `v1`, `v2`, `img2`, `x`, `hod`, `bj`, `sleeptime`, `no_Ace`, `file_finish`, `tr_life_user`, `deactiveTime`, `deactiveLast`, `mark`, `bs`) VALUES
- (22, '" . $u1 . "', 'Призрачная защита', 'add_zmproc=75|add_zaproc=75', 0, 77, 0, '" . $u1 . "', 0, 'priem', 141, 'spirit_block25.gif', 1, 1, '0', 0, 0, '', 0, 0, 0, 0, 0);"
+ Effects::addCustom(
+ [
+ 'id_eff' => 22,
+ 'uid' => $u1,
+ 'name' => 'Призрачная защита',
+ 'data' => 'add_zmproc=75|add_zaproc=75',
+ 'timeUse' => 77,
+ 'user_use' => $u1,
+ 'v1' => 'priem',
+ 'v2' => 141,
+ 'img2' => 'spirit_block25.gif',
+ 'hod' => 1,
+ ]
);
$this->stats[$this->uids[$u1]]['hpNow'] = floor($this->stats[$this->uids[$u1]]['hpAll'] * 0.5);
$this->stats[$this->uids[$u1]]['mpNow'] = floor($this->stats[$this->uids[$u1]]['mpAll'] * 0.5);
} elseif ($this->stats[$this->uids[$u1]]['s7'] > 74 && $this->stats[$this->uids[$u1]]['s7'] < 100) {
//Абсолютная защита
- mysql_query(
- "INSERT INTO `eff_users`
- (`id_eff`, `uid`, `name`, `data`, `overType`, `timeUse`, `timeAce`, `user_use`, `delete`, `v1`, `v2`, `img2`, `x`, `hod`, `bj`, `sleeptime`, `no_Ace`, `file_finish`, `tr_life_user`, `deactiveTime`, `deactiveLast`, `mark`, `bs`) VALUES
- (22, '" . $u1 . "', 'Абсолютная защита', 'add_zmproc=100|add_zaproc=100', 0, 77, 0, '" . $u1 . "', 0, 'priem', 358, 'block_absolute.gif', 1, 1, '0', 0, 0, '', 0, 0, 0, 0, 0);"
+ Effects::addCustom(
+ [
+ 'id_eff' => 22,
+ 'uid' => $u1,
+ 'name' => 'Абсолютная защита',
+ 'data' => 'add_zmproc=100|add_zaproc=100',
+ 'timeUse' => 77,
+ 'user_use' => $u1,
+ 'v1' => 'priem',
+ 'v2' => 358,
+ 'img2' => 'block_absolute.gif',
+ 'hod' => 1,
+ ]
);
$this->stats[$this->uids[$u1]]['hpNow'] = floor($this->stats[$this->uids[$u1]]['hpAll'] * 0.75);
$this->stats[$this->uids[$u1]]['mpNow'] = floor($this->stats[$this->uids[$u1]]['mpAll'] * 0.75);
} elseif ($this->stats[$this->uids[$u1]]['s7'] > 99) {
//Абсолютная защита x2
- mysql_query(
- "INSERT INTO `eff_users`
- (`id_eff`, `uid`, `name`, `data`, `overType`, `timeUse`, `timeAce`, `user_use`, `delete`, `v1`, `v2`, `img2`, `x`, `hod`, `bj`, `sleeptime`, `no_Ace`, `file_finish`, `tr_life_user`, `deactiveTime`, `deactiveLast`, `mark`, `bs`) VALUES
- (22, '" . $u1 . "', 'Защита Мироздателя', 'add_zmproc=100|add_zaproc=100', 0, 77, 0, '" . $u1 . "', 0, 'priem', 358, 'wis_white_shield.gif', 1, 2, '0', 0, 0, '', 0, 0, 0, 0, 0);"
+ Effects::addCustom(
+ [
+ 'id_eff' => 22,
+ 'uid' => $u1,
+ 'name' => 'Божественная защита',
+ 'data' => 'add_zmproc=100|add_zaproc=100',
+ 'timeUse' => 77,
+ 'user_use' => $u1,
+ 'v1' => 'priem',
+ 'v2' => 358,
+ 'img2' => 'wis_white_shield.gif',
+ 'hod' => 2,
+ ]
);
$this->stats[$this->uids[$u1]]['hpNow'] = floor($this->stats[$this->uids[$u1]]['hpAll']);
$this->stats[$this->uids[$u1]]['mpNow'] = floor($this->stats[$this->uids[$u1]]['mpAll']);
@@ -4581,38 +4615,31 @@ JS;
$this->stats[$this->uids[$u1]]['mpNow'] = floor($this->stats[$this->uids[$u1]]['mpAll']);
}
- mysql_query(
- 'DELETE FROM `eff_users` WHERE `uid` = "' . $u1 . '" AND `id_eff` = 22 AND `v1` = "priem" AND `v2` = 324'
- );
- mysql_query(
- 'UPDATE `stats` SET `hpNow` = "' . $this->stats[$this->uids[$u1]]['hpNow'] . '",`mpNow` = "' . $this->stats[$this->uids[$u1]]['mpNow'] . '", `tactic7` = `tactic7` - 25 WHERE `id` = "' . $u1 . '" LIMIT 1'
- );
- $mas['text'] = '{tm1} ' . $this->stats[$this->uids[$u1]]['login'] . ' убит...' . $this->stats[$this->uids[$u1]]['login'] . ' был спасен. ';
+ Db::sql("delete from eff_users where uid = ? and id_eff = 22 and v1 = 'priem' and v2 = 324", [$u1]);
+ Db::sql('update stats set hpnow = ?, mpnow = ?, tactic7 = tactic7 - 25 where id = ?', [$this->stats[$this->uids[$u1]]['hpNow'], $this->stats[$this->uids[$u1]]['mpNow'], $u1]);
$this->priemAddLog(
- $id, 1, 2, $u->info['id'], $u1,
+ 22, 1, 2, $u->info['id'], $u1,
' ',
- $mas['text'],
+ '{tm1} ' . $this->stats[$this->uids[$u1]]['login'] . ' убит...' . $this->stats[$this->uids[$u1]]['login'] . ' был спасен. ',
$this->hodID
);
} elseif (isset($this->stats[$this->uids[$u1]]['login'])) {
- mysql_query('UPDATE `stats` SET `hpNow` = "0",`mpNow` = "0" WHERE `id` = "' . $u1 . '" LIMIT 1');
+ Db::sql('update stats set hpnow = 0, mpnow = 0 where id = ?', [$u1]);
$this->stats[$this->uids[$u1]]['hpNow'] = 0;
$this->users[$this->uids[$u1]]['hpNow'] = 0;
- $mas['text'] = '{tm1} ' . $this->stats[$this->uids[$u1]]['login'] . ' погиб.';
$this->priemAddLog(
- $id, 1, 2, $u->info['id'], $u1,
+ 22, 1, 2, $u->info['id'], $u1,
' ',
- $mas['text'],
- ($this->hodID + 1)
- //Удаляем размен из базы //ТУТ возможен лаг удаления
+ '{tm1} ' . $this->stats[$this->uids[$u1]]['login'] . ' погиб.',
+ $this->hodID + 1
);
- mysql_query(
- 'DELETE FROM `battle_act` WHERE `uid1` = "' . $this->stats[$this->uids[$u1]]['id'] . '" OR `uid2` = "' . $this->stats[$this->uids[$u1]]['id'] . '" OR `uid2` = "-' . $this->stats[$this->uids[$u1]]['id'] . '"'
- );
- mysql_query(
- 'DELETE FROM `eff_users` WHERE `uid` = "' . $this->stats[$this->uids[$u1]]['id'] . '" AND `v1` = "priem" AND `delete` =0'
+
+ Db::sql(
+ 'delete from battle_act where uid1 = ? or uid2 = ? or uid2 = ?',
+ [$this->stats[$this->uids[$u1]]['id'], $this->stats[$this->uids[$u1]]['id'], -$this->stats[$this->uids[$u1]]['id']]
);
+ Effects::removePriems($this->stats[$this->uids[$u1]]['id']);
}
}