- const error = ChallengeModel.checkChallenge(req.body.chall);
- // TODO: treat "to" field separately (search users by name)
- // --> replace "to" by an array of uid (in chall), then call:
- const from = req.userId;
-// let to = !!req.body.to ? ObjectID(req.body.to) : undefined;
-// let nameTo = !!req.body.nameTo ? req.body.nameTo : undefined;
-// let vid = ObjectID(req.body.vid);
-// if (!to && !!nameTo)
-// {
-// UserModel.getByName(nameTo, (err,user) => {
-// access.checkRequest(res, err, user, "Opponent not found", () => {
-// createChallenge(vid, from, user._id, res);
-// });
-// });
-// }
-// else if (!!to)
-// createChallenge(vid, from, to, res);
-// else
-// createChallenge(vid, from, undefined, res); //automatch
- ChallengeModel.create(req.body.chall, (err,lastId) => {
- res.json(err || {cid: lastId["rowid"]});
- });
+ if (ChallengeModel.checkChallenge(req.body.chall)) {
+ let challenge = {
+ fen: req.body.chall.fen,
+ cadence: req.body.chall.cadence,
+ options: req.body.chall.options,
+ randomness: req.body.chall.randomness,
+ vid: req.body.chall.vid,
+ uid: req.userId,
+ to: req.body.chall.to, //string: user name (may be empty)
+ };
+ const insertChallenge = () => {
+ ChallengeModel.create(challenge, (err, ret) => {
+ res.json(err || ret);
+ });
+ };
+ if (req.body.chall.to) {
+ UserModel.getOne(
+ "name", challenge.to, "id, name, email, notify",
+ (err, user) => {
+ if (err || !user) res.json(err || {errmsg: "Typo in player name"});
+ else {
+ challenge.to = user.id; //ready now to insert challenge
+ insertChallenge();
+ if (user.notify) {
+ UserModel.notify(
+ user,
+ "New challenge : " + params.siteURL + "/#/?disp=corr");
+ }
+ }
+ }
+ );
+ }
+ else insertChallenge();
+ }
+});
+
+router.get("/challenges", access.ajax, (req,res) => {
+ const uid = req.query.uid;
+ if (uid.match(/^[0-9]+$/)) {
+ ChallengeModel.getByUser(uid, (err,challenges) => {
+ res.json(err || { challenges: challenges });
+ });
+ }