'use strict'; process .on('uncaughtException', console.error) .on('unhandledRejection', console.error); const msTime = require(__dirname+'/helpers/mstime.js') , deleteCaptchas = require(__dirname+'/helpers/captcha/deletecaptchas.js') , Mongo = require(__dirname+'/db/db.js'); (async () => { await Mongo.connect(); const { buildHomepage } = require(__dirname+'/helpers/build.js') , Files = require(__dirname+'/db/files.js'); console.log('Starting schedules'); await buildHomepage(); setInterval(async () => { try { await buildHomepage(); } catch (e) { console.error(e); } }, msTime.minute*5); //rebuild homepage for pph updates setInterval(async () => { try { await deleteCaptchas(); } catch (e) { console.error(e); } }, msTime.minute*5); //delete files for expired captchas setInterval(async () => { try { //todo: would need to lock the DB or at least disable posting very shortly for this pruning const files = await Files.db.find({ 'count': { '$lte': 0 } }, { 'count': 0 }).toArray().then(res => { return res.map(x => x._id); }); await Files.db.removeMany({ 'count': { '$lte': 0 } }); await Promise.all(files.map(async filename => { return Promise.all([ remove(`${uploadDirectory}img/${filename}`), remove(`${uploadDirectory}img/thumb-${filename.split('.')[0]}.jpg`) ]) })); console.log('Deleted unused files:', files); } catch (e) { console.error(e); } }, msTime.day); })();