Implement bonus points
This commit is contained in:
parent
398b413095
commit
c38ad5611d
3 changed files with 24 additions and 5 deletions
|
@ -71,8 +71,18 @@ class Teams(db.Model):
|
||||||
return members
|
return members
|
||||||
|
|
||||||
def points(self):
|
def points(self):
|
||||||
""" TODO: Implement scoring with Bonus Points """
|
bonuses = [5, 3, 1] # TODO: Make this a setting in the web interface
|
||||||
return 0
|
points = 0
|
||||||
|
|
||||||
|
# TODO: use joins
|
||||||
|
solves = Solves.query.filter_by(tid=self.tid).all()
|
||||||
|
for solve in solves:
|
||||||
|
problem = Problems.query.filter_by(pid=solve.pid).first()
|
||||||
|
multiplier = 1
|
||||||
|
if solve.bonus != -1:
|
||||||
|
multiplier += bonuses[solve.bonus-1]/100.0
|
||||||
|
points += round(problem.value*multiplier)
|
||||||
|
return points
|
||||||
|
|
||||||
def place(self, ranked=True):
|
def place(self, ranked=True):
|
||||||
# score = db.func.sum(Problems.value).label("score")
|
# score = db.func.sum(Problems.value).label("score")
|
||||||
|
@ -139,7 +149,6 @@ class Problems(db.Model):
|
||||||
value = db.Column(db.Integer)
|
value = db.Column(db.Integer)
|
||||||
hint = db.Column(db.Text)
|
hint = db.Column(db.Text)
|
||||||
autogen = db.Column(db.Boolean)
|
autogen = db.Column(db.Boolean)
|
||||||
bonus = db.Column(db.Integer)
|
|
||||||
threshold = db.Column(db.Integer)
|
threshold = db.Column(db.Integer)
|
||||||
weightmap = db.Column(db.PickleType)
|
weightmap = db.Column(db.PickleType)
|
||||||
grader = db.Column(db.Text)
|
grader = db.Column(db.Text)
|
||||||
|
@ -152,7 +161,6 @@ class Problems(db.Model):
|
||||||
self.value = value
|
self.value = value
|
||||||
self.hint = hint
|
self.hint = hint
|
||||||
self.autogen = autogen
|
self.autogen = autogen
|
||||||
self.bonus = bonus
|
|
||||||
self.threshold = threshold
|
self.threshold = threshold
|
||||||
self.weightmap = weightmap
|
self.weightmap = weightmap
|
||||||
|
|
||||||
|
@ -172,6 +180,7 @@ class Solves(db.Model):
|
||||||
date = db.Column(db.Text, default=utils.get_time_since_epoch())
|
date = db.Column(db.Text, default=utils.get_time_since_epoch())
|
||||||
correct = db.Column(db.Boolean)
|
correct = db.Column(db.Boolean)
|
||||||
flag = db.Column(db.Text)
|
flag = db.Column(db.Text)
|
||||||
|
bonus = db.Column(db.Integer) # 1 for first solve, 2 for second, etc.
|
||||||
|
|
||||||
def __init__(self, pid, tid, flag, correct):
|
def __init__(self, pid, tid, flag, correct):
|
||||||
self.pid = pid
|
self.pid = pid
|
||||||
|
|
|
@ -138,6 +138,16 @@ def problem_submit():
|
||||||
db.session.commit()
|
db.session.commit()
|
||||||
|
|
||||||
if correct:
|
if correct:
|
||||||
|
# Wait until after the solve has been added to the database before adding bonus
|
||||||
|
solves = Solves.query.filter_by(pid=pid, correct=1).count()
|
||||||
|
if solves < 4:
|
||||||
|
bonus = solves
|
||||||
|
else:
|
||||||
|
bonus = -1
|
||||||
|
solve.bonus = bonus
|
||||||
|
db.session.add(solve)
|
||||||
|
db.session.commit()
|
||||||
|
|
||||||
logger.log(__name__, "%s has solved %s by submitting %s" % (team.teamname, problem.title, flag), level=logger.WARNING)
|
logger.log(__name__, "%s has solved %s by submitting %s" % (team.teamname, problem.title, flag), level=logger.WARNING)
|
||||||
return { "success": 1, "message": response }
|
return { "success": 1, "message": response }
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue