2022-06-06 21:30:34 +00:00
|
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
namespace Insallah;
|
2022-07-01 12:45:43 +00:00
|
|
|
|
|
2022-06-06 21:30:34 +00:00
|
|
|
|
class TournamentModel
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
/**
|
2022-07-01 12:45:43 +00:00
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>, <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>, <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>, <EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> 30 <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
2022-06-06 21:30:34 +00:00
|
|
|
|
*
|
|
|
|
|
* @param int $uid
|
|
|
|
|
*
|
|
|
|
|
* @return int
|
|
|
|
|
*/
|
|
|
|
|
public static function getUserLevel($uid)
|
|
|
|
|
{
|
2022-07-01 12:45:43 +00:00
|
|
|
|
$db = new Db();
|
2022-06-06 21:30:34 +00:00
|
|
|
|
$level = $db::getValue('select level from users where id = ? and level between 8 and 12 and battle = 0', [$uid]);
|
2022-07-01 12:45:43 +00:00
|
|
|
|
return $level ?: 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param int $uid
|
|
|
|
|
* @param int $level
|
|
|
|
|
*
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
|
|
|
|
public static function isEkrOverpriced($uid, $level = null)
|
|
|
|
|
{
|
|
|
|
|
$db = new Db();
|
|
|
|
|
if (is_null($level)) {
|
|
|
|
|
$level = $db::getValue('select level from users where id = ?', [$uid]);
|
2022-06-06 21:30:34 +00:00
|
|
|
|
}
|
2022-07-01 12:45:43 +00:00
|
|
|
|
$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($uid)
|
|
|
|
|
{
|
|
|
|
|
$db = new Db();
|
|
|
|
|
return $db::getValue('select exp from stats where id = ?', [$uid]) >= Tournament::MIN_EXP;
|
2022-06-06 21:30:34 +00:00
|
|
|
|
}
|
2022-07-01 12:45:43 +00:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param int $uid
|
|
|
|
|
*
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
|
|
|
|
public static function IsRestrictedToJoin($uid)
|
|
|
|
|
{
|
|
|
|
|
$db = new Db();
|
|
|
|
|
$delayEffect = $db::getValue('select count(*) from eff_users where uid = ? and id_eff = 486 and `delete` = 0', [$uid]);
|
|
|
|
|
return (bool)$delayEffect;
|
2022-06-06 21:30:34 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2022-07-01 12:45:43 +00:00
|
|
|
|
* @param $tid
|
|
|
|
|
*
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
|
|
|
|
public static function isStarted($tid)
|
|
|
|
|
{
|
|
|
|
|
$db = new Db();
|
|
|
|
|
$status = $db::getValue('select count(*) from tournaments where start_time = -1 and tid = ?', [$tid]);
|
|
|
|
|
return (bool)$status;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
2022-06-06 21:30:34 +00:00
|
|
|
|
*
|
|
|
|
|
* @param int $tid
|
|
|
|
|
*
|
|
|
|
|
* @return int
|
|
|
|
|
*/
|
|
|
|
|
public static function getWaitingMembersQuantity($tid)
|
|
|
|
|
{
|
|
|
|
|
$db = new Db();
|
|
|
|
|
return $db::getValue('select count(*) from tournaments_users where tid = ?', [$tid]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2022-07-01 12:45:43 +00:00
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
2022-06-06 21:30:34 +00:00
|
|
|
|
*
|
|
|
|
|
* @param int $tid
|
|
|
|
|
*
|
|
|
|
|
* @return void
|
|
|
|
|
*/
|
|
|
|
|
public static function createTournament($tid)
|
|
|
|
|
{
|
|
|
|
|
$db = new Db();
|
|
|
|
|
$db::sql('insert into tournaments (tid) values (?)', [$tid]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2022-07-01 12:45:43 +00:00
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
2022-06-06 21:30:34 +00:00
|
|
|
|
*
|
|
|
|
|
* @param int $uid
|
|
|
|
|
* @param int $tid
|
|
|
|
|
*
|
|
|
|
|
* @return void
|
|
|
|
|
*/
|
|
|
|
|
public static function joinTournament($uid, $tid)
|
|
|
|
|
{
|
2022-07-01 12:45:43 +00:00
|
|
|
|
/** <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> 25008 - 25012. */
|
2022-06-06 21:30:34 +00:00
|
|
|
|
$room_id = 25000 + $tid;
|
|
|
|
|
$db = new Db();
|
|
|
|
|
$db::sql('insert into tournaments_users (tid, uid) values (?, ?)', [$tid, $uid]);
|
|
|
|
|
self::teleport($uid, $room_id);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2022-07-01 12:45:43 +00:00
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
2022-06-06 21:30:34 +00:00
|
|
|
|
*
|
|
|
|
|
* @param int $tid
|
|
|
|
|
*
|
|
|
|
|
* @return void
|
|
|
|
|
*/
|
|
|
|
|
public static function startTournament($tid)
|
|
|
|
|
{
|
|
|
|
|
$db = new Db();
|
|
|
|
|
$db::sql('update tournaments set start_time = -1 where tid = ?', [$tid]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2022-07-01 12:45:43 +00:00
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
2022-06-06 21:30:34 +00:00
|
|
|
|
*
|
|
|
|
|
* @param int $tid
|
|
|
|
|
*
|
|
|
|
|
* @return void
|
|
|
|
|
*/
|
|
|
|
|
public static function destroyTournament($tid)
|
|
|
|
|
{
|
|
|
|
|
$db = new Db();
|
2022-07-01 12:45:43 +00:00
|
|
|
|
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD> <20> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> foreign_keys <20> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> tournaments_users !!!
|
2022-06-06 21:30:34 +00:00
|
|
|
|
$db::sql('delete from tournaments where tid = ?', [$tid]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2022-07-01 12:45:43 +00:00
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD> <EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD>. <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD> + 1 <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
2022-06-06 21:30:34 +00:00
|
|
|
|
*
|
|
|
|
|
* @param array $fighters_list
|
|
|
|
|
*
|
|
|
|
|
* @return array
|
|
|
|
|
*/
|
|
|
|
|
public static function getFightersTeams(array $fighters_list)
|
|
|
|
|
{
|
|
|
|
|
$db = new Db();
|
2022-07-01 12:45:43 +00:00
|
|
|
|
$query = sprintf("select id from users where battle = 0 and id in (%s)", implode(', ', $fighters_list));
|
|
|
|
|
return array_chunk($db::getColumn($query), 2);
|
2022-06-06 21:30:34 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2022-07-01 12:45:43 +00:00
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
2022-06-06 21:30:34 +00:00
|
|
|
|
*
|
|
|
|
|
* @param int $tid
|
|
|
|
|
*
|
|
|
|
|
* @return array
|
|
|
|
|
*/
|
|
|
|
|
public static function getFreeFighters($tid)
|
|
|
|
|
{
|
|
|
|
|
$db = new Db();
|
2022-07-01 12:45:43 +00:00
|
|
|
|
return $db::getColumn('select uid from tournaments_users where tid = ? and death_time = 0 order by uid', [$tid]);
|
2022-06-06 21:30:34 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2022-07-01 12:45:43 +00:00
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>. <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>, <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD> <EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
2022-06-06 21:30:34 +00:00
|
|
|
|
*
|
|
|
|
|
* @param int $tid
|
|
|
|
|
*
|
|
|
|
|
* @return array
|
|
|
|
|
*/
|
|
|
|
|
public static function getWinners($tid)
|
|
|
|
|
{
|
|
|
|
|
$db = new Db();
|
2022-07-01 12:45:43 +00:00
|
|
|
|
$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]
|
|
|
|
|
];
|
2022-06-06 21:30:34 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2022-07-01 12:45:43 +00:00
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
2022-06-06 21:30:34 +00:00
|
|
|
|
* @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
|
2022-07-01 12:45:43 +00:00
|
|
|
|
battle_users.team != last_battle.team_win and
|
|
|
|
|
battle_users.uid in (select uid from tournaments_users where death_time = 0)';
|
2022-06-06 21:30:34 +00:00
|
|
|
|
$db = new Db;
|
|
|
|
|
$row = $db::getRow($query);
|
|
|
|
|
return $row['uid'];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2022-07-01 12:45:43 +00:00
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
2022-06-06 21:30:34 +00:00
|
|
|
|
*
|
|
|
|
|
* @param int $uid
|
|
|
|
|
*
|
|
|
|
|
* @return void
|
|
|
|
|
*/
|
2022-07-01 12:45:43 +00:00
|
|
|
|
public static function removeFighter($uid, $winner = false)
|
2022-06-06 21:30:34 +00:00
|
|
|
|
{
|
2022-07-01 12:45:43 +00:00
|
|
|
|
if (!$uid) return;
|
|
|
|
|
$winner_timer_add = $winner? 500 : 0; # <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
2022-06-06 21:30:34 +00:00
|
|
|
|
$db = new Db();
|
2022-07-01 12:45:43 +00:00
|
|
|
|
$db::sql('update tournaments_users set death_time = unix_timestamp() + ? where death_time = 0 and uid = ?', [$winner_timer_add, $uid]);
|
2022-06-06 21:30:34 +00:00
|
|
|
|
self::teleport($uid, 9);
|
2022-07-01 12:45:43 +00:00
|
|
|
|
//fixme: <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20> <20><><EFBFBD><EFBFBD><EFBFBD>. <20><><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>. :(
|
|
|
|
|
Db::sql("update users_achiv set trn = trn + 1 where id = ?", [$uid]);
|
|
|
|
|
//(new Achievements(\user::start()))->updateCounter('trn');
|
2022-06-06 21:30:34 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2022-07-01 12:45:43 +00:00
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> id <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD> id <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
2022-06-06 21:30:34 +00:00
|
|
|
|
*
|
|
|
|
|
* @param int $uid
|
|
|
|
|
*
|
|
|
|
|
* @return mixed
|
|
|
|
|
*/
|
|
|
|
|
public static function getTournamentIdByUserId($uid)
|
|
|
|
|
{
|
|
|
|
|
$db = new Db();
|
|
|
|
|
return $db::getValue('select tid from tournaments_users where uid = ?', [$uid]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2022-07-01 12:45:43 +00:00
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
|
|
|
|
* 25000 - <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> id <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
|
|
|
|
* noinc - <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
* invis - <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD>
|
2022-06-06 21:30:34 +00:00
|
|
|
|
*
|
|
|
|
|
* @param int $uid1
|
|
|
|
|
* @param int $uid2
|
|
|
|
|
*
|
|
|
|
|
* @return void
|
|
|
|
|
*/
|
|
|
|
|
public static function startBattle($uid1, $uid2)
|
|
|
|
|
{
|
|
|
|
|
$db = new Db();
|
2022-07-01 12:45:43 +00:00
|
|
|
|
$check = Db::getValue('select count(*) from users where id in (?, ?) and battle = 0', [$uid1, $uid2]);
|
|
|
|
|
if ((int)$check !== 2) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2022-06-06 21:30:34 +00:00
|
|
|
|
$db::exec('insert into battle (city, time_start, timeout, type, invis, noinc, travmChance, typeBattle)
|
|
|
|
|
values (\'capitalcity\', unix_timestamp(), 60, 0, 1, 1, 0, 25000)');
|
2022-07-01 12:45:43 +00:00
|
|
|
|
$bid = $db::lastInsertId(); // <20><><EFBFBD><EFBFBD><EFBFBD>!
|
2022-06-06 21:30:34 +00:00
|
|
|
|
$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]);
|
2022-07-01 12:45:43 +00:00
|
|
|
|
$db::sql('update users set battle = ? where id in (?, ?)', [$bid, $uid1, $uid2]);
|
2022-06-06 21:30:34 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2022-07-01 12:45:43 +00:00
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD> id.
|
2022-06-06 21:30:34 +00:00
|
|
|
|
*
|
|
|
|
|
* @param int $uid
|
|
|
|
|
*
|
|
|
|
|
* @return mixed
|
|
|
|
|
*/
|
|
|
|
|
public static function uidToLogin($uid)
|
|
|
|
|
{
|
|
|
|
|
$db = new Db();
|
|
|
|
|
return $db::getValue('select login from users where id = ?', [$uid]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2022-07-01 12:45:43 +00:00
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
2022-06-06 21:30:34 +00:00
|
|
|
|
*
|
|
|
|
|
* @param int $uid
|
|
|
|
|
* @param int $room_id
|
|
|
|
|
*
|
|
|
|
|
* @return void
|
|
|
|
|
*/
|
|
|
|
|
private static function teleport($uid, $room_id)
|
|
|
|
|
{
|
|
|
|
|
$db = new Db();
|
|
|
|
|
$db::sql('update users set room = ? where id = ?', [$room_id, $uid]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2022-07-01 12:45:43 +00:00
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> $message <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
2022-06-06 21:30:34 +00:00
|
|
|
|
*
|
|
|
|
|
* @param string $message
|
|
|
|
|
*
|
|
|
|
|
* @return void
|
|
|
|
|
*/
|
2022-07-01 12:45:43 +00:00
|
|
|
|
public static function sysMessage($message)
|
2022-06-06 21:30:34 +00:00
|
|
|
|
{
|
2022-07-01 12:45:43 +00:00
|
|
|
|
if (!empty($message)) {
|
2022-06-06 21:30:34 +00:00
|
|
|
|
$db = new Db();
|
2022-07-01 12:45:43 +00:00
|
|
|
|
$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]);
|
|
|
|
|
}
|
2022-06-06 21:30:34 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2022-07-01 12:45:43 +00:00
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD> $quantity <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> $uid.
|
2022-06-06 21:30:34 +00:00
|
|
|
|
*
|
|
|
|
|
* @param int $uid
|
|
|
|
|
* @param int $quantity
|
|
|
|
|
*
|
|
|
|
|
* @return void
|
|
|
|
|
*/
|
|
|
|
|
public static function givePrizeItems($uid, $quantity)
|
|
|
|
|
{
|
|
|
|
|
$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);
|
|
|
|
|
}
|
|
|
|
|
}
|
2022-07-01 12:45:43 +00:00
|
|
|
|
|
|
|
|
|
/** <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>-<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
|
|
|
|
* @param $uid
|
|
|
|
|
* @param $unix_time
|
|
|
|
|
*
|
|
|
|
|
* @return void
|
|
|
|
|
*/
|
|
|
|
|
public static function giveDelay($uid, $unix_time)
|
|
|
|
|
{
|
|
|
|
|
$db = new Db();
|
|
|
|
|
$query = 'insert into eff_users (id_eff, uid, name, timeUse) VALUES (?,?,?,?)';
|
|
|
|
|
$args = [486, $uid, '<27><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>!', $unix_time];
|
|
|
|
|
$db::sql($query, $args);
|
|
|
|
|
}
|
2022-06-06 21:30:34 +00:00
|
|
|
|
}
|