public static function CheckAndSaveFirstTimeAccess($user_id, $contest_id) { $contest_user = self::getByPK($user_id, $contest_id); // If is null, add our contest_user relationship if (is_null($contest_user)) { $contest_user = new ContestsUsers(); $contest_user->setUserId($user_id); $contest_user->setContestId($contest_id); $contest_user->setAccessTime(date("Y-m-d H:i:s")); $contest_user->setScore(0); $contest_user->setTime(0); ContestsUsersDAO::save($contest_user); } else { if ($contest_user->getAccessTime() === "0000-00-00 00:00:00") { // If its set to default time, update it $contest_user->setAccessTime(date("Y-m-d H:i:s")); ContestsUsersDAO::save($contest_user); } } return $contest_user; }
public static function CheckAndSaveFirstTimeAccess($user_id, $contest_id, $grant_access = false) { $contest_user = self::getByPK($user_id, $contest_id); if (is_null($contest_user)) { if (!$grant_access) { // User was not authorized to do this. throw new ForbiddenAccessException(); } $contest_user = new ContestsUsers(); $contest_user->setUserId($user_id); $contest_user->setContestId($contest_id); $contest_user->setAccessTime(date('Y-m-d H:i:s')); $contest_user->setScore(0); $contest_user->setTime(0); ContestsUsersDAO::save($contest_user); } elseif ($contest_user->getAccessTime() === '0000-00-00 00:00:00') { // If its set to default time, update it $contest_user->setAccessTime(date('Y-m-d H:i:s')); ContestsUsersDAO::save($contest_user); } return $contest_user; }
/** * Remove a user from a private contest * * @param Request $r * @return type * @throws InvalidDatabaseOperationException */ public static function apiRemoveUser(Request $r) { // Authenticate logged user self::authenticateRequest($r); self::validateAddUser($r); $contest_user = new ContestsUsers(); $contest_user->setContestId($r["contest"]->getContestId()); $contest_user->setUserId($r["user"]->getUserId()); try { ContestsUsersDAO::delete($contest_user); } catch (Exception $e) { throw new InvalidDatabaseOperationException($e); } return array("status" => "ok"); }
/** * Get Contests which a certain user has participated in * * @param Request $r * @return Contests array * @throws InvalidDatabaseOperationException */ public static function apiContestStats(Request $r) { self::authenticateOrAllowUnauthenticatedRequest($r); $response = array(); $response["contests"] = array(); $user = self::resolveTargetUser($r); $contest_user_key = new ContestsUsers(); $contest_user_key->setUserId($user->getUserId()); // Get contests where user had at least 1 run try { $contestsParticipated = ContestsDAO::getContestsParticipated($user->getUserId()); } catch (Exception $e) { throw new InvalidDatabaseOperationException($e); } $contests = array(); foreach ($contestsParticipated as $contest) { // Get user ranking $scoreboardR = new Request(array("auth_token" => $r["auth_token"], "contest_alias" => $contest->getAlias(), "token" => $contest->getScoreboardUrlAdmin())); $scoreboardResponse = ContestController::apiScoreboard($scoreboardR); // Grab the place of the current user in the given contest $contests[$contest->getAlias()]["place"] = null; foreach ($scoreboardResponse["ranking"] as $userData) { if ($userData["username"] == $user->getUsername()) { $contests[$contest->getAlias()]["place"] = $userData["place"]; break; } } $contest->toUnixTime(); $contests[$contest->getAlias()]["data"] = $contest->asArray(); } $response["contests"] = $contests; $response["status"] = "ok"; return $response; }