function can_u_reach($who, $loc_go, $stor, $depth = 1) { // lokacija $id = is_player($who); if ($id) { $lq = do_mysql("SELECT location FROM players WHERE id_player = '" . $id . "';"); $loc = mysql_result($lq, 0); } else { include_once 'modules/f_get_npc_info.php'; $loc = get_npc_info($who, 'location'); } require_once 'modules/f_get_loc.php'; $near = get_loc($who, $stor, $depth); if (!$near || $near != $loc_go) { return 0; } return 1; }
function go_to_loc($who, $loc_go, $stor, $ok = 0) { # get_pl_info(), do_mysql();, get_npc_info();, loc();, put_error();, delete_from_loc();, add_to_loc();, addjournal(); require_once 'modules/f_get_pl_info.php'; require_once 'modules/f_get_npc_info.php'; require_once 'modules/f_loc.php'; require_once 'modules/f_add_to_loc.php'; // proverka dannyh // $who = preg_replace ('/[^a-z\._0-9]/i', '', $who); if (!$ok) { $loc_go = preg_replace('/[^a-z0-9\\|]/', '', $loc_go); $stor = preg_replace('/[^a-z0-9]/i', '', $stor); } // $stor - eto storona. dlja massiva // lokacija if (substr($who, 0, 2) == 'p.') { // login $login = substr($who, 2); $who = $login; $id = is_player($login); $lq = do_mysql("SELECT location FROM players WHERE id_player = '" . $id . "';"); $loc = mysql_result($lq, 0); $lq = do_mysql("SELECT name FROM players WHERE id_player = '" . $id . "';"); $name = mysql_result($lq, 0); //$loc = get_pl_info ($login, 'location'); $qg = do_mysql("SELECT gender FROM players WHERE id_player = '" . $id . "';"); $gender = mysql_result($qg, 0); $qg = do_mysql("SELECT walking FROM players WHERE id_player = '" . $id . "';"); $w = mysql_result($qg, 0); if ($w > 0) { $CAN_JUMP = 1; } $qg = do_mysql("SELECT carry FROM players WHERE id_player = '" . $id . "';"); $carry = mysql_result($qg, 0); include_once 'modules/f_get_pl_weight.php'; if ($carry < get_pl_weight($login)) { put_g_error('вы перегруженны'); } $n = 0; $who = $login; // proverka na boj - $q = do_mysql("SELECT in_battle FROM players WHERE id_player = '" . $id . "';"); $inb = mysql_result($q, 0); $type = 'a'; } if (substr($who, 0, 2) == 'n.') { $loc = get_npc_info($who, 'location'); $id = is_npc($who); // adding npc to move log - global $NPC_MOVED; $NPC_MOVED[$id] = 1; $alo = do_mysql("SELECT name FROM npc WHERE id_npc = '" . $id . "';"); $login = mysql_result($alo, 0); $name = $login; $alo = do_mysql("SELECT type FROM npc WHERE id_npc = '" . $id . "';"); $type = mysql_result($alo, 0); $n = 1; $inb = 0; } # vozmozhny dva puti - na druguju kartu ili prosto na druguju lokaciju # na druguju kartu ne storony, potomu prosto stor = 'nmap'; # na druguju lokaciju - togda cherez near // ESLI NA DRUGUJU KARU $show_info = 0; if (substr($loc, 0, 4) != substr($loc_go, 0, 4)) { global $NEWMAP; $NEWMAP = 1; // a eshe ustanovim flag show_info, po kotoromu potom opredelim, nado li pokazatq vstupitelqnyj tekst k loakacci $show_info = 1; // zlye npc nemogut idti v goroda if ($type == 'x') { $toloc = substr($loc_go, 0, 4); if ($toloc == 'rele' || $toloc == 'elfc' || $toloc == 'verg') { return 0; } } } $li = ''; // voobshem eto tazhe lokacija include_once 'modules/f_can_u_reach.php'; $depth = 1; if (isset($_GET['jump']) && isset($CAN_JUMP)) { $depth = 2; } // esli v okruzhnoj lokacii netu takoj loki v takuju storonu, to idti nelzja if (!can_u_reach($who, $loc_go, $stor, $depth)) { //put_error ('<p>извините, но в указаном направлении такой локации нет</p>'); return 0; } if ($depth == 2) { // get loc v can u reach $ll = get_loc($who, $stor, 1); add_journal($name . ' пронесся мимо!', 'l.' . $ll); } // est9q li loka na kotoruju idut? ////////////////////////////// // pitomec $an = do_mysql("SELECT name, fullname FROM npc WHERE belongs = '" . $who . "' AND location = '" . $loc . "' AND move <> 0;"); $an = mysql_fetch_assoc($an); if ($an['fullname']) { $pit = ' и ' . $an['name'] . ' '; add_to_loc($loc_go, $an['fullname']); } else { $pit = ''; } if (substr($who, 0, 2) == 'n.') { $map = substr($loc_go, 0, 4); do_mysql("UPDATE npc SET location = '" . $loc_go . "', map = '" . $map . "' WHERE id_npc = '" . $id . "';"); } else { do_mysql("UPDATE players SET location = '" . $loc_go . "' WHERE id_player = '" . $id . "';"); } $loc2 = 'l.' . $loc; // pogonja if ($inb && substr($loc_go, 0, 4) != 'rele' && substr($loc_go, 0, 4) != 'elfc' && substr($loc_go, 0, 4) != 'verg') { $tinb = 0; if ($inb == 1) { $tinb = 2; } else { $tinb = 1; } $q = do_mysql("SELECT fullname FROM npc WHERE location = '" . $loc . "' AND in_battle = '" . $tinb . "';"); while ($nt = mysql_fetch_assoc($q)) { go_to_loc($nt['fullname'], $loc_go, $stor, 1); } } // formiruem soobshenie. $pere = ''; if (isset($near)) { $pere = $near[$stor][2]; } if ($li) { $pere = $li[2]; } if ($pit) { $gone = 'ушли'; $come = 'пришли'; } else { if (!isset($gender)) { // dlja npc, esliimja konchaetsja na 'a', to skorej vsego devushka $len = strlen($login); $len2 = $len - 1; if (substr($login, $len2) == 'а') { $gone = 'ушла'; $come = 'пришла'; } else { $gone = 'ушел'; $come = 'пришел'; } } else { if ($gender == 'male') { $gone = 'ушел'; $come = 'пришел'; } if ($gender == 'female') { $gone = 'ушла'; $come = 'пришла'; } } } // proverim $n, esli 1 to eto npc i nado vsem pisatq, esli net to perehodjashemu ne nado if ($n) { $need = 1; } else { $need = 0; } // v byvshuju lokaciju add_journal('<b>' . $name . '' . $pit . ' ' . $gone . ' ' . $pere . '</b>', 'l.' . $loc, $need); // v novuju add_journal('<b>' . $come . ' ' . $name . '' . $pit . '</b>', 'l.' . $loc_go, $need); //echo '<br/>show info = '.$show_info.'<br/>'; //echo 'n = '.$n.'<br/>'; //echo 'settings 4 = '.$p['settings'][4].'<br/>'; // takzhe, esli showinfo = 1, perehodjashemu chelu pokazatq info toj karty if ($show_info && !$n) { global $p; if ($p['settings'][4] == 1) { $lg = loc($loc_go, 'locinfo'); // kartinki v locpics/(nazvanie karty).jpg $map = substr($loc_go, 0, 4); //$mapi = gen_header ($lg[1]); $mapi = ''; //$mapi .= '<div class="y" id="adg"><b>'.$lg[1].'</div>'; if (file_exists('modules/locpics/' . $map . '.JPEG')) { $mapi .= '<p><img src="modules/locpics/' . $map . '.JPEG" alt="."/></p>'; } // teperq infa // '/mapinfo/'.$map.'.mapi' if (file_exists('modules/mapinfo/' . $map . '.txt')) { $mapi .= '<p>'; $mapi .= file_get_contents('modules/mapinfo/' . $map . '.txt'); $mapi .= '</p>'; } else { $mapi .= '<p>нет информации</p>'; } //global $sid; //$mapi .= '<p><a class="blue" href="game.php?sid='.$sid.'">в игру</a></p>'; //$mapi .= gen_footer(); add_journal($mapi, $p['login']); } } }
<?php session_start(); include_once 'incl/creds.php'; include_once 'incl/functions.php'; $link = mysqli_connect($sql_host, $sql_user, $sql_pass, $sql_db); $profile = mysqli_real_escape_string($link, strtolower($_GET['of'])); if (mysqli_num_rows(mysqli_query($link, "SELECT `id` FROM `users` WHERE `username`='{$profile}'")) <= 0) { header("Location:index.php"); } if (!isset($_SESSION['login'])) { $user = null; include getLangFile(get_loc()); } else { $user = getUserInfo($link, $_SESSION['login']); include getLangFile($user['lang']); } $profile = getUserInfo($link, $profile); ?> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Quatro - <?php echo "@" . $profile['username']; ?> </title> <script type="text/javascript" src="resx/js.js"></script> <link rel="stylesheet" href="resx/css.css"> <link rel="stylesheet" href="resx/small_topbar.css"> <link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css">
} ?> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta name="description" content="Quatro is an anonymous, easy-to-use social networking site." /> <meta name="keywords" content="quatro, anonymous, anonimowy, portal, spolecznosciowy, spolecznosciowy, social, share" /> <meta name="robots" content="index, nofollow" /> <meta name="revisit-after" content="1 month"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <link rel="stylesheet" type="text/css" href="img/css.css"> <title>Quatro</title> <?php include "./incl/tools.php"; include get_lang_file(get_loc()); ?> </head> <body> <div class="box"> <img src='img/greylogo.gif' alt='Quatro' title='Hey, get off me!' /> <div class="header"><?php echo $slogan; ?> </div> <?php if (isset($_GET['good'])) { echo "<div class=\"good\">" . htmlspecialchars($_GET['good']) . "</div>"; } if (isset($_GET['bad'])) { echo "<div class=\"bad\">" . htmlspecialchars($_GET['bad']) . "</div>";
$q = do_mysql("SELECT login FROM players WHERE location = '" . $loc[$loc[0][4][$i]][0] . "' AND active = '1' AND hidden = '0';"); while ($pla = mysql_fetch_assoc($q)) { $f .= '>' . $pla['login']; $f .= ' : <a class="red" href="game.php?sid=' . $sid . '&action=attack&to=' . $pla['login'] . '&near=' . $loc[$loc[0][4][$i]][0] . '">x</a><br/>'; } $q = do_mysql("SELECT fullname, name FROM npc WHERE location = '" . $loc[$loc[0][4][$i]][0] . "' AND type != 's' AND type != 't' AND hidden = '0';"); while ($pla = mysql_fetch_assoc($q)) { $f .= '>' . $pla['name']; $f .= ' : <a class="red" href="game.php?sid=' . $sid . '&action=attack&to=' . $pla['fullname'] . '&near=' . $loc[$loc[0][4][$i]][0] . '">x</a><br/>'; } $f .= '</small>'; } } elseif ($p['settings'][2] == 0) { // esli mozhno letatq ili prygatq, ili verhom, to togda pokazhem ssylku vpered if ($p['walking'] > 0) { $loc2go = get_loc($LOGIN, $loc[0][4][$i], 2); if ($loc2go) { $f .= ' <a class="blue" href="game.php?sid=' . $sid . '&action=go_to_loc&loc_go=' . $loc2go . '&stor=' . $loc[0][4][$i] . '&jump=1">*</a>'; } } $f .= ' | '; } } //etime ('perehody'); // adminka if ($p['admin'] > 1) { $f .= '»<a class="red" href="game.php?sid=' . $sid . '&action=admin">админка</a><br/>'; } // ssylka osmotretsja if ($need2show) { $f .= '»<a class="blue" href="game.php?sid=' . $sid . '&action=locinfo">осмотреться</a><br/>';