55 lines
2.0 KiB
Python
55 lines
2.0 KiB
Python
|
from typing import Dict, Optional
|
||
|
from sqlalchemy import Table, Column, UniqueConstraint, PrimaryKeyConstraint, and_
|
||
|
from sqlalchemy.types import Integer, String, TIMESTAMP, Boolean, JSON
|
||
|
from sqlalchemy.schema import ForeignKey
|
||
|
from sqlalchemy.sql import func, select
|
||
|
from sqlalchemy.dialects.mysql import insert
|
||
|
|
||
|
from core.data.schema import BaseData, metadata
|
||
|
|
||
|
gp_log = Table(
|
||
|
"ongeki_gp_log",
|
||
|
metadata,
|
||
|
Column("id", Integer, primary_key=True, nullable=False),
|
||
|
Column("user", ForeignKey("aime_user.id", ondelete="cascade", onupdate="cascade")),
|
||
|
Column("usedCredit", Integer),
|
||
|
Column("placeName", String(255)),
|
||
|
Column("trxnDate", String(255)),
|
||
|
Column("placeId", Integer), # Making this an FK would mess with people playing with default KC
|
||
|
Column("kind", Integer),
|
||
|
Column("pattern", Integer),
|
||
|
Column("currentGP", Integer),
|
||
|
mysql_charset='utf8mb4'
|
||
|
)
|
||
|
|
||
|
session_log = Table(
|
||
|
"ongeki_session_log",
|
||
|
metadata,
|
||
|
Column("id", Integer, primary_key=True, nullable=False),
|
||
|
Column("user", ForeignKey("aime_user.id", ondelete="cascade", onupdate="cascade")),
|
||
|
Column("sortNumber", Integer),
|
||
|
Column("placeId", Integer),
|
||
|
Column("playDate", String(10)),
|
||
|
Column("userPlayDate", String(25)),
|
||
|
Column("isPaid", Boolean),
|
||
|
mysql_charset='utf8mb4'
|
||
|
)
|
||
|
|
||
|
class OngekiLogData(BaseData):
|
||
|
def put_gp_log(self, aime_id: Optional[int], used_credit: int, place_name: str, tx_date: str, place_id: int,
|
||
|
kind: int, pattern: int, current_gp: int) -> Optional[int]:
|
||
|
sql = insert(gp_log).values(
|
||
|
user=aime_id,
|
||
|
usedCredit=used_credit,
|
||
|
placeName=place_name,
|
||
|
trxnDate=tx_date,
|
||
|
placeId=place_id,
|
||
|
kind=kind,
|
||
|
pattern=pattern,
|
||
|
currentGP=current_gp,
|
||
|
)
|
||
|
|
||
|
result = self.execute(sql)
|
||
|
if result is None:
|
||
|
self.logger.warn(f"put_gp_log: Failed to insert GP log! aime_id: {aime_id} kind {kind} pattern {pattern} current_gp {current_gp}")
|
||
|
return result.lastrowid
|