2016-09-25 09:00:52 +00:00
|
|
|
from django.db import models
|
|
|
|
from django.utils.timezone import now
|
|
|
|
from jsonfield import JSONField
|
|
|
|
|
|
|
|
from account.models import User
|
2017-01-23 08:48:04 +00:00
|
|
|
from group.models import Group
|
2016-09-25 09:00:52 +00:00
|
|
|
from problem.models import AbstractProblem
|
|
|
|
from utils.models import RichTextField
|
|
|
|
|
|
|
|
|
|
|
|
class ContestType(object):
|
2017-01-24 05:22:40 +00:00
|
|
|
GROUP_CONTEST = "group_contest"
|
|
|
|
PUBLIC_CONTEST = "public_contest"
|
|
|
|
PASSWORD_PROTECTED_CONTEST = "password_protected_contest"
|
2016-09-25 09:00:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
class ContestStatus(object):
|
2017-01-24 05:22:40 +00:00
|
|
|
CONTEST_NOT_START = "contest_not_start"
|
|
|
|
CONTEST_ENDED = "contest_ended"
|
|
|
|
CONTEST_UNDERWAY = "contest_underway"
|
2016-09-25 09:00:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
class ContestRuleType(object):
|
2017-01-24 05:22:40 +00:00
|
|
|
ACM = "acm"
|
|
|
|
OI = "oi"
|
2016-09-25 09:00:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
class Contest(models.Model):
|
|
|
|
title = models.CharField(max_length=40, unique=True)
|
|
|
|
description = RichTextField()
|
|
|
|
# show real time rank or cached rank
|
|
|
|
real_time_rank = models.BooleanField()
|
|
|
|
password = models.CharField(max_length=30, blank=True, null=True)
|
|
|
|
# enum of ContestType
|
2017-01-24 05:22:40 +00:00
|
|
|
contest_type = models.CharField(max_length=36)
|
2016-09-25 09:00:52 +00:00
|
|
|
# enum of ContestRuleType
|
2017-01-24 05:22:40 +00:00
|
|
|
rule_type = models.CharField(max_length=36)
|
2016-09-25 09:00:52 +00:00
|
|
|
start_time = models.DateTimeField()
|
|
|
|
end_time = models.DateTimeField()
|
|
|
|
create_time = models.DateTimeField(auto_now_add=True)
|
|
|
|
last_updated_time = models.DateTimeField(auto_now=True)
|
|
|
|
created_by = models.ForeignKey(User)
|
|
|
|
groups = models.ManyToManyField(Group)
|
|
|
|
# 是否可见 false的话相当于删除
|
|
|
|
visible = models.BooleanField(default=True)
|
|
|
|
|
|
|
|
@property
|
|
|
|
def status(self):
|
|
|
|
if self.start_time > now():
|
|
|
|
# 没有开始 返回1
|
|
|
|
return ContestStatus.CONTEST_NOT_START
|
|
|
|
elif self.end_time < now():
|
|
|
|
# 已经结束 返回-1
|
|
|
|
return ContestStatus.CONTEST_ENDED
|
|
|
|
else:
|
|
|
|
# 正在进行 返回0
|
|
|
|
return ContestStatus.CONTEST_UNDERWAY
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
db_table = "contest"
|
|
|
|
|
|
|
|
|
|
|
|
class ContestProblem(AbstractProblem):
|
|
|
|
contest = models.ForeignKey(Contest)
|
|
|
|
# 比如A B 或者1 2 或者 a b 将按照这个排序
|
|
|
|
sort_index = models.CharField(max_length=30)
|
|
|
|
# 是否已经公开了题目,防止重复公开
|
|
|
|
is_public = models.BooleanField(default=False)
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
db_table = "contest_problem"
|
|
|
|
|
|
|
|
|
|
|
|
class ContestRank(models.Model):
|
|
|
|
user = models.ForeignKey(User)
|
|
|
|
contest = models.ForeignKey(Contest)
|
|
|
|
total_submission_number = models.IntegerField(default=0)
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
abstract = True
|
|
|
|
|
|
|
|
|
|
|
|
class ACMContestRank(ContestRank):
|
|
|
|
total_ac_number = models.IntegerField(default=0)
|
|
|
|
# total_time is only for ACM contest total_time = ac time + none-ac times * 20 * 60
|
|
|
|
total_time = models.IntegerField(default=0)
|
|
|
|
# {23: {"is_ac": True, "ac_time": 8999, "error_number": 2, "is_first_ac": True}}
|
|
|
|
# key is problem id
|
|
|
|
submission_info = JSONField(default={})
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
db_table = "acm_contest_rank"
|
|
|
|
|
|
|
|
|
|
|
|
class OIContestRank(ContestRank):
|
|
|
|
total_score = models.IntegerField(default=0)
|
|
|
|
# {23: {"score": 80, "total_score": 100}}
|
|
|
|
# key is problem id
|
|
|
|
submission_info = JSONField(default={})
|
|
|
|
|
|
|
|
class Meta:
|
2017-01-24 05:22:40 +00:00
|
|
|
db_table = "oi_contest_rank"
|