2018-01-28 16:40:49 +00:00
< ? php
2021-08-26 14:44:14 +00:00
use Battles\GameLogs ;
use Battles\Nick ;
2018-01-28 16:40:49 +00:00
$us = mysql_fetch_array ( mysql_query ( " SELECT *,(select `id` from `online` WHERE `real_time` >= " . ( time () - 60 ) . " AND `id` = users.`id`) as `online` FROM `users` WHERE `login` = ' { $_POST [ 'target' ] } ' LIMIT 1; " ));
$owntravma = mysql_fetch_array ( mysql_query ( " SELECT * FROM `effects` WHERE `owner` = " . $us [ 'id' ] . " AND (type=13 OR ND type=12 OR type=14); " ));
$magic = mysql_fetch_array ( mysql_query ( " SELECT `chanse` FROM `magic` WHERE `id` = '23' ; " ));
$raid_t = mysql_fetch_array ( mysql_query ( " SELECT * FROM variables WHERE var='raid_on_status' limit 1; " ));
$hm = mysql_fetch_array ( mysql_query ( " SELECT `value` FROM `variables` WHERE `var` = 'haos_match' LIMIT 1; " ));
$hm = unserialize ( $hm [ 'value' ]);
$us_b = mysql_fetch_array ( mysql_query ( " SELECT `type`,`open` FROM `battle` WHERE `id`=' { $us [ 'battle' ] } '; " ));
$effect = mysql_fetch_array ( mysql_query ( " SELECT `id` FROM `effects` WHERE `owner` = ' { $us [ 'id' ] } ' AND `time` > ' " . time () . " ' AND `type` = '227' LIMIT 1 " ));
if ( $user [ 'intel' ] >= 4 ) {
$int = $magic [ 'chanse' ] + ( $user [ 'intel' ] - 4 ) * 3 ;
if ( $int > 98 ){ $int = 99 ;}
}
else { $int = 0 ;}
if ( $user [ 'battle' ] > 0 ) {
echo " Н е в бою..." ;
} elseif ( $us_b [ 'type' ] == 3 || $us_b [ 'type' ] == 5 ) {
echo " Запрещено входить в хаотический бой! " ;
} elseif ( $us [ 'battle' ] > 0 && $us_b [ 'open' ] == 0 ) {
echo " Бой закрыт для вмешательства! " ;
} elseif ( ! $us [ 'online' ]) {
echo " Персонаж не в игре! " ;
2021-03-10 21:03:59 +00:00
} elseif ( in_array ( $us [ 'room' ], UNKILABLE [ 'rooms' ])) {
2018-01-28 16:40:49 +00:00
echo " В данной комнате запрещены нападения ..." ;
2021-03-10 21:03:59 +00:00
} elseif ( in_array ( $us [ 'id' ], UNKILABLE [ 'users' ])) {
2018-01-28 16:40:49 +00:00
echo " Персонаж под защитой от нападений ... " ;
} elseif ( isset ( $effect [ 'id' ])) {
echo " Персонаж под защитой от нападений ... " ;
} elseif ( $owntravma [ 'id' ] && ! $us [ 'battle' ]) {
echo " Персонаж тяжело травмирован... " ;
} elseif ( $user [ 'klan' ] != '' && ( $user [ 'klan' ] == $us [ 'klan' ])) {
echo " Чтите честь ваших сокланов. " ;
2021-02-01 19:20:23 +00:00
} elseif ( $user -> getRoom () != $us [ 'room' ]) {
2018-01-28 16:40:49 +00:00
echo " Персонаж в другой комнате! " ;
} elseif ( $us [ 'room' ] == 31 || $us [ 'room' ] == 46 || $us [ 'room' ] == 47 || $us [ 'room' ] == 48 || $us [ 'room' ] == 49 || $us [ 'room' ] == 600 || $us [ 'room' ] == 601 || $us [ 'room' ] == 45 || $us [ 'room' ] == 603 || $us [ 'room' ] == 602 || $us [ 'room' ] == 43 || $us [ 'room' ] == 45 ) {
echo " Нападения в этой локации запрещены! " ;
} elseif ( $us [ 'level' ] < 1 ) {
echo " Новички находятся под защитой Мироздателя! " ;
} elseif ( $us [ 'hp' ] < $us [ 'maxhp' ] * 0.33 && ! $us [ 'battle' ]) {
echo " Жертва слишком слаба! " ;
} elseif ( $user [ 'hp' ] < $user [ 'maxhp' ] * 0.33 ) {
echo " Вы слишком ослаблены для нападения! " ;
} elseif ( $us [ 'hp' ] < 1 && $us [ 'battle' ]) {
echo " Вы не можете напасть на погибшего! " ;
} elseif ((( $us [ 'room' ] == 101 ) && ( $us [ 'battle' ] > 0 )) && (((( $user [ 'align' ] == 3 ) || ( $user [ 'align' ] == 2.2 )) && ( $us [ 'align' ] != 6 && $us [ 'align' ] != 2.1 )) || ((( $user [ 'align' ] == 6 ) || ( $user [ 'align' ] == 2.1 )) && ( $us [ 'align' ] != 3 && $us [ 'align' ] != 2.2 )))) {
echo " Н е атакуйте своих союзников!" ;
} elseif ( rand ( 1 , 100 ) < $int ) {
if ( $user [ 'sex' ] == 1 ) { $action = " напал " ;} else { $action = " напала " ;}
if ( $user [ 'align' ] > '2' && $user [ 'align' ] < '3' ) {
$angel = " Ангел " ;
} elseif ( $user [ 'align' ] > '1' && $user [ 'align' ] < '2' ) {
$angel = " Персонаж " ;
}
$jert = mysql_fetch_array ( mysql_query ( " SELECT * FROM `users` WHERE `login` = ' { $_POST [ 'target' ] } ' LIMIT 1; " ));
if ( $jert [ 'id' ] != $user [ 'id' ]) {
addch ( " <img src=i/magic/attack.gif> <B> { $user [ 'login' ] } </B>, применив магию нападения, внезапно " . $action . " на " { $_POST [ 'target' ] } " " );
2020-08-27 12:17:02 +00:00
addchp ( '<font color=red>Внимание!</font> Н а вас ' . $action . ' <B>' . $user [ 'login' ] . '</B>.<BR>\'; top.frames[\'main\'].location=\'fbattle.php\'; var z = \' ' , '{[]}' . Nick :: id ( $jert [ 'id' ]) -> short () . '{[]}' );
2018-01-28 16:40:49 +00:00
//destructitem($row['id']);
$bet = 1 ;
//а р х
if ( $jert [ 'id' ] > _BOTSEPARATOR_ ) {
$arha = mysql_fetch_array ( mysql_query ( 'SELECT * FROM `bots` WHERE `prototype` = ' . $jert [ 'id' ] . ' LIMIT 1;' ));
$jert [ 'battle' ] = $arha [ 'battle' ];
$jert [ 'id' ] = $arha [ 'id' ];
$bot = 1 ;
}
if ( $jert [ 'battle' ] > 0 ) {
//вмешиваемся
$bd = mysql_fetch_array ( mysql_query ( 'SELECT * FROM `battle` WHERE `id` = ' . $jert [ 'battle' ] . ' LIMIT 1;' ));
$battle = unserialize ( $bd [ 'teams' ]);
$ak = array_keys ( $battle [ $jert [ 'id' ]]);
$battle [ $user [ 'id' ]] = $battle [ $ak [ 0 ]];
foreach ( $battle [ $user [ 'id' ]] as $k => $v ) {
$battle [ $user [ 'id' ]][ $k ] = array ( 0 , 0 , time ());
$battle [ $k ][ $user [ 'id' ]] = array ( 0 , 0 , time ());
}
$t1 = explode ( " ; " , $bd [ 't1' ]);
// проставляем кто-где
if ( in_array ( $jert [ 'id' ], $t1 )) {
$ttt = 2 ;
} else {
$ttt = 1 ;
}
2021-02-01 19:20:23 +00:00
addch ( " <b> " . Nick :: id ( $user [ 'id' ]) -> short () . " </b> вмешался в <a href=logs.php?log= " . $id . " target=_blank>поединок »»</a>. " , $user -> getRoom ());
2018-01-28 16:40:49 +00:00
2018-11-05 20:15:13 +00:00
//mysql_query('UPDATE `logs` SET `log` = CONCAT(`log`,\'<span class=date>'.date("H:i").'</span> '.nick::id($user['id'])->short().' вмешался в поединок!<BR>\') WHERE `id` = '.$jert['battle'].'');
2018-01-28 16:40:49 +00:00
2021-08-26 14:44:14 +00:00
GameLogs :: addBattleLog ( $jert [ 'battle' ], '<span class=date>' . date ( " H:i " ) . '</span> ' . Nick :: id ( $user [ 'id' ]) -> short () . ' вмешался в поединок!<BR>' );
2018-01-28 16:40:49 +00:00
mysql_query ( 'UPDATE `battle` SET `teams` = \'' . serialize ( $battle ) . '\', `t' . $ttt . '`=CONCAT(`t' . $ttt . '`,\';' . $user [ 'id' ] . '\') WHERE `id` = ' . $jert [ 'battle' ] . ' ;' );
mysql_query ( " UPDATE users SET `battle` = " . $jert [ 'battle' ] . " ,`zayavka`=0 WHERE `id`= " . $user [ 'id' ]);
header ( " Location:fbattle.php " );
2020-09-30 12:01:33 +00:00
//exit("<script>location.href='fbattle.php';</script>");
2018-01-28 16:40:49 +00:00
}
else
{
// начинаем бой
//$bet=1;
// если чел в заявке, выбиваем е г о
if ( $jert [ 'zayavka' ]) {
$fict1 = mysql_fetch_array ( mysql_query ( " SELECT * FROM `zayavka` WHERE `team1` LIKE ' { $jert [ 'id' ] } ;%' OR `team1` LIKE '%; { $jert [ 'id' ] } ;%' LIMIT 1; " ));
$fict2 = mysql_fetch_array ( mysql_query ( " SELECT * FROM `zayavka` WHERE `team2` LIKE ' { $jert [ 'id' ] } ;%' OR `team2` LIKE '%; { $jert [ 'id' ] } ;%' LIMIT 1; " ));
if ( $fict1 ) { $team = 1 ; }
elseif ( $fict2 ) { $team = 2 ; }
mysql_query ( " UPDATE `users` SET `zayavka` = '' WHERE `id` = { $jert [ 'id' ] } LIMIT 1; " );
$z = mysql_fetch_array ( mysql_query ( " SELECT `team { $team } ` FROM `zayavka` WHERE `id`= " . $jert [ 'zayavka' ] . " ; " ));
$teams = str_replace ( $jert [ 'id' ] . " ; " , " " , $z [ 0 ]);
mysql_query ( " UPDATE `zayavka` SET team { $team } = ' { $teams } ' WHERE id = { $jert [ 'zayavka' ] } ; " );
}
//arch
if ( $bot ) {
mysql_query ( " INSERT INTO `bots` (`name`,`prototype`,`battle`,`hp`) values ('Архивариус','83','',' " . $jert [ 'hp' ] . " '); " );
$jert [ 'id' ] = mysql_insert_id ();
}
$teams = array ();
$teams [ $user [ 'id' ]][ $jert [ 'id' ]] = array ( 0 , 0 , time ());
$teams [ $jert [ 'id' ]][ $user [ 'id' ]] = array ( 0 , 0 , time ());
$sv = array ( 3 , 4 , 5 );
//$tou = array_rand($sv,1);
mysql_query ( " INSERT INTO `battle`
(
`id` , `coment` , `teams` , `timeout` , `type` , `status` , `t1` , `t2` , `to1` , `to2` , `blood`
)
VALUES
(
NULL , '' , '".serialize($teams)."' , '".$sv[rand(0,2)]."' , '1' , '0' , '".$user[' id ']."' , '".$jert[' id ']."' , '".time()."' , '".time()."' , '0'
) " );
$id = mysql_insert_id ();
// апдейтим врага
if ( $bot ) {
mysql_query ( " UPDATE `bots` SET `battle` = { $id } WHERE `id` = { $jert [ 'id' ] } LIMIT 1; " );
} else {
mysql_query ( " UPDATE `users` SET `battle` = { $id } WHERE `id` = { $jert [ 'id' ] } LIMIT 1; " );
}
// создаем лог
2020-08-27 12:17:02 +00:00
$rr = " <b> " . Nick :: id ( $user [ 'id' ]) -> full ( 1 ) . " </b> и <b> " . Nick :: id ( $jert [ 'id' ]) -> full ( 1 ) . " </b> " ;
2021-02-01 19:20:23 +00:00
addch ( " <a href=logs.php?log= " . $id . " target=_blank>Бой</a> между <B><b> " . Nick :: id ( $user [ 'id' ]) -> short () . " </b> и <b> " . Nick :: id ( $jert [ 'id' ]) -> short () . " </b> начался. " , $user -> getRoom ());
2018-01-28 16:40:49 +00:00
//mysql_query("INSERT INTO `logs` (`id`,`log`) VALUES('{$id}',"Часы показывали <span class=date>".date("Y.m.d H.i")."</span>, когда ".$rr." бросили вызов друг другу. <BR>");
2021-08-26 14:44:14 +00:00
GameLogs :: addBattleLog ( $id , " Часы показывали <span class=date> " . date ( " Y.m.d H.i " ) . " </span>, когда " . $rr . " бросили вызов друг другу. <BR> " );
2018-01-28 16:40:49 +00:00
mysql_query ( " UPDATE users SET `battle` = { $id } ,`zayavka`=0 WHERE `id`= { $user [ 'id' ] } OR `id` = { $jert [ 'id' ] } " );
header ( " Location:fbattle.php " );
2020-09-30 12:01:33 +00:00
//exit("<script>location.href='fbattle.php';</script>");
2018-01-28 16:40:49 +00:00
}
} else {
echo '<font color=red>Мазохист?...</font>' ;
}
//$bet=1;
} else {
echo " Свиток рассыпался в ваших руках... " ;
$bet = 1 ;
}