mirror of
https://github.com/RYGhub/royalnet.git
synced 2024-11-24 03:54:20 +00:00
40 lines
1.1 KiB
Python
40 lines
1.1 KiB
Python
from sqlalchemy import Column, \
|
|
Integer, \
|
|
ForeignKey
|
|
from sqlalchemy.orm import relationship, backref
|
|
from sqlalchemy.ext.declarative import declared_attr
|
|
|
|
|
|
class TriviaScore:
|
|
__tablename__ = "triviascores"
|
|
|
|
@declared_attr
|
|
def royal_id(self):
|
|
return Column(Integer, ForeignKey("users.uid"), primary_key=True)
|
|
|
|
@declared_attr
|
|
def royal(self):
|
|
return relationship("User", backref=backref("trivia_score", uselist=False))
|
|
|
|
@declared_attr
|
|
def correct_answers(self):
|
|
return Column(Integer, nullable=False, default=0)
|
|
|
|
@declared_attr
|
|
def wrong_answers(self):
|
|
return Column(Integer, nullable=False, default=0)
|
|
|
|
@property
|
|
def total_answers(self):
|
|
return self.correct_answers + self.wrong_answers
|
|
|
|
@property
|
|
def offset(self):
|
|
return self.correct_answers - self.wrong_answers
|
|
|
|
@property
|
|
def correct_rate(self):
|
|
return self.correct_answers / self.total_answers
|
|
|
|
def __repr__(self):
|
|
return f"<TriviaScore of {self.royal}: ({self.correct_answers}|{self.wrong_answers})>"
|