-
Notifications
You must be signed in to change notification settings - Fork 52
/
Copy pathgame_releases_utils.py
111 lines (91 loc) · 3.36 KB
/
game_releases_utils.py
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
from __future__ import annotations
from collections import defaultdict
from datetime import datetime
from typing import TYPE_CHECKING, List
import requests
from sqlalchemy.orm import Session
from app.database.models import UserSettings
if TYPE_CHECKING:
from app.routers.calendar_grid import Day, Week
def is_user_signed_up_for_game_releases(
session: Session,
current_user_id: int,
) -> bool:
is_signed_up = (
session.query(UserSettings)
.filter(UserSettings.user_id == current_user_id)
.filter(UserSettings.video_game_releases.is_(True))
.first()
)
if is_signed_up:
return True
return False
def add_game_events_to_weeks(
weeks: List["Week"],
is_active: bool = True,
) -> List["Week"]:
if not is_active:
return weeks
first_week: Week = weeks[0]
last_week: Week = weeks[-1]
first_day: Day = first_week.days[0]
last_day: Day = last_week.days[-1]
first_day_str = datetime.strptime(first_day.set_id(), "%d-%B-%Y")
last_day_str = datetime.strptime(last_day.set_id(), "%d-%B-%Y")
games_by_dates = get_games_data_separated_by_days(
start_date=first_day_str.strftime("%Y-%m-%d"),
end_date=last_day_str.strftime("%Y-%m-%d"),
)
formatted_games = get_formatted_games_in_days(games_by_dates)
for week in weeks:
for day in week.days:
if day.set_id() in formatted_games.keys():
for game in formatted_games[day.set_id()]:
day.dailyevents.append(
(
f"GR!- {(game)[:10]}",
(game),
),
)
return weeks
def get_games_data_separated_by_days(
start_date: datetime,
end_date: datetime,
) -> defaultdict[List]:
API = "https://api.rawg.io/api/games"
current_day_games = requests.get(
f"{API}?dates={start_date},{end_date}",
)
current_day_games = current_day_games.json()["results"]
games_data = defaultdict(list)
for result in current_day_games:
current = {}
current["name"] = result["name"]
if result["platforms"]:
current["platforms"] = []
for platform in result["platforms"]:
current["platforms"].append(platform["platform"]["name"])
ybd_release_date = translate_ymd_date_to_dby(result["released"])
games_data[ybd_release_date].append(current)
return games_data
def get_formatted_games_in_days(
separated_games_dict: defaultdict[List],
with_platforms: bool = False,
) -> defaultdict[List]:
formatted_games = defaultdict(list)
for date, game_data in separated_games_dict.items():
for game in game_data:
formatted_game_str = ""
formatted_game_str += game["name"]
if with_platforms:
formatted_game_str += "-Platforms-<br>"
for platform in game["platforms"]:
formatted_game_str += f"{platform},"
formatted_games[date].append(formatted_game_str)
return formatted_games
def translate_ymd_date_to_dby(ymd_str: str) -> str:
ymd_time = datetime.strptime(ymd_str, "%Y-%m-%d")
return ymd_time.strftime("%d-%B-%Y")
def translate_dby_date_to_ymd(dby_str: str) -> str:
dby_time = datetime.strptime(dby_str, "%d-%B-%Y")
return dby_time.strftime("%Y-%m-%d")