Implement bonus points

This commit is contained in:
James Wang 2016-04-17 22:39:04 -04:00
parent 398b413095
commit c38ad5611d
No known key found for this signature in database
GPG key ID: 5B80C0B3F263CD5B
3 changed files with 24 additions and 5 deletions

View file

@ -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

View file

@ -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 }