/* * This file is part of SYZOJ. * * Copyright (c) 2016 Menci * * SYZOJ is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * SYZOJ is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public * License along with SYZOJ. If not, see . */ 'use strict'; let Sequelize = require('sequelize'); let db = syzoj.db; let User = syzoj.model('user'); let Problem = syzoj.model('problem'); let Contest = syzoj.model('contest'); let model = db.define('contest_player', { id: { type: Sequelize.INTEGER, primaryKey: true, autoIncrement: true }, contest_id: { type: Sequelize.INTEGER }, user_id: { type: Sequelize.INTEGER }, score: { type: Sequelize.INTEGER }, score_details: { type: Sequelize.TEXT, json: true }, time_spent: { type: Sequelize.INTEGER } }, { timestamps: false, tableName: 'contest_player', indexes: [ { fields: ['contest_id'], }, { fields: ['user_id'], } ] }); let Model = require('./common'); class ContestPlayer extends Model { static async create(val) { return ContestPlayer.fromRecord(ContestPlayer.model.build(Object.assign({ contest_id: 0, user_id: 0, score: 0, score_details: '{}', time_spent: 0 }, val))); } static async findInContest(where) { return ContestPlayer.findOne({ where: where }); } async loadRelationships() { this.user = await User.fromID(this.user_id); this.contest = await Contest.fromID(this.contest_id); } async updateScore(judge_state) { this.score_details[judge_state.problem_id] = { score: judge_state.score, judge_id: judge_state.id }; this.score = 0; for (let x in this.score_details) { this.score += this.score_details[x].score; } } getModel() { return model; } } ContestPlayer.model = model; module.exports = ContestPlayer;