X-Git-Url: https://git.auder.net/css/rpsls.css?a=blobdiff_plain;ds=sidebyside;f=server%2Fmodels%2FChallenge.js;h=6f8ba0be6047ea8f3ed7609b47dcb3c25ef5814e;hb=4edfed6c011cd97d58d5bd8e0451cc0c1006a0a0;hp=8adf3cac1048791527cc0d1884df218fbdce19cc;hpb=36093ebabecde5a86451a4600babbecc971887c0;p=vchess.git diff --git a/server/models/Challenge.js b/server/models/Challenge.js index 8adf3cac..6f8ba0be 100644 --- a/server/models/Challenge.js +++ b/server/models/Challenge.js @@ -126,29 +126,61 @@ const ChallengeModel = }); }, - testfunc: function() + getSeatCount: function(id, cb) { - db.serialize(function() { - db.run("DELETE * FROM TableTest", (err,ret) => { - console.log(ret); + db.serialize(function() { + let query = + "SELECT COUNT(*) AS scount " + + "FROM WillPlay " + + "WHERE cid = " + id; + db.get(query, (err,scRow) => { + if (!!err) + return cb(err); + query = + "SELECT nbPlayers " + + "FROM Challenges " + + "WHERE id = " + id; + db.get(query, (err2,chRow) => { + if (!!err2) + return cb(err2); + cb(chRow["nbPlayers"] - scRow["scount"]); + }); }); }); }, + setSeat: function(id, uid) + { + // TODO: remove extra "db.serialize" (parallelize by default) + //db.serialize(function() { + const query = + "INSERT OR REPLACE INTO WillPlay " + + "VALUES (true," + id + "," + uid +")"; + db.run(query); + //}); + }, + remove: function(id, uid) { db.serialize(function() { let query = - "DELETE FROM Challenges " + - "WHERE id = " + id + " AND uid = " + uid; - db.run(query, (err,ret) => { - if (!err && ret >= 1) + "SELECT 1 " + + "FROM Challenges " + + "WHERE id = " + id + " AND uid = " + uid; + db.run(query, (err,rows) => { + if (rows.length > 0) //it's my challenge { - // Also remove matching WillPlay entries if a challenge was deleted - query = - "DELETE FROM WillPlay " + - "WHERE cid = " + id; - db.run(query); + db.parallelize(function() { + query = + "DELETE FROM Challenges " + + "WHERE id = " + id; + db.run(query); + // Also remove matching WillPlay entries if a challenge was deleted + query = + "DELETE FROM WillPlay " + + "WHERE cid = " + id; + db.run(query); + }); } }); });