You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

93 lines
2.3 KiB

// page.js
// Copyright (C) 2021 Digital Telepresence, LLC
// License: Apache-2.0
'use strict';
const express = require('express');
const { SiteController, SiteError } = require('../../lib/site-lib');
class PageController extends SiteController {
constructor (dtp) {
super(dtp, module.exports);
}
async start ( ) {
const { dtp } = this;
const { limiter: limiterService } = dtp.services;
const router = express.Router();
dtp.app.use('/page', router);
router.use(async (req, res, next) => {
res.locals.currentView = 'page';
return next();
});
router.param('pageSlug', this.populatePageSlug.bind(this));
router.get('/:pageSlug',
limiterService.createMiddleware(limiterService.config.page.getView),
this.getView.bind(this),
);
}
async populatePageSlug (req, res, next, pageSlug) {
const {
logan: loganService,
page: pageService,
} = this.dtp.services;
try {
res.locals.page = await pageService.getBySlug(pageSlug);
if (!res.locals.page) {
throw new SiteError(404, 'Page not found');
}
return next();
} catch (error) {
loganService.sendRequestEvent(module.exports, req, {
level: 'error',
event: 'populatePageSlug',
message: error.message,
data: { error },
});
return next(error);
}
}
async getView (req, res, next) {
const {
logan: loganService,
resource: resourceService,
} = this.dtp.services;
try {
await resourceService.recordView(req, 'Page', res.locals.page._id);
res.locals.pageSlug = res.locals.page.slug;
res.locals.pageTitle = `${res.locals.page.title} on ${this.dtp.config.site.name}`;
loganService.sendRequestEvent(module.exports, req, {
level: 'info',
event: 'getView',
});
res.render('page/view');
} catch (error) {
this.log.error('failed to service page view', { pageId: res.locals.page._id, error });
loganService.sendRequestEvent(module.exports, req, {
level: 'error',
event: 'getView',
message: error.message,
data: { error },
});
return next(error);
}
}
}
module.exports = {
logId: 'ctl:page',
index: 'page',
className: 'PageController',
create: async (dtp) => { return new PageController(dtp); },
};