X-Git-Url: https://git.auder.net/?a=blobdiff_plain;f=models%2Fassessment.js;h=9ab92ba448b071b1b1182d03de2ea958429073c5;hb=71d1ca9c594b64d959c608a2abbff926480abad5;hp=a1a41e20d682116478f01fea9ea1e62031655df6;hpb=f03a2ad9e0b2fa36051def18d4c19c2f293cac1d;p=qomet.git diff --git a/models/assessment.js b/models/assessment.js index a1a41e2..9ab92ba 100644 --- a/models/assessment.js +++ b/models/assessment.js @@ -23,6 +23,18 @@ const AssessmentModel = }); }, + checkPassword: function(aid, number, password, cb) + { + AssessmentEntity.getById(aid, (err,assessment) => { + if (!!err || !assessment) + return cb(err, assessment); + const paperIdx = assessment.papers.findIndex( item => { return item.number == number; }); + if (paperIdx === -1) + return cb({errmsg: "Paper not found"}, false); + cb(null, assessment.papers[paperIdx].password == password); + }); + }, + add: function(uid, cid, name, cb) { // 1) Check that course is owned by user of ID uid @@ -38,9 +50,9 @@ const AssessmentModel = update: function(uid, assessment, cb) { - const qid = ObjectId(assessment._id); + const aid = ObjectId(assessment._id); // 1) Check that assessment is owned by user of ID uid - AssessmentEntity.getById(qid, (err,assessmentOld) => { + AssessmentEntity.getById(aid, (err,assessmentOld) => { if (!!err || !assessmentOld) return cb({errmsg: "Assessment retrieval failure"}); CourseEntity.getById(ObjectId(assessmentOld.cid), (err2,course) => { @@ -51,7 +63,7 @@ const AssessmentModel = // 2) Replace assessment delete assessment["_id"]; assessment.cid = ObjectId(assessment.cid); - AssessmentEntity.replace(qid, assessment, cb); + AssessmentEntity.replace(aid, assessment, cb); }); }); }, @@ -62,20 +74,22 @@ const AssessmentModel = AssessmentEntity.getPaperByNumber(aid, number, (err,paper) => { if (!!err) return cb(err,null); + if (!paper && !!password) + return cb({errmsg: "Cannot start a new exam before finishing current"},null); if (!!paper) { if (!password) - return cb({errmsg:"Missing password"}); + return cb({errmsg: "Missing password"}); if (paper.password != password) - return cb({errmsg:"Wrong password"}); + return cb({errmsg: "Wrong password"}); } AssessmentEntity.getQuestions(aid, (err,questions) => { if (!!err) return cb(err,null); if (!!paper) return cb(null,{paper:paper,questions:questions}); - AssessmentEntity.startSession(aid, number, password, (err2,ret) => { - const pwd = TokenGen.generate(12); //arbitrary number, 12 seems enough... + const pwd = TokenGen.generate(12); //arbitrary number, 12 seems enough... + AssessmentEntity.startSession(aid, number, pwd, (err2,ret) => { cb(err2, { questions: questions, password: pwd, @@ -87,7 +101,6 @@ const AssessmentModel = newAnswer: function(aid, number, password, input, cb) { - console.log(JSON.stringify(input)); // Check that student hasn't already answered AssessmentEntity.hasInput(aid, number, password, input.index, (err,ret) => { if (!!err) @@ -95,7 +108,6 @@ const AssessmentModel = if (!!ret) return cb({errmsg:"Question already answered"},null); AssessmentEntity.setInput(aid, number, password, input, (err2,ret2) => { - console.log(JSON.stringify(ret2)); if (!!err2 || !ret2) return cb(err2,ret2); return cb(null,ret2);