From db1c0a57536331e2866b3f5b254e0a0a58fac369 Mon Sep 17 00:00:00 2001 From: felkerch Date: Mon, 4 Jan 2021 18:09:46 -0500 Subject: [PATCH] renders local login form if and only if you're using it --- index.js | 10 ++++++---- views/login.handlebars | 3 ++- 2 files changed, 8 insertions(+), 5 deletions(-) diff --git a/index.js b/index.js index 834913a..15b94f0 100644 --- a/index.js +++ b/index.js @@ -73,12 +73,13 @@ function protectRoutes(site) { /** * middleware to show login page * @param {object} site - * @param {array} currentProviders + * @param {array} providers * @returns {function} */ -function onLogin(site, currentProviders) { +function onLogin(site, providers) { return function (req, res) { const template = compileLoginPage(), + currentProviders = getProviders(providers, site), authUrl = getAuthUrl(site), flash = req.flash(); @@ -102,7 +103,8 @@ function onLogin(site, currentProviders) { currentProviders: currentProviders, user: req.user, logoutLink: `${authUrl}/logout`, - localAuthPath: `${authUrl}/local` + localAuthPath: `${authUrl}/local`, + useLocalAuth: providers.includes('local') })); } }; @@ -185,7 +187,7 @@ function init({ router, providers, store, site, storage, bus }) { // add authorization routes // note: these (and the provider routes) are added here, // rather than as route controllers in lib/routes/ - router.get('/_auth/login', onLogin(site, currentProviders)); + router.get('/_auth/login', onLogin(site, providers)); router.get('/_auth/logout', onLogout(site)); strategyService.addAuthRoutes(providers, router, site); // allow mocking this in tests diff --git a/views/login.handlebars b/views/login.handlebars index 91c9dfd..97a1ad4 100644 --- a/views/login.handlebars +++ b/views/login.handlebars @@ -193,13 +193,14 @@ {{/each}} -

or

{{/if}} + {{#if useLocalAuth}}
+ {{/if}} {{/if}}