mirror of
https://github.com/norohind/SquadsActivityMonitor.git
synced 2025-04-13 13:27:13 +03:00
184 lines
5.6 KiB
Python
184 lines
5.6 KiB
Python
"""
|
|
Run by third side (i.e. cron)
|
|
Request all or specified combination of platform + activity
|
|
Write results to sqlite DB in journal like format
|
|
|
|
|
|
AP - appropriate field from json
|
|
DB structure
|
|
states:
|
|
action_id integer - id of insertion, all records from one request will have the same action_id
|
|
leaderboard_type string - (AP)
|
|
platform string - platform of data
|
|
squadron_id integer - (squadron field)
|
|
score integer - (AP)
|
|
percentile integer - (AP)
|
|
rank integer - (AP)
|
|
name string - (AP)
|
|
tag string - (AP)
|
|
timestamp - inserts by DB, default TIMESTAMP
|
|
|
|
"""
|
|
import typing
|
|
|
|
import requests
|
|
import sqlite3
|
|
|
|
import sql_requests
|
|
# from EDMCLogging import get_main_logger
|
|
import utils
|
|
|
|
db: sqlite3.Connection = sqlite3.connect('squads_stat.sqlite3')
|
|
|
|
db.executescript(sql_requests.schema_create)
|
|
|
|
|
|
def request_leaderboard(platform_enum: utils.Platform, leaderboard_type_enum: utils.LeaderboardTypes) -> dict:
|
|
"""
|
|
Requests specified leaderboard and returns list of squads in specified leaderboard
|
|
|
|
:param platform_enum: leaderboard platform
|
|
:param leaderboard_type_enum: leaderboard type
|
|
:return: list of squads from leaderboard
|
|
"""
|
|
|
|
platform: str = platform_enum.value
|
|
leaderboard_type = leaderboard_type_enum.value
|
|
|
|
SAPIRequest: requests.Response = utils.proxied_request(
|
|
'https://api.orerve.net/2.0/website/squadron/season/leaderboards',
|
|
params={'leaderboardType': leaderboard_type, 'platform': platform})
|
|
|
|
return {
|
|
'leaderboard': SAPIRequest.json()['leaderboards'][leaderboard_type], # list
|
|
'platform': platform, # str
|
|
'type': leaderboard_type # str
|
|
}
|
|
|
|
# return SAPIRequest.json()['leaderboards'][leaderboard_type]
|
|
|
|
|
|
def insert_leaderboard_db(db_conn: sqlite3.Connection, leaderboard_list: dict) -> None:
|
|
"""
|
|
Takes leaderboard as list, it platform, type, db connection and insert leaderboard to DB
|
|
|
|
:param db_conn: Connection to DB
|
|
:param leaderboard_list: list from request_leaderboard
|
|
:return:
|
|
"""
|
|
|
|
platform: str = leaderboard_list['platform']
|
|
LB_type: str = leaderboard_list['type']
|
|
leaderboard: list = leaderboard_list['leaderboard']
|
|
|
|
action_id: int # not last, current that we will use
|
|
|
|
sql_req_action_id: sqlite3.Cursor = db_conn.execute(sql_requests.select_last_action_id)
|
|
action_id_fetch_one: typing.Union[None, tuple[int]] = sql_req_action_id.fetchone()
|
|
if action_id_fetch_one is None:
|
|
# i.e. first launch
|
|
action_id = 1 # yep, not 0
|
|
|
|
else:
|
|
action_id = action_id_fetch_one[0] + 1
|
|
|
|
# Patch for additional values
|
|
for squad in leaderboard:
|
|
squad.update({'action_id': action_id, 'LB_type': LB_type, 'platform': platform})
|
|
|
|
with db_conn:
|
|
db_conn.executemany(
|
|
sql_requests.insert_leader_board,
|
|
leaderboard)
|
|
|
|
|
|
def get_and_save_leaderboard(platform_enum: utils.Platform,
|
|
leaderboard_type_enum: utils.LeaderboardTypes,
|
|
db_conn: sqlite3.Connection) -> None:
|
|
"""
|
|
High logic function to get and save information about specified for type and platform leaderboard
|
|
|
|
:param platform_enum:
|
|
:param leaderboard_type_enum:
|
|
:param db_conn:
|
|
:return:
|
|
"""
|
|
|
|
req = request_leaderboard(platform_enum, leaderboard_type_enum)
|
|
insert_leaderboard_db(db_conn, req)
|
|
|
|
|
|
def main():
|
|
"""
|
|
Run in specified mode from command line
|
|
|
|
main.py update all
|
|
- make all 21 requests (7 leaderboards * 3 platforms)
|
|
|
|
main.py update <leaderboard: string>
|
|
- update specified leaderboard for all platforms (3 requests)
|
|
|
|
main.py update <leaderboard: string> <platform: string>
|
|
- update specified leaderboard for specified platform
|
|
|
|
:return:
|
|
"""
|
|
|
|
from sys import argv
|
|
|
|
help_msg: str = main.__doc__[46:-19]
|
|
|
|
def failed_args(exit_code: int = 0):
|
|
print(help_msg)
|
|
exit(exit_code)
|
|
|
|
if len(argv) == 3: # update all
|
|
if argv[1] == 'update' and argv[2] == 'all':
|
|
# main.py update all
|
|
for platform_enum in utils.Platform:
|
|
for LB_type_enum in utils.LeaderboardTypes:
|
|
get_and_save_leaderboard(platform_enum, LB_type_enum, db)
|
|
|
|
exit(0)
|
|
|
|
elif argv[1] == 'update':
|
|
# main.py update <leaderboard: string>
|
|
leaderboard: str = argv[2].lower()
|
|
try:
|
|
leaderboard_enum: utils.LeaderboardTypes = utils.LeaderboardTypes(leaderboard)
|
|
|
|
for platform_enum in utils.Platform:
|
|
get_and_save_leaderboard(platform_enum, leaderboard_enum, db)
|
|
|
|
exit(0)
|
|
|
|
except ValueError:
|
|
print('leaderboard must be correct leaderboard type')
|
|
exit(1)
|
|
|
|
else:
|
|
failed_args(1)
|
|
|
|
elif len(argv) == 4:
|
|
# main.py update <leaderboard: string> <platform: string>
|
|
if argv[1] == 'update':
|
|
leaderboard = argv[2].lower()
|
|
platform = argv[3].upper()
|
|
|
|
try:
|
|
leaderboard_enum: utils.LeaderboardTypes = utils.LeaderboardTypes(leaderboard)
|
|
platform_enum: utils.Platform = utils.Platform(platform)
|
|
|
|
get_and_save_leaderboard(platform_enum, leaderboard_enum, db)
|
|
exit(0)
|
|
|
|
except ValueError:
|
|
print('leaderboard must be correct leaderboard type, platform must be correct platform')
|
|
exit(0)
|
|
else:
|
|
failed_args(1)
|
|
|
|
|
|
if __name__ == '__main__':
|
|
main()
|