2023-11-05 18:09:58 +01:00
from datetime import date , datetime , timedelta
2023-02-17 07:02:21 +01:00
from typing import Dict , Optional , List
from sqlalchemy import Table , Column , UniqueConstraint , PrimaryKeyConstraint , and_
from sqlalchemy . types import Integer , String , TIMESTAMP , Boolean , JSON
from sqlalchemy . schema import ForeignKey
2023-03-03 23:46:29 +01:00
from sqlalchemy . engine import Row
2023-02-17 07:02:21 +01:00
from sqlalchemy . sql import func , select
from sqlalchemy . dialects . mysql import insert
from core . data . schema import BaseData , metadata
card = Table (
" ongeki_user_card " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
Column ( " user " , ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ) ,
Column ( " cardId " , Integer ) ,
Column ( " digitalStock " , Integer ) ,
Column ( " analogStock " , Integer ) ,
Column ( " level " , Integer ) ,
Column ( " maxLevel " , Integer ) ,
Column ( " exp " , Integer ) ,
Column ( " printCount " , Integer ) ,
Column ( " useCount " , Integer ) ,
Column ( " isNew " , Boolean ) ,
Column ( " kaikaDate " , String ( 25 ) ) ,
Column ( " choKaikaDate " , String ( 25 ) ) ,
Column ( " skillId " , Integer ) ,
Column ( " isAcquired " , Boolean ) ,
Column ( " created " , String ( 25 ) ) ,
UniqueConstraint ( " user " , " cardId " , name = " ongeki_user_card_uk " ) ,
2023-03-09 17:38:58 +01:00
mysql_charset = " utf8mb4 " ,
2023-02-17 07:02:21 +01:00
)
deck = Table (
" ongeki_user_deck " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
Column ( " user " , ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ) ,
Column ( " deckId " , Integer ) ,
Column ( " cardId1 " , Integer ) ,
Column ( " cardId2 " , Integer ) ,
Column ( " cardId3 " , Integer ) ,
UniqueConstraint ( " user " , " deckId " , name = " ongeki_user_deck_uk " ) ,
2023-03-09 17:38:58 +01:00
mysql_charset = " utf8mb4 " ,
2023-02-17 07:02:21 +01:00
)
character = Table (
" ongeki_user_character " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
Column ( " user " , ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ) ,
Column ( " characterId " , Integer ) ,
Column ( " costumeId " , Integer ) ,
Column ( " attachmentId " , Integer ) ,
Column ( " playCount " , Integer ) ,
Column ( " intimateLevel " , Integer ) ,
Column ( " intimateCount " , Integer ) ,
Column ( " intimateCountRewarded " , Integer ) ,
Column ( " intimateCountDate " , String ( 25 ) ) ,
Column ( " isNew " , Boolean ) ,
UniqueConstraint ( " user " , " characterId " , name = " ongeki_user_character_uk " ) ,
2023-03-09 17:38:58 +01:00
mysql_charset = " utf8mb4 " ,
2023-02-17 07:02:21 +01:00
)
2023-03-09 17:38:58 +01:00
boss = Table (
2023-02-17 07:02:21 +01:00
" ongeki_user_boss " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
Column ( " user " , ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ) ,
Column ( " musicId " , Integer ) ,
Column ( " damage " , Integer ) ,
Column ( " isClear " , Boolean ) ,
Column ( " eventId " , Integer ) ,
UniqueConstraint ( " user " , " musicId " , " eventId " , name = " ongeki_user_boss_uk " ) ,
2023-03-09 17:38:58 +01:00
mysql_charset = " utf8mb4 " ,
2023-02-17 07:02:21 +01:00
)
2023-03-09 17:38:58 +01:00
story = Table (
2023-02-17 07:02:21 +01:00
" ongeki_user_story " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
Column ( " user " , ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ) ,
Column ( " storyId " , Integer ) ,
Column ( " jewelCount " , Integer ) ,
Column ( " lastChapterId " , Integer ) ,
Column ( " lastPlayMusicId " , Integer ) ,
Column ( " lastPlayMusicCategory " , Integer ) ,
Column ( " lastPlayMusicLevel " , Integer ) ,
UniqueConstraint ( " user " , " storyId " , name = " ongeki_user_story_uk " ) ,
2023-03-09 17:38:58 +01:00
mysql_charset = " utf8mb4 " ,
2023-02-17 07:02:21 +01:00
)
chapter = Table (
" ongeki_user_chapter " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
Column ( " user " , ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ) ,
Column ( " chapterId " , Integer ) ,
Column ( " jewelCount " , Integer ) ,
Column ( " isStoryWatched " , Boolean ) ,
Column ( " isClear " , Boolean ) ,
Column ( " lastPlayMusicId " , Integer ) ,
Column ( " lastPlayMusicCategory " , Integer ) ,
Column ( " lastPlayMusicLevel " , Integer ) ,
Column ( " skipTiming1 " , Integer ) ,
Column ( " skipTiming2 " , Integer ) ,
UniqueConstraint ( " user " , " chapterId " , name = " ongeki_user_chapter_uk " ) ,
2023-03-09 17:38:58 +01:00
mysql_charset = " utf8mb4 " ,
2023-02-17 07:02:21 +01:00
)
2023-03-03 06:00:22 +01:00
memorychapter = Table (
" ongeki_user_memorychapter " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
Column ( " user " , ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ) ,
Column ( " chapterId " , Integer ) ,
Column ( " gaugeId " , Integer ) ,
Column ( " gaugeNum " , Integer ) ,
Column ( " jewelCount " , Integer ) ,
Column ( " isStoryWatched " , Boolean ) ,
Column ( " isBossWatched " , Boolean ) ,
Column ( " isDialogWatched " , Boolean ) ,
Column ( " isEndingWatched " , Boolean ) ,
Column ( " isClear " , Boolean ) ,
Column ( " lastPlayMusicId " , Integer ) ,
Column ( " lastPlayMusicLevel " , Integer ) ,
Column ( " lastPlayMusicCategory " , Integer ) ,
UniqueConstraint ( " user " , " chapterId " , name = " ongeki_user_memorychapter_uk " ) ,
2023-03-09 17:38:58 +01:00
mysql_charset = " utf8mb4 " ,
2023-03-03 06:00:22 +01:00
)
2023-02-17 07:02:21 +01:00
item = Table (
" ongeki_user_item " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
Column ( " user " , ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ) ,
Column ( " itemKind " , Integer ) ,
Column ( " itemId " , Integer ) ,
Column ( " stock " , Integer ) ,
Column ( " isValid " , Boolean ) ,
UniqueConstraint ( " user " , " itemKind " , " itemId " , name = " ongeki_user_item_uk " ) ,
2023-03-09 17:38:58 +01:00
mysql_charset = " utf8mb4 " ,
2023-02-17 07:02:21 +01:00
)
music_item = Table (
" ongeki_user_music_item " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
Column ( " user " , ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ) ,
Column ( " musicId " , Integer ) ,
Column ( " status " , Integer ) ,
UniqueConstraint ( " user " , " musicId " , name = " ongeki_user_music_item_uk " ) ,
2023-03-09 17:38:58 +01:00
mysql_charset = " utf8mb4 " ,
2023-02-17 07:02:21 +01:00
)
login_bonus = Table (
" ongeki_user_login_bonus " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
Column ( " user " , ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ) ,
Column ( " bonusId " , Integer ) ,
Column ( " bonusCount " , Integer ) ,
Column ( " lastUpdateDate " , String ( 25 ) ) ,
UniqueConstraint ( " user " , " bonusId " , name = " ongeki_user_login_bonus_uk " ) ,
2023-03-09 17:38:58 +01:00
mysql_charset = " utf8mb4 " ,
2023-02-17 07:02:21 +01:00
)
event_point = Table (
" ongeki_user_event_point " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
Column ( " user " , ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ) ,
2023-11-07 04:38:04 +01:00
Column ( " version " , Integer , nullable = False ) ,
Column ( " eventId " , Integer , nullable = False ) ,
Column ( " point " , Integer , nullable = False ) ,
2023-11-05 18:09:58 +01:00
Column ( " rank " , Integer ) ,
2023-11-07 04:38:04 +01:00
Column ( " type " , Integer , nullable = False ) ,
2023-11-05 18:09:58 +01:00
Column ( " date " , String ( 25 ) ) ,
2023-02-17 07:02:21 +01:00
Column ( " isRankingRewarded " , Boolean ) ,
UniqueConstraint ( " user " , " eventId " , name = " ongeki_user_event_point_uk " ) ,
2023-03-09 17:38:58 +01:00
mysql_charset = " utf8mb4 " ,
2023-02-17 07:02:21 +01:00
)
mission_point = Table (
" ongeki_user_mission_point " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
Column ( " user " , ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ) ,
2023-11-09 02:40:57 +01:00
Column ( " version " , Integer ) ,
2023-02-17 07:02:21 +01:00
Column ( " eventId " , Integer ) ,
Column ( " point " , Integer ) ,
UniqueConstraint ( " user " , " eventId " , name = " ongeki_user_mission_point_uk " ) ,
2023-03-09 17:38:58 +01:00
mysql_charset = " utf8mb4 " ,
2023-02-17 07:02:21 +01:00
)
scenerio = Table (
" ongeki_user_scenerio " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
Column ( " user " , ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ) ,
Column ( " scenarioId " , Integer ) ,
Column ( " playCount " , Integer ) ,
UniqueConstraint ( " user " , " scenarioId " , name = " ongeki_user_scenerio_uk " ) ,
2023-03-09 17:38:58 +01:00
mysql_charset = " utf8mb4 " ,
2023-02-17 07:02:21 +01:00
)
trade_item = Table (
" ongeki_user_trade_item " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
Column ( " user " , ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ) ,
Column ( " chapterId " , Integer ) ,
Column ( " tradeItemId " , Integer ) ,
Column ( " tradeCount " , Integer ) ,
2023-03-09 17:38:58 +01:00
UniqueConstraint (
" user " , " chapterId " , " tradeItemId " , name = " ongeki_user_trade_item_uk "
) ,
mysql_charset = " utf8mb4 " ,
2023-02-17 07:02:21 +01:00
)
event_music = Table (
" ongeki_user_event_music " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
Column ( " user " , ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ) ,
Column ( " eventId " , Integer ) ,
Column ( " type " , Integer ) ,
Column ( " musicId " , Integer ) ,
Column ( " level " , Integer ) ,
Column ( " techScoreMax " , Integer ) ,
Column ( " platinumScoreMax " , Integer ) ,
Column ( " techRecordDate " , String ( 25 ) ) ,
Column ( " isTechNewRecord " , Boolean ) ,
2023-03-09 17:38:58 +01:00
UniqueConstraint (
" user " , " eventId " , " type " , " musicId " , " level " , name = " ongeki_user_event_music "
) ,
mysql_charset = " utf8mb4 " ,
2023-02-17 07:02:21 +01:00
)
tech_event = Table (
" ongeki_user_tech_event " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
Column ( " user " , ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ) ,
2023-11-07 04:38:04 +01:00
Column ( " version " , Integer , nullable = False ) ,
Column ( " eventId " , Integer , nullable = False ) ,
Column ( " totalTechScore " , Integer , nullable = False ) ,
Column ( " totalPlatinumScore " , Integer , nullable = False ) ,
2023-02-17 07:02:21 +01:00
Column ( " techRecordDate " , String ( 25 ) ) ,
Column ( " isRankingRewarded " , Boolean ) ,
Column ( " isTotalTechNewRecord " , Boolean ) ,
UniqueConstraint ( " user " , " eventId " , name = " ongeki_user_tech_event_uk " ) ,
2023-03-09 17:38:58 +01:00
mysql_charset = " utf8mb4 " ,
2023-02-17 07:02:21 +01:00
)
2023-11-05 18:09:58 +01:00
tech_ranking = Table (
" ongeki_tech_event_ranking " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
Column ( " user " , ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) , nullable = False ) ,
2023-11-07 04:38:04 +01:00
Column ( " version " , Integer , nullable = False ) ,
2023-11-05 18:09:58 +01:00
Column ( " date " , String ( 25 ) ) ,
2023-11-07 04:38:04 +01:00
Column ( " eventId " , Integer , nullable = False ) ,
2023-11-05 18:09:58 +01:00
Column ( " rank " , Integer ) ,
2023-11-07 04:38:04 +01:00
Column ( " totalPlatinumScore " , Integer , nullable = False ) ,
Column ( " totalTechScore " , Integer , nullable = False ) ,
2023-11-05 18:09:58 +01:00
UniqueConstraint ( " user " , " eventId " , name = " ongeki_tech_event_ranking_uk " ) ,
mysql_charset = " utf8mb4 " ,
)
2023-03-03 23:46:29 +01:00
gacha = Table (
" ongeki_user_gacha " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
2023-03-09 17:38:58 +01:00
Column (
" user " ,
ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ,
nullable = False ,
) ,
2023-03-03 23:46:29 +01:00
Column ( " gachaId " , Integer , nullable = False ) ,
Column ( " totalGachaCnt " , Integer , server_default = " 0 " ) ,
Column ( " ceilingGachaCnt " , Integer , server_default = " 0 " ) ,
Column ( " selectPoint " , Integer , server_default = " 0 " ) ,
Column ( " useSelectPoint " , Integer , server_default = " 0 " ) ,
Column ( " dailyGachaCnt " , Integer , server_default = " 0 " ) ,
Column ( " fiveGachaCnt " , Integer , server_default = " 0 " ) ,
Column ( " elevenGachaCnt " , Integer , server_default = " 0 " ) ,
Column ( " dailyGachaDate " , TIMESTAMP , nullable = False , server_default = func . now ( ) ) ,
UniqueConstraint ( " user " , " gachaId " , name = " ongeki_user_gacha_uk " ) ,
2023-03-09 17:38:58 +01:00
mysql_charset = " utf8mb4 " ,
2023-03-03 23:46:29 +01:00
)
gacha_supply = Table (
" ongeki_user_gacha_supply " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
2023-03-09 17:38:58 +01:00
Column (
" user " ,
ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ,
nullable = False ,
) ,
2023-03-03 23:46:29 +01:00
Column ( " cardId " , Integer , nullable = False ) ,
UniqueConstraint ( " user " , " cardId " , name = " ongeki_user_gacha_supply_uk " ) ,
2023-03-09 17:38:58 +01:00
mysql_charset = " utf8mb4 " ,
2023-03-03 23:46:29 +01:00
)
print_detail = Table (
" ongeki_user_print_detail " ,
metadata ,
Column ( " id " , Integer , primary_key = True , nullable = False ) ,
2023-03-09 17:38:58 +01:00
Column (
" user " ,
ForeignKey ( " aime_user.id " , ondelete = " cascade " , onupdate = " cascade " ) ,
nullable = False ,
) ,
2023-03-03 23:46:29 +01:00
Column ( " cardId " , Integer , nullable = False ) ,
Column ( " cardType " , Integer , server_default = " 0 " ) ,
Column ( " printDate " , TIMESTAMP , nullable = False ) ,
Column ( " serialId " , String ( 20 ) , nullable = False ) ,
Column ( " placeId " , Integer , nullable = False ) ,
Column ( " clientId " , String ( 11 ) , nullable = False ) ,
Column ( " printerSerialId " , String ( 20 ) , nullable = False ) ,
Column ( " isHolograph " , Boolean , server_default = " 0 " ) ,
Column ( " isAutographed " , Boolean , server_default = " 0 " ) ,
Column ( " printOption1 " , Boolean , server_default = " 1 " ) ,
Column ( " printOption2 " , Boolean , server_default = " 1 " ) ,
Column ( " printOption3 " , Boolean , server_default = " 1 " ) ,
Column ( " printOption4 " , Boolean , server_default = " 1 " ) ,
Column ( " printOption5 " , Boolean , server_default = " 1 " ) ,
Column ( " printOption6 " , Boolean , server_default = " 1 " ) ,
Column ( " printOption7 " , Boolean , server_default = " 1 " ) ,
Column ( " printOption8 " , Boolean , server_default = " 1 " ) ,
Column ( " printOption9 " , Boolean , server_default = " 1 " ) ,
Column ( " printOption10 " , Boolean , server_default = " 0 " ) ,
UniqueConstraint ( " serialId " , name = " ongeki_user_print_detail_uk " ) ,
2023-03-09 17:38:58 +01:00
mysql_charset = " utf8mb4 " ,
2023-03-03 23:46:29 +01:00
)
2023-03-09 17:38:58 +01:00
class OngekiItemData ( BaseData ) :
2023-02-17 07:02:21 +01:00
def put_card ( self , aime_id : int , card_data : Dict ) - > Optional [ int ] :
card_data [ " user " ] = aime_id
sql = insert ( card ) . values ( * * card_data )
conflict = sql . on_duplicate_key_update ( * * card_data )
result = self . execute ( conflict )
if result is None :
2023-08-08 16:17:56 +02:00
self . logger . warning ( f " put_card: Failed to update! aime_id: { aime_id } " )
2023-02-17 07:02:21 +01:00
return None
return result . lastrowid
def get_cards ( self , aime_id : int ) - > Optional [ List [ Dict ] ] :
sql = select ( card ) . where ( card . c . user == aime_id )
result = self . execute ( sql )
2023-03-09 17:38:58 +01:00
if result is None :
return None
2023-02-17 07:02:21 +01:00
return result . fetchall ( )
def put_character ( self , aime_id : int , character_data : Dict ) - > Optional [ int ] :
character_data [ " user " ] = aime_id
sql = insert ( character ) . values ( * * character_data )
conflict = sql . on_duplicate_key_update ( * * character_data )
result = self . execute ( conflict )
if result is None :
2023-08-08 16:17:56 +02:00
self . logger . warning ( f " put_character: Failed to update! aime_id: { aime_id } " )
2023-02-17 07:02:21 +01:00
return None
return result . lastrowid
2023-03-09 17:38:58 +01:00
2023-02-17 07:02:21 +01:00
def get_characters ( self , aime_id : int ) - > Optional [ List [ Dict ] ] :
sql = select ( character ) . where ( character . c . user == aime_id )
result = self . execute ( sql )
2023-03-09 17:38:58 +01:00
if result is None :
return None
2023-02-17 07:02:21 +01:00
return result . fetchall ( )
def put_deck ( self , aime_id : int , deck_data : Dict ) - > Optional [ int ] :
deck_data [ " user " ] = aime_id
sql = insert ( deck ) . values ( * * deck_data )
conflict = sql . on_duplicate_key_update ( * * deck_data )
result = self . execute ( conflict )
if result is None :
2023-08-08 16:17:56 +02:00
self . logger . warning ( f " put_deck: Failed to update! aime_id: { aime_id } " )
2023-02-17 07:02:21 +01:00
return None
return result . lastrowid
2023-03-09 17:38:58 +01:00
2023-02-17 07:02:21 +01:00
def get_deck ( self , aime_id : int , deck_id : int ) - > Optional [ Dict ] :
sql = select ( deck ) . where ( and_ ( deck . c . user == aime_id , deck . c . deckId == deck_id ) )
result = self . execute ( sql )
2023-03-09 17:38:58 +01:00
if result is None :
return None
2023-02-17 07:02:21 +01:00
return result . fetchone ( )
2023-03-09 17:38:58 +01:00
2023-02-17 07:02:21 +01:00
def get_decks ( self , aime_id : int ) - > Optional [ List [ Dict ] ] :
sql = select ( deck ) . where ( deck . c . user == aime_id )
result = self . execute ( sql )
2023-03-09 17:38:58 +01:00
if result is None :
return None
2023-02-17 07:02:21 +01:00
return result . fetchall ( )
def put_boss ( self , aime_id : int , boss_data : Dict ) - > Optional [ int ] :
boss_data [ " user " ] = aime_id
sql = insert ( boss ) . values ( * * boss_data )
conflict = sql . on_duplicate_key_update ( * * boss_data )
result = self . execute ( conflict )
if result is None :
2023-08-08 16:17:56 +02:00
self . logger . warning ( f " put_boss: Failed to update! aime_id: { aime_id } " )
2023-02-17 07:02:21 +01:00
return None
return result . lastrowid
2023-03-09 17:38:58 +01:00
2023-02-17 07:02:21 +01:00
def put_story ( self , aime_id : int , story_data : Dict ) - > Optional [ int ] :
story_data [ " user " ] = aime_id
sql = insert ( story ) . values ( * * story_data )
conflict = sql . on_duplicate_key_update ( * * story_data )
result = self . execute ( conflict )
if result is None :
2023-08-08 16:17:56 +02:00
self . logger . warning ( f " put_story: Failed to update! aime_id: { aime_id } " )
2023-02-17 07:02:21 +01:00
return None
return result . lastrowid
2023-03-09 17:38:58 +01:00
2023-02-17 07:02:21 +01:00
def get_stories ( self , aime_id : int ) - > Optional [ List [ Dict ] ] :
sql = select ( story ) . where ( story . c . user == aime_id )
result = self . execute ( sql )
2023-03-09 17:38:58 +01:00
if result is None :
return None
2023-02-17 07:02:21 +01:00
return result . fetchall ( )
def put_chapter ( self , aime_id : int , chapter_data : Dict ) - > Optional [ int ] :
chapter_data [ " user " ] = aime_id
sql = insert ( chapter ) . values ( * * chapter_data )
conflict = sql . on_duplicate_key_update ( * * chapter_data )
result = self . execute ( conflict )
if result is None :
2023-08-08 16:17:56 +02:00
self . logger . warning ( f " put_chapter: Failed to update! aime_id: { aime_id } " )
2023-02-17 07:02:21 +01:00
return None
return result . lastrowid
2023-03-09 17:38:58 +01:00
2023-02-17 07:02:21 +01:00
def get_chapters ( self , aime_id : int ) - > Optional [ List [ Dict ] ] :
sql = select ( chapter ) . where ( chapter . c . user == aime_id )
result = self . execute ( sql )
2023-03-09 17:38:58 +01:00
if result is None :
return None
2023-02-17 07:02:21 +01:00
return result . fetchall ( )
def put_item ( self , aime_id : int , item_data : Dict ) - > Optional [ int ] :
item_data [ " user " ] = aime_id
sql = insert ( item ) . values ( * * item_data )
conflict = sql . on_duplicate_key_update ( * * item_data )
result = self . execute ( conflict )
if result is None :
2023-08-08 16:17:56 +02:00
self . logger . warning ( f " put_item: Failed to update! aime_id: { aime_id } " )
2023-02-17 07:02:21 +01:00
return None
return result . lastrowid
2023-03-09 17:38:58 +01:00
2023-02-17 07:02:21 +01:00
def get_item ( self , aime_id : int , item_id : int , item_kind : int ) - > Optional [ Dict ] :
sql = select ( item ) . where ( and_ ( item . c . user == aime_id , item . c . itemId == item_id ) )
result = self . execute ( sql )
2023-03-09 17:38:58 +01:00
if result is None :
return None
2023-02-17 07:02:21 +01:00
return result . fetchone ( )
def get_items ( self , aime_id : int , item_kind : int = None ) - > Optional [ List [ Dict ] ] :
if item_kind is None :
sql = select ( item ) . where ( item . c . user == aime_id )
else :
2023-03-09 17:38:58 +01:00
sql = select ( item ) . where (
and_ ( item . c . user == aime_id , item . c . itemKind == item_kind )
)
2023-02-17 07:02:21 +01:00
result = self . execute ( sql )
2023-03-09 17:38:58 +01:00
if result is None :
return None
2023-02-17 07:02:21 +01:00
return result . fetchall ( )
def put_music_item ( self , aime_id : int , music_item_data : Dict ) - > Optional [ int ] :
music_item_data [ " user " ] = aime_id
sql = insert ( music_item ) . values ( * * music_item_data )
conflict = sql . on_duplicate_key_update ( * * music_item_data )
result = self . execute ( conflict )
if result is None :
2023-08-08 16:17:56 +02:00
self . logger . warning ( f " put_music_item: Failed to update! aime_id: { aime_id } " )
2023-02-17 07:02:21 +01:00
return None
return result . lastrowid
2023-03-09 17:38:58 +01:00
2023-02-17 07:02:21 +01:00
def get_music_items ( self , aime_id : int ) - > Optional [ List [ Dict ] ] :
sql = select ( music_item ) . where ( music_item . c . user == aime_id )
result = self . execute ( sql )
2023-03-09 17:38:58 +01:00
if result is None :
return None
2023-02-17 07:02:21 +01:00
return result . fetchall ( )
def put_login_bonus ( self , aime_id : int , login_bonus_data : Dict ) - > Optional [ int ] :
login_bonus_data [ " user " ] = aime_id
sql = insert ( login_bonus ) . values ( * * login_bonus_data )
conflict = sql . on_duplicate_key_update ( * * login_bonus_data )
result = self . execute ( conflict )
if result is None :
2023-08-08 16:17:56 +02:00
self . logger . warning ( f " put_login_bonus: Failed to update! aime_id: { aime_id } " )
2023-02-17 07:02:21 +01:00
return None
return result . lastrowid
2023-03-09 17:38:58 +01:00
2023-02-17 07:02:21 +01:00
def get_login_bonuses ( self , aime_id : int ) - > Optional [ List [ Dict ] ] :
sql = select ( login_bonus ) . where ( login_bonus . c . user == aime_id )
result = self . execute ( sql )
2023-03-09 17:38:58 +01:00
if result is None :
return None
2023-02-17 07:02:21 +01:00
return result . fetchall ( )
2023-11-13 03:03:04 +01:00
def put_mission_point ( self , aime_id : int , version : int , mission_point_data : Dict ) - > Optional [ int ] :
2023-11-09 02:40:57 +01:00
mission_point_data [ " version " ] = version
2023-11-15 15:09:57 +01:00
mission_point_data [ " user " ] = aime_id
2023-02-17 07:02:21 +01:00
sql = insert ( mission_point ) . values ( * * mission_point_data )
conflict = sql . on_duplicate_key_update ( * * mission_point_data )
result = self . execute ( conflict )
if result is None :
2023-08-08 16:17:56 +02:00
self . logger . warning ( f " put_mission_point: Failed to update! aime_id: { aime_id } " )
2023-02-17 07:02:21 +01:00
return None
return result . lastrowid
2023-03-09 17:38:58 +01:00
2023-11-09 02:40:57 +01:00
def get_mission_points ( self , version : int , aime_id : int ) - > Optional [ List [ Dict ] ] :
sql = select ( mission_point ) . where ( and_ ( mission_point . c . user == aime_id , mission_point . c . version == version ) )
2023-02-17 07:02:21 +01:00
result = self . execute ( sql )
2023-03-09 17:38:58 +01:00
if result is None :
return None
2023-02-17 07:02:21 +01:00
return result . fetchall ( )
2023-03-09 17:38:58 +01:00
2023-11-07 04:38:04 +01:00
def put_event_point ( self , aime_id : int , version : int , event_point_data : Dict ) - > Optional [ int ] :
2023-11-05 18:09:58 +01:00
# We update only the newest (type: 1) entry, in official spec game watches for both latest(type:1) and previous (type:2) entries to give an additional info how many ranks has player moved up or down
# This fully featured is on TODO list, at the moment we just update the tables as data comes and give out rank as request comes
2023-02-17 07:02:21 +01:00
event_point_data [ " user " ] = aime_id
2023-11-07 04:38:04 +01:00
event_point_data [ " version " ] = version
2023-11-05 18:09:58 +01:00
event_point_data [ " type " ] = 1
event_point_time = datetime . now ( )
event_point_data [ " date " ] = datetime . strftime ( event_point_time , " % Y- % m- %d % H: % M " )
2023-02-17 07:02:21 +01:00
sql = insert ( event_point ) . values ( * * event_point_data )
conflict = sql . on_duplicate_key_update ( * * event_point_data )
result = self . execute ( conflict )
if result is None :
2023-08-08 16:17:56 +02:00
self . logger . warning ( f " put_event_point: Failed to update! aime_id: { aime_id } " )
2023-02-17 07:02:21 +01:00
return None
return result . lastrowid
2023-03-09 17:38:58 +01:00
2023-02-17 07:02:21 +01:00
def get_event_points ( self , aime_id : int ) - > Optional [ List [ Dict ] ] :
sql = select ( event_point ) . where ( event_point . c . user == aime_id )
result = self . execute ( sql )
2023-03-09 17:38:58 +01:00
if result is None :
return None
2023-02-17 07:02:21 +01:00
return result . fetchall ( )
def put_scenerio ( self , aime_id : int , scenerio_data : Dict ) - > Optional [ int ] :
scenerio_data [ " user " ] = aime_id
sql = insert ( scenerio ) . values ( * * scenerio_data )
conflict = sql . on_duplicate_key_update ( * * scenerio_data )
result = self . execute ( conflict )
if result is None :
2023-08-08 16:17:56 +02:00
self . logger . warning ( f " put_scenerio: Failed to update! aime_id: { aime_id } " )
2023-02-17 07:02:21 +01:00
return None
return result . lastrowid
2023-03-09 17:38:58 +01:00
2023-02-17 07:02:21 +01:00
def get_scenerios ( self , aime_id : int ) - > Optional [ List [ Dict ] ] :
sql = select ( scenerio ) . where ( scenerio . c . user == aime_id )
result = self . execute ( sql )
2023-03-09 17:38:58 +01:00
if result is None :
return None
2023-02-17 07:02:21 +01:00
return result . fetchall ( )
def put_trade_item ( self , aime_id : int , trade_item_data : Dict ) - > Optional [ int ] :
trade_item_data [ " user " ] = aime_id
sql = insert ( trade_item ) . values ( * * trade_item_data )
conflict = sql . on_duplicate_key_update ( * * trade_item_data )
result = self . execute ( conflict )
if result is None :
2023-08-08 16:17:56 +02:00
self . logger . warning ( f " put_trade_item: Failed to update! aime_id: { aime_id } " )
2023-02-17 07:02:21 +01:00
return None
return result . lastrowid
2023-03-09 17:38:58 +01:00
2023-02-17 07:02:21 +01:00
def get_trade_items ( self , aime_id : int ) - > Optional [ List [ Dict ] ] :
sql = select ( trade_item ) . where ( trade_item . c . user == aime_id )
result = self . execute ( sql )
2023-03-09 17:38:58 +01:00
if result is None :
return None
2023-02-17 07:02:21 +01:00
return result . fetchall ( )
2023-03-09 17:38:58 +01:00
2023-02-17 07:02:21 +01:00
def put_event_music ( self , aime_id : int , event_music_data : Dict ) - > Optional [ int ] :
event_music_data [ " user " ] = aime_id
sql = insert ( event_music ) . values ( * * event_music_data )
conflict = sql . on_duplicate_key_update ( * * event_music_data )
result = self . execute ( conflict )
if result is None :
2023-08-08 16:17:56 +02:00
self . logger . warning ( f " put_event_music: Failed to update! aime_id: { aime_id } " )
2023-02-17 07:02:21 +01:00
return None
return result . lastrowid
2023-03-09 17:38:58 +01:00
2023-02-17 07:02:21 +01:00
def get_event_music ( self , aime_id : int ) - > Optional [ List [ Dict ] ] :
sql = select ( event_music ) . where ( event_music . c . user == aime_id )
result = self . execute ( sql )
2023-03-09 17:38:58 +01:00
if result is None :
return None
2023-02-17 07:02:21 +01:00
return result . fetchall ( )
2023-11-26 00:12:23 +01:00
def put_tech_event ( self , aime_id : int , version : int , tech_event_data : Dict ) - > Optional [ int ] :
2023-02-17 07:02:21 +01:00
tech_event_data [ " user " ] = aime_id
2023-11-26 00:12:23 +01:00
tech_event_data [ " version " ] = version
2023-02-17 07:02:21 +01:00
sql = insert ( tech_event ) . values ( * * tech_event_data )
conflict = sql . on_duplicate_key_update ( * * tech_event_data )
result = self . execute ( conflict )
if result is None :
2023-08-08 16:17:56 +02:00
self . logger . warning ( f " put_tech_event: Failed to update! aime_id: { aime_id } " )
2023-02-17 07:02:21 +01:00
return None
return result . lastrowid
2023-03-09 17:38:58 +01:00
2023-11-26 00:12:23 +01:00
def put_tech_event_ranking ( self , aime_id : int , version : int , tech_event_data : Dict ) - > Optional [ int ] :
2023-11-05 18:09:58 +01:00
tech_event_data [ " user " ] = aime_id
2023-11-07 04:38:04 +01:00
tech_event_data [ " version " ] = version
2023-11-05 18:09:58 +01:00
tech_event_data . pop ( " isRankingRewarded " )
tech_event_data . pop ( " isTotalTechNewRecord " )
tech_event_data [ " date " ] = tech_event_data . pop ( " techRecordDate " )
tech_event_data [ " rank " ] = 0
sql = insert ( tech_ranking ) . values ( * * tech_event_data )
conflict = sql . on_duplicate_key_update ( * * tech_event_data )
result = self . execute ( conflict )
if result is None :
self . logger . warning ( f " put_tech_event_ranking: Failed to update ranking! aime_id { aime_id } " )
return None
return result . lastrowid
2023-11-07 04:38:04 +01:00
def get_tech_event ( self , version : int , aime_id : int ) - > Optional [ List [ Dict ] ] :
sql = select ( tech_event ) . where ( and_ ( tech_event . c . user == aime_id , tech_event . c . version == version ) )
2023-02-17 07:02:21 +01:00
result = self . execute ( sql )
2023-03-09 17:38:58 +01:00
if result is None :
return None
2023-02-17 07:02:21 +01:00
return result . fetchall ( )
def get_bosses ( self , aime_id : int ) - > Optional [ List [ Dict ] ] :
sql = select ( boss ) . where ( boss . c . user == aime_id )
result = self . execute ( sql )
2023-03-09 17:38:58 +01:00
if result is None :
return None
2023-03-03 06:00:22 +01:00
return result . fetchall ( )
2023-03-03 23:46:29 +01:00
2023-03-09 17:38:58 +01:00
def put_memorychapter (
self , aime_id : int , memorychapter_data : Dict
) - > Optional [ int ] :
2023-03-03 06:00:22 +01:00
memorychapter_data [ " user " ] = aime_id
sql = insert ( memorychapter ) . values ( * * memorychapter_data )
conflict = sql . on_duplicate_key_update ( * * memorychapter_data )
result = self . execute ( conflict )
if result is None :
2023-08-08 16:17:56 +02:00
self . logger . warning ( f " put_memorychapter: Failed to update! aime_id: { aime_id } " )
2023-03-03 06:00:22 +01:00
return None
return result . lastrowid
2023-03-03 23:46:29 +01:00
2023-03-03 06:00:22 +01:00
def get_memorychapters ( self , aime_id : int ) - > Optional [ List [ Dict ] ] :
sql = select ( memorychapter ) . where ( memorychapter . c . user == aime_id )
result = self . execute ( sql )
2023-03-03 23:46:29 +01:00
if result is None :
return None
return result . fetchall ( )
def get_user_gacha ( self , aime_id : int , gacha_id : int ) - > Optional [ Row ] :
2023-03-09 17:38:58 +01:00
sql = gacha . select ( and_ ( gacha . c . user == aime_id , gacha . c . gachaId == gacha_id ) )
2023-03-03 23:46:29 +01:00
result = self . execute ( sql )
if result is None :
return None
return result . fetchone ( )
def get_user_gachas ( self , aime_id : int ) - > Optional [ List [ Row ] ] :
sql = gacha . select ( gacha . c . user == aime_id )
result = self . execute ( sql )
if result is None :
return None
return result . fetchall ( )
def get_user_gacha_supplies ( self , aime_id : int ) - > Optional [ List [ Row ] ] :
sql = gacha_supply . select ( gacha_supply . c . user == aime_id )
result = self . execute ( sql )
if result is None :
return None
return result . fetchall ( )
def put_user_gacha ( self , aime_id : int , gacha_id : int , * * data ) - > Optional [ int ] :
2023-03-09 17:38:58 +01:00
sql = insert ( gacha ) . values ( user = aime_id , gachaId = gacha_id , * * data )
2023-03-03 23:46:29 +01:00
2023-03-09 17:38:58 +01:00
conflict = sql . on_duplicate_key_update ( user = aime_id , gachaId = gacha_id , * * data )
2023-03-03 23:46:29 +01:00
result = self . execute ( conflict )
if result is None :
2023-08-08 16:17:56 +02:00
self . logger . warning ( f " put_user_gacha: Failed to insert! aime_id: { aime_id } " )
2023-03-03 23:46:29 +01:00
return None
return result . lastrowid
2023-03-09 17:38:58 +01:00
def put_user_print_detail (
self , aime_id : int , serial_id : str , user_print_data : Dict
) - > Optional [ int ] :
2023-03-03 23:46:29 +01:00
sql = insert ( print_detail ) . values (
2023-03-09 17:38:58 +01:00
user = aime_id , serialId = serial_id , * * user_print_data
)
2023-03-03 23:46:29 +01:00
2023-04-24 03:04:52 +02:00
conflict = sql . on_duplicate_key_update ( user = aime_id , * * user_print_data )
2023-03-03 23:46:29 +01:00
result = self . execute ( conflict )
if result is None :
2023-08-08 16:17:56 +02:00
self . logger . warning (
2023-03-09 17:38:58 +01:00
f " put_user_print_detail: Failed to insert! aime_id: { aime_id } "
)
2023-03-03 23:46:29 +01:00
return None
return result . lastrowid
2023-11-05 18:09:58 +01:00
2023-11-07 04:38:04 +01:00
def get_ranking_event_ranks ( self , version : int , aime_id : int ) - > Optional [ List [ Dict ] ] :
2023-11-05 18:09:58 +01:00
# Calculates player rank on GameRequest from server, and sends it back, official spec would rank players in maintenance period, on TODO list
2023-11-07 04:38:04 +01:00
sql = select ( event_point . c . id , event_point . c . user , event_point . c . eventId , event_point . c . type , func . row_number ( ) . over ( partition_by = event_point . c . eventId , order_by = event_point . c . point . desc ( ) ) . label ( ' rank ' ) , event_point . c . date , event_point . c . point ) . where ( event_point . c . version == version )
2023-11-05 18:09:58 +01:00
result = self . execute ( sql )
if result is None :
self . logger . error ( f " failed to rank aime_id: { aime_id } ranking event positions " )
return None
return result . fetchall ( )
2023-11-07 04:38:04 +01:00
def get_tech_event_ranking ( self , version : int , aime_id : int ) - > Optional [ List [ Dict ] ] :
sql = select ( tech_ranking . c . id , tech_ranking . c . user , tech_ranking . c . date , tech_ranking . c . eventId , func . row_number ( ) . over ( partition_by = tech_ranking . c . eventId , order_by = [ tech_ranking . c . totalTechScore . desc ( ) , tech_ranking . c . totalPlatinumScore . desc ( ) ] ) . label ( ' rank ' ) , tech_ranking . c . totalTechScore , tech_ranking . c . totalPlatinumScore ) . where ( tech_ranking . c . version == version )
2023-11-05 18:09:58 +01:00
result = self . execute ( sql )
if result is None :
self . logger . warning ( f " aime_id: { aime_id } has no tech ranking ranks " )
return None
return result . fetchall ( )