diff --git a/packages/node_modules/@node-red/editor-api/lib/auth/index.js b/packages/node_modules/@node-red/editor-api/lib/auth/index.js index 5552301d0..f32f6d0d6 100644 --- a/packages/node_modules/@node-red/editor-api/lib/auth/index.js +++ b/packages/node_modules/@node-red/editor-api/lib/auth/index.js @@ -199,8 +199,12 @@ function genericStrategy(adminApp,strategy) { passport.use(new strategy.strategy(options, verify)); adminApp.get('/auth/strategy', - passport.authenticate(strategy.name, {session:false, failureRedirect: settings.httpAdminRoot }), - completeGenerateStrategyAuth + passport.authenticate(strategy.name, {session:false, + failureMessage: true, + failureRedirect: settings.httpAdminRoot + }), + completeGenerateStrategyAuth, + handleStrategyError ); var callbackMethodFunc = adminApp.get; @@ -208,8 +212,13 @@ function genericStrategy(adminApp,strategy) { callbackMethodFunc = adminApp.post; } callbackMethodFunc.call(adminApp,'/auth/strategy/callback', - passport.authenticate(strategy.name, {session:false, failureRedirect: settings.httpAdminRoot }), - completeGenerateStrategyAuth + passport.authenticate(strategy.name, { + session:false, + failureMessage: true, + failureRedirect: settings.httpAdminRoot + }), + completeGenerateStrategyAuth, + handleStrategyError ); } @@ -219,6 +228,13 @@ function completeGenerateStrategyAuth(req,res) { // Successful authentication, redirect home. res.redirect(settings.httpAdminRoot + '?access_token='+tokens.accessToken); } +function handleStrategyError(err, req, res, next) { + if (res.headersSent) { + return next(err) + } + log.audit({event: "auth.login.fail.oauth",error:err.toString()}); + res.redirect(settings.httpAdminRoot + '?session_message='+err.toString()); +} module.exports = { init: init, diff --git a/packages/node_modules/@node-red/editor-api/lib/editor/ui.js b/packages/node_modules/@node-red/editor-api/lib/editor/ui.js index 5fff30725..998816f5e 100644 --- a/packages/node_modules/@node-red/editor-api/lib/editor/ui.js +++ b/packages/node_modules/@node-red/editor-api/lib/editor/ui.js @@ -91,7 +91,16 @@ module.exports = { }, editor: async function(req,res) { - res.send(Mustache.render(editorTemplate,await theme.context())); + + let sessionMessages; + if (req.session && req.session.messages) { + sessionMessages = JSON.stringify(req.session.messages); + delete req.session.messages + } + res.send(Mustache.render(editorTemplate,{ + sessionMessages, + ...await theme.context() + })); }, editorResources: express.static(path.join(editorClientDir,'public')) }; diff --git a/packages/node_modules/@node-red/editor-client/src/images/node-red-256.svg b/packages/node_modules/@node-red/editor-client/src/images/node-red-256.svg new file mode 100644 index 000000000..a8bb17861 --- /dev/null +++ b/packages/node_modules/@node-red/editor-client/src/images/node-red-256.svg @@ -0,0 +1 @@ + diff --git a/packages/node_modules/@node-red/editor-client/src/js/user.js b/packages/node_modules/@node-red/editor-client/src/js/user.js index bd7339285..6f265df38 100644 --- a/packages/node_modules/@node-red/editor-client/src/js/user.js +++ b/packages/node_modules/@node-red/editor-client/src/js/user.js @@ -21,10 +21,10 @@ RED.user = (function() { opts = {}; } - var dialog = $('