Add Knightrelay1. Some fixes. Move odd 'isAttackedBy_multiple_colors' to Checkered...
[vchess.git] / server / routes / problems.js
CommitLineData
89021f18
BA
1let router = require("express").Router();
2const access = require("../utils/access");
3const ProblemModel = require("../models/Problem");
4const sanitizeHtml = require('sanitize-html');
5
866842c3 6router.post("/problems", access.logged, access.ajax, (req,res) => {
0234201f
BA
7 if (ProblemModel.checkProblem(req.body.prob)) {
8 const problem = {
866842c3
BA
9 vid: req.body.prob.vid,
10 fen: req.body.prob.fen,
11 uid: req.userId,
12 instruction: sanitizeHtml(req.body.prob.instruction),
13 solution: sanitizeHtml(req.body.prob.solution),
14 };
0234201f
BA
15 ProblemModel.create(problem, (err, ret) => {
16 res.json(err || ret);
866842c3
BA
17 });
18 }
19 else
20 res.json({});
21});
22
e57c4de4 23router.get("/problems", access.ajax, (req,res) => {
89021f18 24 const probId = req.query["pid"];
68e19a44
BA
25 const cursor = req.query["cursor"];
26 if (!!probId && !!probId.match(/^[0-9]+$/)) {
27 ProblemModel.getOne(req.query["pid"], (err, problem) => {
866842c3 28 res.json(err || {problem: problem});
89021f18 29 });
68e19a44
BA
30 } else if (!!cursor && !!cursor.match(/^[0-9]+$/)) {
31 ProblemModel.getNext(cursor, (err, problems) => {
0234201f 32 res.json(err || { problems: problems });
89021f18
BA
33 });
34 }
35});
36
89021f18 37router.put("/problems", access.logged, access.ajax, (req,res) => {
604b951e 38 let obj = req.body.prob;
0234201f 39 if (ProblemModel.checkProblem(obj)) {
866842c3
BA
40 obj.instruction = sanitizeHtml(obj.instruction);
41 obj.solution = sanitizeHtml(obj.solution);
42 ProblemModel.safeUpdate(obj, req.userId);
43 }
44 res.json({});
89021f18
BA
45});
46
47router.delete("/problems", access.logged, access.ajax, (req,res) => {
48 const pid = req.query.id;
866842c3
BA
49 if (pid.toString().match(/^[0-9]+$/))
50 ProblemModel.safeRemove(pid, req.userId);
51 res.json({});
89021f18
BA
52});
53
54module.exports = router;