From e70fd3594cfa8e0e29c3e9fb25991a9bad048469 Mon Sep 17 00:00:00 2001 From: LMBishop <13875753+LMBishop@users.noreply.github.com> Date: Tue, 21 Dec 2021 15:16:27 +0000 Subject: Seperate router modules from index.ts --- app/routes/special/router.ts | 52 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 52 insertions(+) create mode 100644 app/routes/special/router.ts (limited to 'app/routes/special/router.ts') diff --git a/app/routes/special/router.ts b/app/routes/special/router.ts new file mode 100644 index 0000000..1508ffa --- /dev/null +++ b/app/routes/special/router.ts @@ -0,0 +1,52 @@ +import express, { Router } from 'express'; +import { navbar, page } from '../../middlewares/index.js'; + +export const router = express.Router({ mergeParams: true }); + +router.use('/special/purge/:page?', page); +router.use('/special/purge/:page/confirm', page); + +router.get('/special/purge/:page?', navbar, (req, res, next) => { + let page = res.locals.page; + + if (!page) { + next(); + return; + } + + res.render('purge.ejs', { + navbar: res.locals.navbarHtml, + page: res.locals.path, + buildTime: new Date(page.buildTime) ?? 'never', + buildTimeRelative: Math.round((Date.now() - page.buildTime) / 1000 / 60) + }); +}); + +router.get('/special/purge/:page/confirm', (req, res, next) => { + let page = res.locals.page; + + if (!page) { + next(); + return; + } + + if (res.locals.directory.purge(res.locals.path)) { + res.status(200).send(); + } else { + res.status(429).send(); + } +}); + +router.get('/special/rebuild', navbar, (req, res) => { + res.render('rebuild.ejs', { + navbar: res.locals.navbarHtml + }); +}); + +router.get('/special/rebuild/confirm', (req, res) => { + if (res.locals.directory.rebuild()) { + res.status(200).send(); + } else { + res.status(429).send(); + } +}); -- cgit v1.2.3-70-g09d2