X-Git-Url: https://git.auder.net/?a=blobdiff_plain;f=server%2Fmodels%2FGame.js;h=32b2a6624b8fdc9127d9e88d61ead7096787ed49;hb=99f12ac0a1dc9633db08bf2804d7920d060fc214;hp=a3ddc3c4f793787b5fe84ed7a61052a18c71b905;hpb=dfeb96ea90e880a2557cbb5953dbb7258c912283;p=vchess.git diff --git a/server/models/Game.js b/server/models/Game.js index a3ddc3c4..32b2a662 100644 --- a/server/models/Game.js +++ b/server/models/Game.js @@ -81,7 +81,7 @@ const GameModel = // NOTE: g.scoreMsg can be NULL // (in this case score = "*" and no reason to look at it) "SELECT g.id, g.vid, g.fen, g.fenStart, g.timeControl, g.score, " + - "g.scoreMsg, v.name AS vname " + + "g.scoreMsg, g.drawOffer, v.name AS vname " + "FROM Games g " + "JOIN Variants v " + " ON g.vid = v.id " + @@ -131,15 +131,15 @@ const GameModel = getByUser: function(uid, excluded, cb) { db.serialize(function() { - // Next query is fine because a player appear at most once in a game const query = - "SELECT gid " + + "SELECT DISTINCT gid " + "FROM Players " + "WHERE uid " + (excluded ? "<>" : "=") + " " + uid; db.all(query, (err,gameIds) => { if (!!err) return cb(err); - gameIds = gameIds || []; //might be empty + if (gameIds.length == 0) + return cb(null, []); let gameArray = []; for (let i=0; i { games.forEach(g => { @@ -272,13 +278,19 @@ const GameModel = "FROM Moves " + "WHERE gid = " + g.id; db.get(query, (err2,updated) => { - if (!updated && tsNow - g.created > 7*day) - return GameModel.remove(g.id); - const lastMaj = updated.lastMaj; - if (g.score != "*" && tsNow - lastMaj > 7*day || - g.score == "*" && tsNow - lastMaj > 91*day) + if (!updated.lastMaj) + { + if (tsNow - g.created > 7*day) + return GameModel.remove(g.id); + } + else //at least one move { - GameModel.remove(g.id); + const lastMaj = updated.lastMaj; + if (g.score != "*" && tsNow - lastMaj > 7*day || + g.score == "*" && tsNow - lastMaj > 91*day) + { + GameModel.remove(g.id); + } } }); });