@clerk/nextjs
Version:
Clerk SDK for NextJS
121 lines • 6.39 kB
JavaScript
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
var getAuthDataFromRequest_exports = {};
__export(getAuthDataFromRequest_exports, {
getAuthDataFromRequestAsync: () => getAuthDataFromRequestAsync,
getAuthDataFromRequestSync: () => getAuthDataFromRequestSync
});
module.exports = __toCommonJS(getAuthDataFromRequest_exports);
var import_internal = require("@clerk/backend/internal");
var import_jwt = require("@clerk/backend/jwt");
var import_constants = require("../constants");
var import_headers_utils = require("../headers-utils");
var import_utils = require("../utils");
const getAuthDataFromRequestSync = (req, { treatPendingAsSignedOut = true, ...opts } = {}) => {
var _a, _b;
const { authStatus, authMessage, authReason, authToken, authSignature } = getAuthHeaders(req);
(_a = opts.logger) == null ? void 0 : _a.debug("headers", { authStatus, authMessage, authReason });
const encryptedRequestData = (0, import_headers_utils.getHeader)(req, import_internal.constants.Headers.ClerkRequestData);
const decryptedRequestData = (0, import_utils.decryptClerkRequestData)(encryptedRequestData);
const options = {
secretKey: (opts == null ? void 0 : opts.secretKey) || decryptedRequestData.secretKey || import_constants.SECRET_KEY,
publishableKey: decryptedRequestData.publishableKey || import_constants.PUBLISHABLE_KEY,
apiUrl: import_constants.API_URL,
apiVersion: import_constants.API_VERSION,
authStatus,
authMessage,
authReason,
treatPendingAsSignedOut
};
if (!(0, import_internal.isTokenTypeAccepted)(import_internal.TokenType.SessionToken, opts.acceptsToken || import_internal.TokenType.SessionToken)) {
return (0, import_internal.signedOutAuthObject)(options);
}
let authObject;
if (!authStatus || authStatus !== import_internal.AuthStatus.SignedIn) {
authObject = (0, import_internal.signedOutAuthObject)(options);
} else {
(0, import_utils.assertTokenSignature)(authToken, options.secretKey, authSignature);
const jwt = (0, import_jwt.decodeJwt)(authToken);
(_b = opts.logger) == null ? void 0 : _b.debug("jwt", jwt.raw);
return (0, import_internal.getAuthObjectFromJwt)(jwt, options);
}
return authObject;
};
const handleMachineToken = async (bearerToken, acceptsToken, options) => {
const hasMachineToken = bearerToken && (0, import_internal.isMachineTokenByPrefix)(bearerToken);
const acceptsOnlySessionToken = acceptsToken === import_internal.TokenType.SessionToken || Array.isArray(acceptsToken) && acceptsToken.length === 1 && acceptsToken[0] === import_internal.TokenType.SessionToken;
if (hasMachineToken && !acceptsOnlySessionToken) {
const machineTokenType = (0, import_internal.getMachineTokenType)(bearerToken);
if (Array.isArray(acceptsToken) && !acceptsToken.includes(machineTokenType)) {
return (0, import_internal.invalidTokenAuthObject)();
}
if (!Array.isArray(acceptsToken) && acceptsToken !== "any" && machineTokenType !== acceptsToken) {
const authObject2 = (0, import_internal.unauthenticatedMachineObject)(acceptsToken, options);
return (0, import_internal.getAuthObjectForAcceptedToken)({ authObject: authObject2, acceptsToken });
}
const { data, errors } = await (0, import_internal.verifyMachineAuthToken)(bearerToken, options);
const authObject = errors ? (0, import_internal.unauthenticatedMachineObject)(machineTokenType, options) : (0, import_internal.authenticatedMachineObject)(machineTokenType, bearerToken, data);
return (0, import_internal.getAuthObjectForAcceptedToken)({ authObject, acceptsToken });
}
return null;
};
const getAuthDataFromRequestAsync = async (req, opts = {}) => {
var _a, _b;
const { authStatus, authMessage, authReason } = getAuthHeaders(req);
(_a = opts.logger) == null ? void 0 : _a.debug("headers", { authStatus, authMessage, authReason });
const bearerToken = (_b = (0, import_headers_utils.getHeader)(req, import_internal.constants.Headers.Authorization)) == null ? void 0 : _b.replace("Bearer ", "");
const acceptsToken = opts.acceptsToken || import_internal.TokenType.SessionToken;
const options = {
secretKey: (opts == null ? void 0 : opts.secretKey) || import_constants.SECRET_KEY,
publishableKey: import_constants.PUBLISHABLE_KEY,
apiUrl: import_constants.API_URL,
authStatus,
authMessage,
authReason
};
const machineAuthObject = await handleMachineToken(bearerToken, acceptsToken, options);
if (machineAuthObject) {
return machineAuthObject;
}
if (bearerToken && Array.isArray(acceptsToken) && !acceptsToken.includes(import_internal.TokenType.SessionToken)) {
return (0, import_internal.invalidTokenAuthObject)();
}
const authObject = getAuthDataFromRequestSync(req, opts);
return (0, import_internal.getAuthObjectForAcceptedToken)({ authObject, acceptsToken });
};
const getAuthHeaders = (req) => {
const authStatus = (0, import_headers_utils.getAuthKeyFromRequest)(req, "AuthStatus");
const authToken = (0, import_headers_utils.getAuthKeyFromRequest)(req, "AuthToken");
const authMessage = (0, import_headers_utils.getAuthKeyFromRequest)(req, "AuthMessage");
const authReason = (0, import_headers_utils.getAuthKeyFromRequest)(req, "AuthReason");
const authSignature = (0, import_headers_utils.getAuthKeyFromRequest)(req, "AuthSignature");
return {
authStatus,
authToken,
authMessage,
authReason,
authSignature
};
};
// Annotate the CommonJS export names for ESM import in node:
0 && (module.exports = {
getAuthDataFromRequestAsync,
getAuthDataFromRequestSync
});
//# sourceMappingURL=getAuthDataFromRequest.js.map
;