mirror of
https://github.com/RYGhub/royalnet.git
synced 2024-11-27 13:34:28 +00:00
Create a recursive monster
This commit is contained in:
parent
ff8de20667
commit
262045108b
1 changed files with 56 additions and 18 deletions
74
db.py
74
db.py
|
@ -8,6 +8,7 @@ from sqlalchemy.orm import sessionmaker, relationship
|
||||||
from sqlalchemy.ext.hybrid import hybrid_property
|
from sqlalchemy.ext.hybrid import hybrid_property
|
||||||
from sqlalchemy import Column, BigInteger, Integer, String, DateTime, ForeignKey, Float, Enum, create_engine, \
|
from sqlalchemy import Column, BigInteger, Integer, String, DateTime, ForeignKey, Float, Enum, create_engine, \
|
||||||
UniqueConstraint, PrimaryKeyConstraint, Boolean, LargeBinary, Text, Date, func
|
UniqueConstraint, PrimaryKeyConstraint, Boolean, LargeBinary, Text, Date, func
|
||||||
|
from sqlalchemy.inspection import inspect
|
||||||
import requests
|
import requests
|
||||||
from errors import NotFoundError, AlreadyExistingError, PrivateError
|
from errors import NotFoundError, AlreadyExistingError, PrivateError
|
||||||
import re
|
import re
|
||||||
|
@ -39,7 +40,43 @@ os.environ["COLOREDLOGS_LOG_FORMAT"] = "%(asctime)s %(levelname)s %(name)s %(mes
|
||||||
coloredlogs.install(level="DEBUG", logger=logger)
|
coloredlogs.install(level="DEBUG", logger=logger)
|
||||||
|
|
||||||
|
|
||||||
class Royal(Base):
|
def recursive_relationship_name_search(_class, keyword) -> typing.Optional[tuple]:
|
||||||
|
"""Recursively find a relationship with a given name."""
|
||||||
|
inspected = set()
|
||||||
|
|
||||||
|
def search(_mapper, chain):
|
||||||
|
inspected.add(_mapper)
|
||||||
|
relationships = _mapper.relationships
|
||||||
|
try:
|
||||||
|
return chain + (relationships[keyword],)
|
||||||
|
except KeyError:
|
||||||
|
for _relationship in set(relationships):
|
||||||
|
if _relationship.mapper in inspected:
|
||||||
|
continue
|
||||||
|
result = search(_relationship.mapper, chain + (_relationship,))
|
||||||
|
if result is not None:
|
||||||
|
return result
|
||||||
|
return None
|
||||||
|
|
||||||
|
return search(inspect(_class), tuple())
|
||||||
|
|
||||||
|
|
||||||
|
class Mini(object):
|
||||||
|
@classmethod
|
||||||
|
def mini_get_all(cls, session: Session) -> list:
|
||||||
|
return session.query(cls).all()
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def mini_get_single(cls, session: Session, **kwargs):
|
||||||
|
return session.query(cls).filter_by(**kwargs).one_or_none()
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def mini_get_single_from_royal(cls, session: Session, royal: "Royal"):
|
||||||
|
chain = recursive_relationship_name_search(cls, "royal")
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
class Royal(Base, Mini):
|
||||||
__tablename__ = "royals"
|
__tablename__ = "royals"
|
||||||
|
|
||||||
id = Column(Integer, primary_key=True)
|
id = Column(Integer, primary_key=True)
|
||||||
|
@ -66,6 +103,10 @@ class Royal(Base):
|
||||||
gravatar = libgravatar.Gravatar(self.email)
|
gravatar = libgravatar.Gravatar(self.email)
|
||||||
return gravatar.get_image(default="identicon")
|
return gravatar.get_image(default="identicon")
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def mini_get_single_from_royal(cls, session: Session, royal: "Royal"):
|
||||||
|
return royal
|
||||||
|
|
||||||
|
|
||||||
class Telegram(Base):
|
class Telegram(Base):
|
||||||
__tablename__ = "telegram"
|
__tablename__ = "telegram"
|
||||||
|
@ -112,6 +153,10 @@ class Telegram(Base):
|
||||||
else:
|
else:
|
||||||
return self.first_name
|
return self.first_name
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def mini_get_single_from_royal(cls, session: Session, royal: "Royal"):
|
||||||
|
return royal.telegram
|
||||||
|
|
||||||
|
|
||||||
class Steam(Base):
|
class Steam(Base):
|
||||||
__tablename__ = "steam"
|
__tablename__ = "steam"
|
||||||
|
@ -200,6 +245,10 @@ class Steam(Base):
|
||||||
return
|
return
|
||||||
self.most_played_game_id = j["response"]["games"][0]["appid"]
|
self.most_played_game_id = j["response"]["games"][0]["appid"]
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def mini_get_single_from_royal(cls, session: Session, royal: "Royal"):
|
||||||
|
return royal.steam
|
||||||
|
|
||||||
|
|
||||||
class RocketLeague(Base):
|
class RocketLeague(Base):
|
||||||
__tablename__ = "rocketleague"
|
__tablename__ = "rocketleague"
|
||||||
|
@ -902,23 +951,6 @@ class Reddit(Base):
|
||||||
return f"<Reddit u/{self.username}>"
|
return f"<Reddit u/{self.username}>"
|
||||||
|
|
||||||
|
|
||||||
class GameLog(Base):
|
|
||||||
__tablename__ = "gamelog"
|
|
||||||
|
|
||||||
royal_id = Column(Integer, ForeignKey("royals.id"))
|
|
||||||
royal = relationship("Royal", backref="gamelog", lazy="joined")
|
|
||||||
|
|
||||||
username = Column(String, primary_key=True)
|
|
||||||
owned_games = Column(Integer)
|
|
||||||
unfinished_games = Column(Integer)
|
|
||||||
beaten_games = Column(Integer)
|
|
||||||
completed_games = Column(Integer)
|
|
||||||
mastered_games = Column(Integer)
|
|
||||||
|
|
||||||
def __repr__(self):
|
|
||||||
return f"<GameLog {self.username}>"
|
|
||||||
|
|
||||||
|
|
||||||
class ParsedRedditPost(Base):
|
class ParsedRedditPost(Base):
|
||||||
__tablename__ = "parsedredditposts"
|
__tablename__ = "parsedredditposts"
|
||||||
|
|
||||||
|
@ -1061,12 +1093,18 @@ class Quest(Base):
|
||||||
class Terraria13(Base):
|
class Terraria13(Base):
|
||||||
__tablename__ = "terraria13"
|
__tablename__ = "terraria13"
|
||||||
|
|
||||||
|
game_name = "Terraria 13"
|
||||||
|
|
||||||
royal_id = Column(Integer, ForeignKey("royals.id"), primary_key=True)
|
royal_id = Column(Integer, ForeignKey("royals.id"), primary_key=True)
|
||||||
royal = relationship("Royal", backref="terraria13", lazy="joined")
|
royal = relationship("Royal", backref="terraria13", lazy="joined")
|
||||||
|
|
||||||
character_name = Column(String)
|
character_name = Column(String)
|
||||||
contribution = Column(Integer)
|
contribution = Column(Integer)
|
||||||
|
|
||||||
|
def __repr__(self):
|
||||||
|
return f"<Terraria13 {self.character_name} {self.contribution}>"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# If run as script, create all the tables in the db
|
# If run as script, create all the tables in the db
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
|
|
Loading…
Reference in a new issue