From beede9f92c5509026318a49db4b358368bfb8ea7 Mon Sep 17 00:00:00 2001 From: authcompanion Date: Sat, 11 Nov 2023 21:07:00 -0500 Subject: [PATCH] fix: correct admin unsuccessful login to dashboard --- services/admin/users/login.js | 7 ++++++- utils/authenticate.js | 5 ++--- 2 files changed, 8 insertions(+), 4 deletions(-) diff --git a/services/admin/users/login.js b/services/admin/users/login.js index 267c875..1976cd8 100644 --- a/services/admin/users/login.js +++ b/services/admin/users/login.js @@ -1,4 +1,4 @@ -import { verifyValueWithHash } from "../../../utils/credential.js"; +import { verifyValueWithHash, secureCookie } from "../../../utils/credential.js"; import { makeAdminToken, makeAdminRefreshtoken } from "../../../utils/jwt.js"; import config from "../../../config.js"; @@ -52,6 +52,11 @@ export const loginHandler = async function (request, reply) { expireDate.setTime(expireDate.getTime() + 7 * 24 * 60 * 60 * 1000); // TODO: Make configurable now, set to 7 days reply.headers({ + "set-cookie": [ + `adminDashboardAccessToken=${adminAccessToken.token}; Path=/; Expires=${expireDate}; SameSite=${ + config.SAMESITE + }; HttpOnly; ${secureCookie()}`, + ], "x-authc-app-origin": config.ADMINORIGIN, }); diff --git a/utils/authenticate.js b/utils/authenticate.js index 1b1d33a..0c4b16e 100644 --- a/utils/authenticate.js +++ b/utils/authenticate.js @@ -56,14 +56,13 @@ export const authenticateWebAdminRequest = async function (request, reply) { const cookies = parse(request.headers.cookie); // Check if adminAccessToken token exists in the cookies - if (!cookies.adminAccessToken) { + if (!cookies.adminDashboardAccessToken) { reply.redirect("/v1/admin/login"); throw { statusCode: "401", message: "Unauthorized, Please Login" }; } // Validate the adminAccessToken token and get its payload - const fingerPrint = cookies["Fgp"]; - const payload = await validateJWT(cookies.adminAccessToken, this.key, fingerPrint); + const payload = await validateJWT(cookies.adminDashboardAccessToken, this.key); // Check if the payload contains the admin scope if (!payload.scope.includes("admin")) {