public function action() { $team = new Team(); $team->initById($this->parameters->teamId); $teamInJSON = JSONPrepare::team($team); $teamInJSON["footballers"] = JSONPrepare::footballers(FootballerSatellite::initForTeam($team)); $teamInJSON["sponsors"] = JSONPrepare::sponsors(SponsorSatellite::initForTeam($team)); $this->result['team'] = $teamInJSON; }
public function action() { $this->result['teams'] = array(); track_stats(); // Отслеживаем производительность $sql_template = "SELECT\n *, unix_timestamp(tour_bonus_time) as tour_bonus_time \n FROM teams\n WHERE \n%d < param_sum AND param_sum < %d AND MOD(vk_id, %d) = 0 AND able_to_choose = 1\n LIMIT 30"; $sql = sprintf($sql_template, $this->teamProfile->getParameterSum() - GlobalParameters::ENEMY_RANGE, $this->teamProfile->getParameterSum() + GlobalParameters::ENEMY_RANGE, rand(0, 29)); $teamResult = SQL::getInstance()->query($sql); if ($teamResult instanceof ErrorPoint) { return $teamResult; } track_stats(); // Отслеживаем производительность if ($teamResult->num_rows) { while ($teamObject = $teamResult->fetch_object()) { if (empty($teamObject->user_name) || $teamObject->vk_id == $this->teamProfile->getSocialUserId()) { continue; } $team = new Team(); $team->initFromDB($teamObject); $chnase = Utils::detectChanceOfWin($this->teamProfile, $team); $teamInJSON = JSONPrepare::team($team); $teamInJSON["score"] = md5($chnase . $team->getSocialUserId() . SECRET_KEY); $this->result['teams'][] = $teamInJSON; } track_stats(); // Отслеживаем производительность } else { $sql_template = "SELECT\n *, unix_timestamp(tour_bonus_time) as tour_bonus_time\nFROM teams\n WHERE\n%d < (param_sum) AND\n(param_sum) < %d AND\nMOD(vk_id, %d) = 0 and able_to_choose = 1\n LIMIT 30"; $sql = sprintf($sql_template, $this->teamProfile->getParameterSum() - GlobalParameters::ENEMY_RANGE * 3, $this->teamProfile->getParameterSum() + GlobalParameters::ENEMY_RANGE * 3, rand(0, 29)); $teamResult = SQL::getInstance()->query($sql); if ($teamResult instanceof ErrorPoint) { return $teamResult; } track_stats(); // Отслеживаем производительность if ($teamResult->num_rows) { while ($teamObject = $teamResult->fetch_object()) { if (empty($teamObject->user_name) || $teamObject->vk_id == $this->teamProfile->getSocialUserId()) { continue; } $team = new Team(); $team->initFromDB($teamObject); $teamInJSON = JSONPrepare::team($team); $chnase = Utils::detectChanceOfWin($this->teamProfile, $team); //$teamInJSON["score"] = Utils::detectChanceOfWin($this->teamProfile, $team); $teamInJSON["score"] = md5($chnase . $team->getSocialUserId() . SECRET_KEY); $this->result['teams'][] = $teamInJSON; } track_stats(); // Отслеживаем производительность } } }
public function getResult() { $this->result["teamProfiler"] = JSONPrepare::team($this->teamProfile); return $this->result; }
public function action() { $groupType = intval($this->parameters->groupType); $placerId = intval($this->parameters->placerId); if ($groupType == 0 || $groupType == TOUR_TYPE_VK && $placerId != 0) { return new ErrorPoint(ErrorPoint::CODE_LOGIC, "Ошибка в программе", ErrorPoint::TYPE_USER); } track_stats(); // Отслеживаем производительность $sql_template = "SELECT vk_id, wins, ties, loses, score, group_number, in_play_off, tour_group_id FROM tour_groups WHERE was_closed = 0 and tour_type = %d and tour_placer_id = %d;"; $sql = sprintf($sql_template, $groupType, $placerId); $SQLresult = SQL::getInstance()->query($sql); if ($SQLresult instanceof ErrorPoint) { return $SQLresult; } $group = array(); track_stats(); // Отслеживаем производительность if ($SQLresult->num_rows) { while ($teamObject = $SQLresult->fetch_object()) { $group[$teamObject->group_number][] = $teamObject; $team = new Team(); $team->initById($teamObject->vk_id); $teamInJSON = JSONPrepare::team($team); $this->result['teams'][] = $teamInJSON; if ($teamObject->vk_id == $this->teamProfile->getSocialUserId()) { $this->userInGroups = array($teamObject->tour_group_id, $teamObject->group_number); if ($teamObject->in_play_off) { $this->userInPlayOff = true; } } } } track_stats(); // Отслеживаем производительность $this->result['group'] = $group; $playOff = array(); $currentStep = 4; $playOff[$currentStep] = $this->getPlayOffByStep($currentStep, $groupType, $placerId); $currentStep--; $playOff[$currentStep] = $this->getPlayOffByStep($currentStep, $groupType, $placerId); $currentStep--; $playOff[$currentStep] = $this->getPlayOffByStep($currentStep, $groupType, $placerId); $currentStep--; $playOff[$currentStep] = $this->getPlayOffByStep($currentStep, $groupType, $placerId); $this->result['playOff'] = $playOff; track_stats(); // Отслеживаем производительность $this->result['groupSteps'] = array(); if ($this->userInGroups) { $sql_template = "SELECT finished, goals_enemy, goals, result, vk_id_enemy, vk_id, group_details_id FROM tour_groups_details WHERE tour_group_id = %d and vk_id = %d ORDER BY group_details_id ;"; $sql = sprintf($sql_template, $this->userInGroups[0], $this->teamProfile->getSocialUserId()); $SQLresult = SQL::getInstance()->query($sql); if ($SQLresult instanceof ErrorPoint) { return $SQLresult; } $finishedCounter = 0; if ($SQLresult->num_rows) { while ($groupStepObject = $SQLresult->fetch_object()) { $this->result['groupSteps'][$groupStepObject->group_details_id] = $groupStepObject; $this->result['groupSteps'][$groupStepObject->group_details_id]->group_number = $this->userInGroups[1]; $finishedCounter += $groupStepObject->finished; } } if ($finishedCounter == 3) { $this->result['groupSteps'] = array(); } } track_stats(); // Отслеживаем производительность $this->result['playOffSteps'] = array(); if ($this->userInPlayOff) { $sql_template = "SELECT vk_id_enemy, result, goals, goals_enemy, finished, play_off_step, play_off_id FROM tour_play_off WHERE vk_id = %d and tour_type = %d and tour_placer_id = %d ORDER BY play_off_id ;"; $sql = sprintf($sql_template, $this->teamProfile->getSocialUserId(), $groupType, $placerId); $SQLresult = SQL::getInstance()->query($sql); if ($SQLresult instanceof ErrorPoint) { return $SQLresult; } if ($SQLresult->num_rows) { while ($playOffStepObject = $SQLresult->fetch_object()) { $this->result['playOffSteps'][$playOffStepObject->play_off_step] = $playOffStepObject; } } } track_stats(); // Отслеживаем производительность }
register_shutdown_function('shutdown'); set_error_handler("handlerError"); $userId = intval($_GET["userId"]); $authKey = @trim($_GET["authKey"]); $checkSum = @trim($_GET["checkSum"]); $serverCheckSum = md5($authKey . SECRET_KEY . $userId); if ($serverCheckSum != $checkSum) { $actionResult = new ErrorPoint(ErrorPoint::CODE_BAD_MD5, "WFT", ErrorPoint::TYPE_USER); } if (!in_array(getRealIP(), $allowIPForSystemCommand)) { $actionResult = new ErrorPoint(ErrorPoint::CODE_BAD_MD5, "WFT!: " . getRealIP(), ErrorPoint::TYPE_USER); } UserParameters::setUserId($userId); if (SQL::getInstance()->connect_error) { $actionResult = new ErrorPoint(ErrorPoint::CODE_SQL, "Невозможно подключиться (" . SQL::getInstance()->connect_error . ")", ErrorPoint::TYPE_SYSTEM); break; } echo '<?xml version="1.0"?> <userInfo>'; if (!array_key_exists("onlyProfile", $_GET)) { echo '<requests>'; getUsersActivity(); echo "</requests>"; } $team = new Team(); $team->initById(UserParameters::getUserId()); echo "<team><![CDATA[" . json_encode(JSONPrepare::team($team)) . "]]></team>"; echo "</userInfo>"; ob_end_flush(); ?>
public function action() { $this->result["isInstalled"] = $this->teamProfile->getIsInstalled(); track_stats(); // ќтслеживаем производительность $startAt = RAM::getInstance()->getTourStart(); $finishAt = RAM::getInstance()->getTourFinish(); track_stats(); // ќтслеживаем производительность if (empty($startAt) || empty($finishAt)) { $tourTimer = TourSatellite::getTimerDate(); $startAt = $tourTimer->startAt; $finishAt = $tourTimer->finishAt; RAM::getInstance()->setTourStart($startAt); RAM::getInstance()->setTourFinish($finishAt); } track_stats(); // ќтслеживаем производительность $this->result["tourStartAt"] = $startAt; $this->result["tourFinishedAt"] = $finishAt; $this->result["serverTime"] = time(); if ($this->teamProfile->getIsInstalled()) { track_stats(); // ќтслеживаем производительность $energyTimer = RAM::getInstance()->getEnergyLastUpdate(); if (empty($energyTimer)) { $energyTimer = filemtime(SYSTEM_LOGS . "/cron.updateEnergy.log"); // microtime RAM::getInstance()->setEnergyLastUpdate($energyTimer); } $this->result['energyTimer'] = $energyTimer; track_stats(); // ќтслеживаем производительность if ($this->teamProfile->isNeedDailyBonus()) { $dailyBonus = $this->teamProfile->getTotalStadiumBonus(); $this->teamProfile->setMoney($this->teamProfile->getMoney() + $dailyBonus); $actionResult = TeamSatellite::accrueDailyBonus(UserParameters::getUserId(), $this->teamProfile->getMoney()); if ($actionResult instanceof ErrorPoint) { return $actionResult; } } track_stats(); // ќтслеживаем производительность if ($this->teamProfile->isNewTour() && $this->teamProfile->getTourBonus() != 0 && $this->teamProfile->getTourBonusTime() == 0) { $finishBonusAt = time() + 1 * 24 * 60 * 60; $actionResult = TeamSatellite::startTourBonus(UserParameters::getUserId(), $finishBonusAt); if ($actionResult instanceof ErrorPoint) { return $actionResult; } $this->teamProfile->setTourBonusTime($finishBonusAt); } track_stats(); // ќтслеживаем производительность $this->result["teamInfo"] = JSONPrepare::team($this->teamProfile); track_stats(); // ќтслеживаем производительность // Ёто надо обновить после отдачи профайла if ($this->teamProfile->getTourNotify() == TOUR_NOTIFY_START || $this->teamProfile->getTourNotify() == TOUR_NOTIFY_NEW) { $actionResult = TeamSatellite::updateTourNotify(UserParameters::getUserId(), $this->teamProfile->getTourNotify() - 2); if ($actionResult instanceof ErrorPoint) { return $actionResult; } } track_stats(); // ќтслеживаем производительность if ($this->teamProfile->isNewTour() && $this->teamProfile->getTourBonus() != 0 && $this->teamProfile->getTourBonusTime() > 0 && $this->teamProfile->getTourBonusTime() < time()) { $actionResult = TeamSatellite::eraseTourBonus(UserParameters::getUserId()); if ($actionResult instanceof ErrorPoint) { return $actionResult; } $this->teamProfile->setTourBonus(0); $this->teamProfile->setTourBonusTime(0); } track_stats(); // ќтслеживаем производительность if ($this->teamProfile->getStudyPointsViaPrize() > 0) { $actionResult = TeamSatellite::resetPrizeStudyPoint(UserParameters::getUserId()); if ($actionResult instanceof ErrorPoint) { return $actionResult; } } //Utils::forDebug($this->teamProfile); } }
private function getFriendsTeams() { $this->result['teams'] = array(); $this->result['news'] = array(); $this->result['rating'] = array(); if ($this->parameters->groupSourceId) { logGroupSource($this->parameters->groupSourceId); } $needToUpgrade = false; $userCountry = intval($this->parameters->userCountry); $userCity = intval($this->parameters->userCity); $userUniversity = intval($this->parameters->userUniversity); track_stats(); // Отслеживаем производительность if ($userCountry != $this->teamProfile->getUserCountry()) { $this->teamProfile->setUserCountry($userCountry); $needToUpgrade = true; } if ($userCity != $this->teamProfile->getUserCity()) { $this->teamProfile->setUserCity($userCity); $needToUpgrade = true; } if ($userUniversity != $this->teamProfile->getUserUniversity()) { $this->teamProfile->setUserUniversity($userUniversity); $needToUpgrade = true; } if (isset($this->parameters->groupBonusNeeded) && $this->parameters->groupBonusNeeded == 1 && $this->teamProfile->getInGroup() == 0) { $this->teamProfile->setInGroup(1); $this->teamProfile->setRealMoney($this->teamProfile->getRealMoney() + GlobalParameters::GROUP_BONUS_REAL); $needToUpgrade = true; } track_stats(); // Отслеживаем производительность if ($needToUpgrade) { $actionResult = $this->teamProfile->save(); if ($actionResult instanceof ErrorPoint) { return $actionResult; } } if ($this->parameters->uids) { if (!is_object($this->parameters->uids)) { $this->parameters->uids = str_replace('\\\\', '', $this->parameters->uids); $this->parameters->uids = str_replace('\\"', '', $this->parameters->uids); $this->parameters->uids = json_decode($this->parameters->uids); } track_stats(); // Отслеживаем производительность $sql_template = "SELECT\n teams.team_name,\n teams.param_forward,\n teams.param_half,\n teams.param_safe,\n teams.user_photo,\n teams.user_name, \n teams.team_logo_id, \n teams.vk_id,\n teams.level\nFROM teams\nWHERE teams.vk_id IN (%s) order by teams.level desc, teams.counter_won desc "; $sql = sprintf($sql_template, Utils::IdsSeparetedByComma($this->parameters->uids)); $SQLresult = SQL::getInstance()->query($sql); if ($SQLresult instanceof ErrorPoint) { return $SQLresult; } if ($SQLresult->num_rows) { $counterPlace = 1; while ($teamObject = $SQLresult->fetch_object()) { $team = new Team(); $team->initFromDB($teamObject, false); if ($team->getLevel() == 0) { continue; } $team->place = $counterPlace; $teamInJSON = JSONPrepare::team($team); $counterPlace++; $this->result['teams'][] = $teamInJSON; // $this->result['teams'][] = $teamObject; } } } $this->result['news'] = RAM::getInstance()->getNews(); if (count($this->result['news']) == 0) { $sql_template = "SELECT news_sport.* FROM news_sport ORDER BY news_id"; $sql = $sql_template; $SQLresult = SQL::getInstance()->query($sql); if ($SQLresult instanceof ErrorPoint) { return $SQLresult; } if ($SQLresult->num_rows) { $counter = 0; while ($newsObject = $SQLresult->fetch_object()) { $news = new NewsEntry($newsObject); $news->id = $counter; $this->result['news'][] = $news; RAM::getInstance()->setNews($news); $counter++; } } } $leadTeams = RAM::getInstance()->getLeaders(); if (count($leadTeams) == 0) { $sql_template = "SELECT teams.* FROM teams WHERE total_place is not NULL ORDER BY total_place LIMIT 6"; $sql = $sql_template; $SQLresult = SQL::getInstance()->query($sql); if ($SQLresult instanceof ErrorPoint) { return $SQLresult; } if ($SQLresult->num_rows) { $counter = 0; while ($teamObject = $SQLresult->fetch_object()) { $team = new Team(); $team->initFromDB($teamObject); RAM::getInstance()->setLeader($team, $counter); $counter++; $teamInJSON = JSONPrepare::team($team); $this->result['rating'][] = $teamInJSON; } } } else { foreach ($leadTeams as $team) { $teamInJSON = JSONPrepare::team($team); $this->result['rating'][] = $teamInJSON; } } }