mailtrain/lib/client-helpers.js

51 lines
1.4 KiB
JavaScript
Raw Normal View History

'use strict';
const passport = require('./passport');
const config = require('config');
2017-07-24 04:03:32 +00:00
const permissions = require('./permissions');
2017-07-30 13:22:07 +00:00
const forms = require('../models/forms');
2017-08-13 18:11:58 +00:00
const shares = require('../models/shares');
2017-07-30 13:22:07 +00:00
async function getAnonymousConfig(context) {
return {
authMethod: passport.authMethod,
isAuthMethodLocal: passport.isAuthMethodLocal,
externalPasswordResetLink: config.ldap.passwordresetlink,
language: config.language || 'en',
2017-07-24 04:03:32 +00:00
isAuthenticated: !!context.user
}
}
2017-07-30 13:22:07 +00:00
async function getAuthenticatedConfig(context) {
2017-07-24 04:03:32 +00:00
return {
2017-07-30 13:22:07 +00:00
defaultCustomFormValues: await forms.getDefaultCustomFormValues(),
user: {
id: context.user.id,
namespace: context.user.namespace
},
2017-08-13 18:11:58 +00:00
globalPermissions: shares.getGlobalPermissions(context)
}
}
function registerRootRoute(router, entryPoint, title) {
2017-07-30 13:22:07 +00:00
router.getAsync('/*', passport.csrfProtection, async (req, res) => {
const mailtrainConfig = await getAnonymousConfig(req.context);
2017-07-24 04:03:32 +00:00
if (req.user) {
2017-07-30 13:22:07 +00:00
Object.assign(mailtrainConfig, await getAuthenticatedConfig(req.context));
2017-07-24 04:03:32 +00:00
}
res.render('react-root', {
title,
reactEntryPoint: entryPoint,
reactCsrfToken: req.csrfToken(),
2017-07-24 04:03:32 +00:00
mailtrainConfig: JSON.stringify(mailtrainConfig)
});
});
}
module.exports = {
2017-07-30 13:22:07 +00:00
registerRootRoute,
2017-07-24 04:03:32 +00:00
getAuthenticatedConfig
};