You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
78 lines
3.0 KiB
JavaScript
78 lines
3.0 KiB
JavaScript
5 years ago
|
const
|
||
|
domain = require('./domain'),
|
||
|
validator = require('../lib/validator'),
|
||
|
{ ValidationError, TrainingNotFoundError } = require('../error'),
|
||
|
db = require('../service/db.js'),
|
||
|
coll = db.collection('traning'),
|
||
|
coll_status = db.collection('training.status');
|
||
|
|
||
|
module.exports = {
|
||
|
SETTING_DIFFICULTY_ALGORITHM: 0,
|
||
|
SETTING_DIFFICULTY_ADMIN: 1,
|
||
|
SETTING_DIFFICULTY_AVERAGE: 2,
|
||
|
|
||
|
async add(domainId, title, content, owner_uid, dag = [], desc = '') {
|
||
|
validator.check_title(title);
|
||
|
validator.check_intro(content);
|
||
|
validator.check_description(desc);
|
||
|
for (let node of dag)
|
||
|
for (let nid of node['require_nids'])
|
||
|
if (nid >= node._id)
|
||
|
throw new ValidationError('dag');
|
||
|
return await coll.insertOne({
|
||
|
domainId, content, owner_uid,
|
||
|
dag, title, desc, enroll: 0
|
||
|
});
|
||
|
},
|
||
|
count: (domainId, query) => coll.find(Object.assign({ domainId }, query)).count(),
|
||
|
async edit(domainId, tid, $set) {
|
||
|
if ($set.title) validator.check_title($set.title);
|
||
|
if ($set.content) validator.check_intro($set.content);
|
||
|
if ($set.desc) validator.check_description($set.desc);
|
||
|
if ($set.dag)
|
||
|
for (let node of $set.dag)
|
||
|
for (let nid of node.require_nids)
|
||
|
if (nid >= node._id) throw new ValidationError('dag');
|
||
|
await coll.findOneAndUpdate({ domainId, tid }, { $set });
|
||
|
let tdoc = await coll.findOne({ domainId, tid });
|
||
|
if (!tdoc) throw new TrainingNotFoundError(domainId, tid);
|
||
|
return tdoc;
|
||
|
},
|
||
|
async get(domainId, tid) {
|
||
|
let tdoc = await coll.findOne({ domainId, tid });
|
||
|
if (!tdoc) throw new TrainingNotFoundError(domainId, tid);
|
||
|
return tdoc;
|
||
|
},
|
||
|
get_multi: (domainId, query) => coll.find(Object.assign({ domainId }, query)),
|
||
|
get_multi_status: (query) => coll.find(query),
|
||
|
async get_random_id(query) {
|
||
|
let pdocs = coll.find(query);
|
||
|
let pcount = await pdocs.count();
|
||
|
if (pcount) {
|
||
|
let pdoc = await pdocs.skip(Math.floor(Math.random() * pcount)).limit(1).toArray()[0];
|
||
|
return pdoc.pid;
|
||
|
} else return null;
|
||
|
},
|
||
|
get_status: (domainId, tid, uid) => coll_status.findOne({ domainId, tid, uid }),
|
||
|
set_status: (domainId, tid, uid, $set) => coll_status.findOneAndUpdate({ domainId, tid, uid }, { $set })
|
||
|
|
||
|
};
|
||
|
|
||
|
/*
|
||
|
async def get_dict_status(domainId, uid, tids, *, fields=None):
|
||
|
result = dict()
|
||
|
async for tsdoc in get_multi_status(domainId=domainId,
|
||
|
uid=uid,
|
||
|
doc_id={'$in': list(set(tids))},
|
||
|
fields=fields):
|
||
|
result[tsdoc['doc_id']] = tsdoc
|
||
|
return result
|
||
|
|
||
|
async def get_dict(domainId, tids, *, fields=None):
|
||
|
result = dict()
|
||
|
async for tdoc in get_multi(domainId=domainId,
|
||
|
doc_id={'$in': list(set(tids))},
|
||
|
fields=fields):
|
||
|
result[tdoc['doc_id']] = tdoc
|
||
|
return result
|
||
|
*/
|