From fd41e587ca01d709551e0cc04bb94fb5e769fe97 Mon Sep 17 00:00:00 2001
From: Benjamin Auder <benjamin.auder@somewhere>
Date: Wed, 12 Feb 2020 14:48:46 +0100
Subject: [PATCH] Soften removal conditions in CRON tasks (no challenge removal
 at all)

---
 server/bin/www             |  4 +---
 server/models/Challenge.js | 22 ----------------------
 server/models/Game.js      | 23 ++++++++---------------
 3 files changed, 9 insertions(+), 40 deletions(-)

diff --git a/server/bin/www b/server/bin/www
index b3a2c732..9fd23a44 100755
--- a/server/bin/www
+++ b/server/bin/www
@@ -27,12 +27,10 @@ var server = http.createServer(app);
 
 var cron = require('node-cron');
 var UserModel = require("../models/User");
-var ChallengeModel = require("../models/Challenge");
 var GameModel = require("../models/Game");
 cron.schedule('0 0 0 * * *', function() {
-  // Remove some old users, challenges and games every 24h
+  // Remove unlogged users and unstarted games every 24h
   UserModel.cleanUsersDb();
-  ChallengeModel.removeOld();
   GameModel.cleanGamesDb();
 });
 
diff --git a/server/models/Challenge.js b/server/models/Challenge.js
index 75cab3ab..4aae427a 100644
--- a/server/models/Challenge.js
+++ b/server/models/Challenge.js
@@ -98,28 +98,6 @@ const ChallengeModel =
       });
     });
   },
-
-  // Remove challenges older than 1 month, and 1to1 older than 2 days
-  removeOld: function()
-  {
-    const tsNow = Date.now();
-    // 86400000 = 24 hours in milliseconds
-    const day = 86400000;
-    db.serialize(function() {
-      const query =
-        "SELECT id, target, added " +
-        "FROM Challenges";
-      db.all(query, (err, challenges) => {
-        challenges.forEach(c => {
-          if ((!c.target && tsNow - c.added > 30*day) ||
-            (!!c.target && tsNow - c.added > 2*day))
-          {
-            db.run("DELETE FROM Challenges WHERE id = " + c.id);
-          }
-        });
-      });
-    });
-  },
 }
 
 module.exports = ChallengeModel;
diff --git a/server/models/Game.js b/server/models/Game.js
index 16c050cd..70f32be2 100644
--- a/server/models/Game.js
+++ b/server/models/Game.js
@@ -277,28 +277,21 @@ const GameModel =
     const day = 86400000;
     db.serialize(function() {
       let query =
-        "SELECT id,score,created " +
+        "SELECT id,created " +
         "FROM Games ";
       db.all(query, (err,games) => {
         games.forEach(g => {
           query =
-            "SELECT max(played) AS lastMaj " +
+            "SELECT count(*) as nbMoves, max(played) AS lastMaj " +
             "FROM Moves " +
             "WHERE gid = " + g.id;
-          db.get(query, (err2,updated) => {
-            if (!updated.lastMaj)
+          db.get(query, (err2,mstats) => {
+            // Remove games still not really started,
+            // with no action in the last 3 months:
+            if ((mstats.nbMoves == 0 && tsNow - g.created > 91*day) ||
+              (mstats.nbMoves == 1 && tsNow - mstats.lastMaj > 91*day))
             {
-              if (tsNow - g.created > 7*day)
-                return GameModel.remove(g.id);
-            }
-            else //at least one move
-            {
-              const lastMaj = updated.lastMaj;
-              if (g.score != "*" && tsNow - lastMaj > 7*day ||
-                g.score == "*" && tsNow - lastMaj > 91*day)
-              {
-                GameModel.remove(g.id);
-              }
+              return GameModel.remove(g.id);
             }
           });
         });
-- 
2.44.0