- const error = ChallengeModel.checkChallenge(req.body.chall);
- if (!!error)
- return res.json({errmsg:error});
- let challenge =
- {
- fen: req.body.chall.fen,
- timeControl: req.body.chall.timeControl,
- 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) => {
- if (!!err)
- return res.json(err);
- });
- };
- if (!!req.body.chall.to)
- {
- UserModel.getOne("name", challenge.to, (err,user) => {
- if (!!err || !user)
- return res.json(err | {errmsg: "Typo in player name"});
- challenge.to = user.id; //ready now to insert challenge
- });
- insertChallenge();
+ if (ChallengeModel.checkChallenge(req.body.chall)) {
+ let challenge = {
+ fen: req.body.chall.fen,
+ cadence: req.body.chall.cadence,
+ 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();