from app import db, ma import enum class Players(enum.Enum): BLACK = "The player taking black stones" WHITE = "The player taking white stones" VOID = "The game was a draw or voided" class WinType(enum.Enum): DRAW = "The game is a draw" RESIGN = "The game ended in resignation" SCORE = "The game ended by counting points" TIME = "The game ended in loss by time out" VOID = "The game was suspended" class Game(db.Model): __tablename__ = "games" __table_args__ = {'extend_existing': True} id = db.Column(db.Integer, primary_key=True, autoincrement=True) date = db.Column(db.DateTime()) komi = db.Column(db.Numeric(2,1), nullable=False) handicap = db.Column(db.Integer, nullable=False) board_size = db.Column(db.Integer, nullable=False) win_type = db.Column(db.Enum(WinType)) winner = db.Column(db.Enum(Players)) score = db.Column(db.Numeric(2,1)) white_captures = db.Column(db.Integer) black_captures = db.Column(db.Integer) application = db.Column(db.String(40)) application_version = db.Column(db.String(20)) event = db.Column(db.String(40)) name = db.Column(db.String(40)) description = db.Column(db.String(200)) round = db.Column(db.Integer) # foreign keys game_room = db.Column(db.Integer, db.ForeignKey("game_rooms.id")) time_settings = db.Column(db.Integer, db.ForeignKey("time_settings.id")) player_black = db.Column(db.Integer, db.ForeignKey("users.id")) player_white = db.Column(db.Integer, db.ForeignKey("users.id")) def __init__(self): pass