fix: errors from registerComplete

isekai-main
Barış Soner Uşaklı 4 years ago
parent 57e54d559b
commit a48bbdbfe3

@ -138,16 +138,14 @@ async function addToApprovalQueue(req, userData) {
return { message: message }; return { message: message };
} }
authenticationController.registerComplete = function (req, res, next) { authenticationController.registerComplete = async function (req, res) {
// For the interstitials that respond, execute the callback with the form body try {
plugins.hooks.fire('filter:register.interstitial', { // For the interstitials that respond, execute the callback with the form body
req, const data = await plugins.hooks.fire('filter:register.interstitial', {
userData: req.session.registration, req,
interstitials: [], userData: req.session.registration,
}, async (err, data) => { interstitials: [],
if (err) { });
return next(err);
}
const callbacks = data.interstitials.reduce((memo, cur) => { const callbacks = data.interstitials.reduce((memo, cur) => {
if (cur.hasOwnProperty('callback') && typeof cur.callback === 'function') { if (cur.hasOwnProperty('callback') && typeof cur.callback === 'function') {
@ -165,13 +163,10 @@ authenticationController.registerComplete = function (req, res, next) {
return memo; return memo;
}, []); }, []);
const done = function (err, data) { const done = function (data) {
delete req.session.registration; delete req.session.registration;
if (err) {
return res.redirect(`${nconf.get('relative_path')}/?register=${encodeURIComponent(err.message)}`);
}
if (!err && data && data.message) { if (data && data.message) {
return res.redirect(`${nconf.get('relative_path')}/?register=${encodeURIComponent(data.message)}`); return res.redirect(`${nconf.get('relative_path')}/?register=${encodeURIComponent(data.message)}`);
} }
@ -199,8 +194,7 @@ authenticationController.registerComplete = function (req, res, next) {
if (!data) { if (!data) {
return winston.warn('[register] Interstitial callbacks processed with no errors, but one or more interstitials remain. This is likely an issue with one of the interstitials not properly handling a null case or invalid value.'); return winston.warn('[register] Interstitial callbacks processed with no errors, but one or more interstitials remain. This is likely an issue with one of the interstitials not properly handling a null case or invalid value.');
} }
done(data);
done(null, data);
} else { } else {
// Update user hash, clear registration data in session // Update user hash, clear registration data in session
const payload = req.session.registration; const payload = req.session.registration;
@ -217,7 +211,10 @@ authenticationController.registerComplete = function (req, res, next) {
await user.setUserFields(uid, payload); await user.setUserFields(uid, payload);
done(); done();
} }
}); } catch (err) {
delete req.session.registration;
res.redirect(`${nconf.get('relative_path')}/?register=${encodeURIComponent(err.message)}`);
}
}; };
authenticationController.registerAbort = function (req, res) { authenticationController.registerAbort = function (req, res) {

Loading…
Cancel
Save