1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
|
from flask import Blueprint, request
from functools import reduce
from db import cursor
from auth.login_token import token_login
from user.info import format_user
from rating import outcome
from ruleset import resolve_ruleset
def format_game(game_id, user_id = None):
game = cursor.execute("select " + ", ".join([
"game_id", # 0
"parent_game", # 1
"moves", # 2
"player_1_id", # 3
"player_2_id", # 4
"outcome", # 5
"created", # 6
"started", # 7
"duration", # 8
"rating_delta_player_1", # 9
"rating_delta_player_2", # 10
"ruleset", # 11
"status", # 12
"private", # 13
]) + " from games where game_id = ?", [game_id]).fetchone()
is_player_1 = game[4] != user_id
opponent = game[4] if is_player_1 else game[3]
return {
"id": game[0],
"parent": game[1],
"moves": [] if len(game[2]) == 0 else [int(move) for move in str(game[2] + "0").split(",")],
"opponent": None if not opponent else format_user(opponent),
"outcome": None if not game[5] else outcome(game[5], is_player_1),
"created": game[6],
"started": game[7],
"duration": game[8],
"rating": game[9] if is_player_1 else game[10],
"rating_opponent": game[10] if is_player_1 else game[9],
"ruleset": resolve_ruleset(game[11]),
"status": game[12],
"private": bool(game[13]),
}
def valid_game_id(game_id):
query = cursor.execute("select game_id from games where game_id = ?", [game_id]).fetchone()
return bool(query)
game_info = Blueprint('game_info', __name__)
@game_info.route('/info', methods = ['POST'])
def index():
data = request.get_json()
if not data: return "", 400
game_id = data.get("id") or ""
if not game_id: return "", 400
user_id = None
token = request.cookies.get("token") or ""
if token: user_id = token_login(token)
if not valid_game_id(game_id): return "", 403
return format_game(game_id, user_id), 200
dynamic_route = ["/game", game_info]
|