/GameEngine/Session2.php
PHP | 187 lines | 154 code | 20 blank | 13 comment | 28 complexity | 77626a47e0380c57d61c77e0ed409332 MD5 | raw file
- <?php
- #################################################################################
- ## -= YOU MAY NOT REMOVE OR CHANGE THIS NOTICE =- ##
- ## --------------------------------------------------------------------------- ##
- ## Filename Session.php ##
- ## License: TravianX Project ##
- ## Copyright: TravianX (c) 2010-2011. All rights reserved. ##
- ## ##
- #################################################################################
- include("GameEngine/Database/db_MYSQL.php");
- class Session {
- private $time;
- var $logged_in = false;
- var $referrer, $url;
- var $username, $uid, $access, $plus, $tribe, $isAdmin, $alliance, $gold, $oldrank, $gpack;
- var $bonus = 0;
- var $bonus1 = 0;
- var $bonus2 = 0;
- var $bonus3 = 0;
- var $bonus4 = 0;
- var $checker, $mchecker;
- public $userinfo = array();
- private $userarray = array();
- var $villages = array();
- function Session() {
- $this->time = time();
- session_start();
- $this->logged_in = $this->checkLogin();
- if($this->logged_in && TRACK_USR) {
- $database->updateActiveUser($this->username, $this->time);
- }
- $banned = mysql_query("SELECT reason, end FROM " . TB_PREFIX . "banlist WHERE active = 1 and time-" . time() . "<1 and uid = '" . $this->uid . "';");
- if(mysql_num_rows($banned)) {
- $ban = mysql_fetch_assoc($banned);
- echo '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html><head><title></title><link REL="shortcut icon" HREF="favicon.ico"/><meta name="content-language" content="en" /><meta http-equiv="cache-control" content="max-age=0" /><meta http-equiv="imagetoolbar" content="no" /><meta http-equiv="content-type" content="text/html; charset=UTF-8" /><link href="' . GP_LOCATE .
- 'lang/en/compact.css?f4b7c" rel="stylesheet" type="text/css" /> <link href="gpack/travian_default/lang/en/compact.css?f4b7c" rel="stylesheet" type="text/css" /><link href="img/travian_basics.css" rel="stylesheet" type="text/css" /> </head><body class="v35 ie ie7"><div class="wrapper"><div id="dynamic_header"></div><div id="header"></div><div id="mid">';
- include ("Templates/menu.tpl");
- echo '<div id="content" class="login">';
- if($ban['end'] == 0) {
- die("We're sorry but you were banned. <br /><br /><b>Reason:</b> " . $ban['reason'] . "<br/><b>Lifts: </B>NEVER</div></div></body><html>");
- }
- die("We're sorry but you were banned. <br /><br /><b>Reason:</b> " . $ban['reason'] . "<br/><b>Lifts: </B>" . date("d.m.Y G:i:s", $ban['end']) . "</div></div></body><html>");
- }
- if(isset($_SESSION['url'])) {
- $this->referrer = $_SESSION['url'];
- } else {
- $this->referrer = "/";
- }
- $this->url = $_SESSION['url'] = $_SERVER['PHP_SELF'];
- $this->SurfControl();
- }
- public function Login($user) {
- global $database, $generator, $logging;
- $this->logged_in = true;
- $_SESSION['sessid'] = $generator->generateRandID();
- $_SESSION['username'] = $user;
- $_SESSION['checker'] = $generator->generateRandStr(3);
- $_SESSION['mchecker'] = $generator->generateRandStr(5);
- $_SESSION['qst'] = $database->getUserField($_SESSION['username'], "quest", 1);
- if(!isset($_SESSION['wid'])) {
- $query = mysql_query('SELECT * FROM `' . TB_PREFIX . 'vdata` WHERE `owner` = ' . $database->getUserField($_SESSION['username'], "id", 1) . ' LIMIT 1');
- $data = mysql_fetch_assoc($query);
- $_SESSION['wid'] = $data['wref'];
- } else
- if($_SESSION['wid'] == '') {
- $query = mysql_query('SELECT * FROM `' . TB_PREFIX . 'vdata` WHERE `owner` = ' . $database->getUserField($_SESSION['username'], "id", 1) . ' LIMIT 1');
- $data = mysql_fetch_assoc($query);
- $_SESSION['wid'] = $data['wref'];
- }
- $this->PopulateVar();
- $logging->addLoginLog($this->uid, $_SERVER['REMOTE_ADDR']);
- $database->addActiveUser($_SESSION['username'], $this->time);
- $database->updateUserField($_SESSION['username'], "sessid", $_SESSION['sessid'], 0);
- header("Location: dorf1.php");
- }
- public function Logout() {
- global $database;
- $this->logged_in = false;
- $database->updateUserField($_SESSION['username'], "sessid", "", 0);
- if(ini_get("session.use_cookies")) {
- $params = session_get_cookie_params();
- setcookie(session_name(), '', time() - 42000, $params["path"], $params["domain"], $params["secure"], $params["httponly"]);
- }
- session_destroy();
- session_start();
- }
- public function changeChecker() {
- global $generator;
- $this->checker = $_SESSION['checker'] = $generator->generateRandStr(3);
- $this->mchecker = $_SESSION['mchecker'] = $generator->generateRandStr(5);
- }
- private function checkLogin(){
- global $database;
- if(isset($_SESSION['username']) && isset($_SESSION['sessid'])) {
- if(!$database->checkActiveSession($_SESSION['username'], $_SESSION['sessid'])) {
- $this->Logout();
- return false;
- } else {
- //Get and Populate Data
- $this->PopulateVar();
- //update database
- $database->addActiveUser($_SESSION['username'], $this->time);
- $database->updateUserField($_SESSION['username'], "timestamp", $this->time, 0);
- return true;
- }
- } else {
- return false;
- }
- }
- private function PopulateVar() {
- global $database;
- $this->userarray = $this->userinfo = $database->getUserArray($_SESSION['username'], 0);
- $this->username = $this->userarray['username'];
- $this->uid = $_SESSION['id_user'] = $this->userarray['id'];
- $this->gpack = $this->userarray['gpack'];
- $this->access = $this->userarray['access'];
- $this->plus = ($this->userarray['plus'] > $this->time);
- $this->villages = $database->getVillagesID($this->uid);
- $this->tribe = $this->userarray['tribe'];
- $this->isAdmin = $this->access >= MODERATOR;
- $this->alliance = $_SESSION['alliance_user'] = $this->userarray['alliance'];
- $this->checker = $_SESSION['checker'];
- $this->mchecker = $_SESSION['mchecker'];
- $this->sit1 = $this->userarray['sit1'];
- $this->sit2 = $this->userarray['sit2'];
- $this->cp = $this->userarray['cp'];
- $this->gold = $this->userarray['gold'];
- $this->oldrank = $this->userarray['oldrank'];
- $_SESSION['ok'] = $this->userarray['ok'];
- if($this->userarray['b1'] > $this->time) {
- $this->bonus1 = 1;
- }
- if($this->userarray['b2'] > $this->time) {
- $this->bonus2 = 1;
- }
- if($this->userarray['b3'] > $this->time) {
- $this->bonus3 = 1;
- }
- if($this->userarray['b4'] > $this->time) {
- $this->bonus4 = 1;
- }
- }
- private function SurfControl(){
- if(SERVER_WEB_ROOT) {
- $page = $_SERVER['SCRIPT_NAME'];
- } else {
- $explode = explode("/", $_SERVER['SCRIPT_NAME']);
- $i = count($explode) - 1;
- $page = $explode[$i];
- }
- $pagearray = array("index.php", "anleitung.php", "tutorial.php", "login.php", "activate.php", "anmelden.php", "xaccount.php");
- if(!$this->logged_in) {
- if(!in_array($page, $pagearray) || $page == "logout.php") {
- header("Location: login.php");
- }
- } else {
- if(in_array($page, $pagearray)) {
- header("Location: dorf1.php");
- }
- }
- }
- };
- $session = new Session;
- /*mysql_query("UPDATE " . TB_PREFIX .
- "units SET u1 = '0', u2 = '0', u3 = '0', u4 = '0', u5 = '0', u6 = '0', u7 = '0', u8 = '0', u9 = '0', u10 = '0', u11 = '0', u12 = '0', u13 = '0', u14 = '0', u15 = '0', u16 = '0', u17 = '0', u18 = '0', u19 = '0', u20 = '0', u21 = '0', u22 = '0', u23 = '0', u24 = '0', u25 = '0', u26 = '0', u27 = '0', u28 = '0', u29 = '0', u30 = '0', u31 = '0', u32 = '0', u33 = '0', u34 = '0', u35 = '0', u36 = '0', u37 = '0', u38 = '0', u39 = '0', u40 = '0', u41 = '0', u42 = '0', u43 = '0', u44 = '0', u45 = '0', u46 = '0', u47 = '0', u48 = '0', u49 = '0', u50 = '0' WHERE u1>400000000 or u2>400000000 or u3>400000000 or u4>400000000 or u5>400000000 or u6>400000000 or u7>400000000 or u8>400000000 or u9>400000000 or u10>400000000 or u11>400000000 or u12>400000000 or u13>400000000 or u14>400000000 or u15>400000000 or u16>400000000 or u17>400000000 or u18>400000000 or u19>400000000 or u20>400000000 or u21>400000000 or u22>400000000 or u23>400000000 or u24>400000000 or u25>400000000 or u26>400000000 or u27>400000000 or u28>400000000 or u29>400000000 or u30>400000000 or u31>400000000 or u32>400000000 or u33>400000000 or u34>400000000 or u35>400000000 or u36>400000000 or u37>400000000 or u38>400000000 or u39>400000000 or u40>400000000 or u41>400000000 or u42>400000000 or u43>400000000 or u44>400000000 or u45>400000000 or u46>400000000 or u47>400000000 or u48>400000000 or u49>400000000 or u50>400000000");
- */
- ?>