Refactoring
This commit is contained in:
@@ -1,18 +1,35 @@
|
||||
import atexit
|
||||
import re
|
||||
from dataclasses import dataclass
|
||||
from hashlib import md5
|
||||
from json import dumps
|
||||
from os import environ
|
||||
from flask import Flask, jsonify
|
||||
from time import time
|
||||
from urllib.parse import parse_qs, urlparse
|
||||
|
||||
from apscheduler.schedulers.background import BackgroundScheduler
|
||||
from apscheduler.triggers.interval import IntervalTrigger
|
||||
import requests
|
||||
from time import time
|
||||
import atexit
|
||||
import re
|
||||
from urllib.parse import urlparse, parse_qs
|
||||
from flask import Flask
|
||||
|
||||
|
||||
TOKEN = environ.get("STEAM_TOKEN")
|
||||
MY_ID = 76561198826355942
|
||||
|
||||
recent = {}
|
||||
owned = {}
|
||||
@dataclass
|
||||
class Cache:
|
||||
data = {}
|
||||
last_updated = time()
|
||||
status = None
|
||||
|
||||
data = {
|
||||
"caches": {
|
||||
"recent": Cache(),
|
||||
"owned": Cache()
|
||||
},
|
||||
"last_updated": time(),
|
||||
"etag": ""
|
||||
}
|
||||
|
||||
def modify_game_list(json: dict) -> dict:
|
||||
if 'games' in json.keys():
|
||||
@@ -37,34 +54,40 @@ def api_request(cache, *args, **kwargs):
|
||||
try:
|
||||
response = steam_request(*args, **kwargs)
|
||||
if response.status_code == 200:
|
||||
cache.update({
|
||||
'data': modify_game_list(response.json().get("response")),
|
||||
'last_updated': time(),
|
||||
'status': 'success'
|
||||
})
|
||||
json = modify_game_list(response.json().get("response"))
|
||||
cache.status = 'success'
|
||||
|
||||
if cache.data != json:
|
||||
cache.data = json
|
||||
cache.last_updated = time()
|
||||
data['last_updated'] = time()
|
||||
data['etag'] = md5(''.join(
|
||||
( dumps(data['caches'][x].data) for x in data['caches'] )
|
||||
).encode()).hexdigest()
|
||||
else:
|
||||
cache['status'] = f'error: {response.status_code}'
|
||||
cache.status = f'error: {response.status_code}'
|
||||
print("x")
|
||||
except Exception as e:
|
||||
cache['status'] = f'error: {str(e)}'
|
||||
cache.status = f'error: {str(e)}'
|
||||
|
||||
if TOKEN:
|
||||
scheduler = BackgroundScheduler()
|
||||
scheduler.add_job(
|
||||
func=lambda: api_request(recent, "IPlayerService", "GetRecentlyPlayedGames", steamid=76561198826355942),
|
||||
func=lambda: api_request(data['caches']['recent'], "IPlayerService", "GetRecentlyPlayedGames", steamid=76561198826355942),
|
||||
trigger=IntervalTrigger(minutes=15),
|
||||
id='risdeveau.steam.recent',
|
||||
replace_existing=True
|
||||
)
|
||||
scheduler.add_job(
|
||||
func=lambda: api_request(owned, "IPlayerService", "GetOwnedGames", steamid=76561198826355942, include_appinfo=1, include_played_free_games=1),
|
||||
func=lambda: api_request(data['caches']['owned'], "IPlayerService", "GetOwnedGames", steamid=76561198826355942, include_appinfo=1, include_played_free_games=1),
|
||||
trigger=IntervalTrigger(minutes=60),
|
||||
id='risdeveau.steam.owned',
|
||||
replace_existing=True
|
||||
)
|
||||
scheduler.start()
|
||||
|
||||
api_request(recent, "IPlayerService", "GetRecentlyPlayedGames", steamid=76561198826355942)
|
||||
api_request(owned, "IPlayerService", "GetOwnedGames", steamid=76561198826355942, include_appinfo=1, include_played_free_games=1)
|
||||
api_request(data['caches']['recent'], "IPlayerService", "GetRecentlyPlayedGames", steamid=76561198826355942)
|
||||
api_request(data['caches']['owned'], "IPlayerService", "GetOwnedGames", steamid=76561198826355942, include_appinfo=1, include_played_free_games=1)
|
||||
|
||||
atexit.register(lambda: scheduler.shutdown())
|
||||
else:
|
||||
|
||||
Reference in New Issue
Block a user