@dxkit-org/node-js-kit
Version:
Modern TypeScript utility library for Node.js - Network and JWT utilities for server-side JavaScript and TypeScript projects
271 lines (266 loc) • 6.99 kB
JavaScript
'use strict';
var jsKit = require('@dxkit-org/js-kit');
var jsonwebtoken = require('jsonwebtoken');
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
var jsonwebtoken__default = /*#__PURE__*/_interopDefault(jsonwebtoken);
// src/jwt/index.ts
async function jwtVerify(input) {
const { token, secret, options = {} } = input;
try {
jsKit.assertNodeEnvironment();
} catch (error) {
return {
status: "error",
error: {
code: "environment_error",
message: "JWT operations are only supported in Node.js environment",
originalError: error
}
};
}
return new Promise((resolve) => {
if (!token || typeof token !== "string") {
return resolve({
status: "error",
error: {
code: "invalid_token",
message: "Invalid token: Token must be a non-empty string"
}
});
}
if (!secret) {
return resolve({
status: "error",
error: {
code: "invalid_secret",
message: "Invalid secret: Secret is required for token verification"
}
});
}
jsonwebtoken__default.default.verify(token, secret, options, (err, decoded) => {
if (err) {
return resolve({
status: "error",
error: {
code: "verification_failed",
message: `JWT verification failed: ${err.message}`,
originalError: err
}
});
}
if (!decoded || typeof decoded === "string") {
return resolve({
status: "error",
error: {
code: "invalid_payload",
message: "Invalid payload: Expected object payload"
}
});
}
resolve({
status: "success",
data: decoded
});
});
});
}
async function jwtSign(input) {
const { payload, secret, options = {} } = input;
try {
jsKit.assertNodeEnvironment();
} catch (error) {
return {
status: "error",
error: {
code: "environment_error",
message: "JWT operations are only supported in Node.js environment",
originalError: error
}
};
}
const { defaultExpiresIn, ...signOptions } = options;
return new Promise((resolve) => {
if (!payload || typeof payload !== "object") {
return resolve({
status: "error",
error: {
code: "invalid_payload",
message: "Invalid payload: Payload must be an object"
}
});
}
if (!secret) {
return resolve({
status: "error",
error: {
code: "invalid_secret",
message: "Invalid secret: Secret is required for token signing"
}
});
}
const finalOptions = {
...signOptions,
...defaultExpiresIn && !signOptions.expiresIn && { expiresIn: defaultExpiresIn }
};
jsonwebtoken__default.default.sign(
payload,
secret,
finalOptions,
(err, token) => {
if (err) {
return resolve({
status: "error",
error: {
code: "signing_failed",
message: `JWT signing failed: ${err.message}`,
originalError: err
}
});
}
if (!token) {
return resolve({
status: "error",
error: {
code: "signing_failed",
message: "JWT signing failed: No token generated"
}
});
}
resolve({
status: "success",
data: token
});
}
);
});
}
function jwtDecode(input) {
const { token, options = {} } = input;
try {
if (!token || typeof token !== "string") {
return {
status: "error",
error: {
code: "invalid_token",
message: "Invalid token: Token must be a non-empty string"
}
};
}
const decoded = jsonwebtoken__default.default.decode(token, options);
if (!decoded) {
return {
status: "error",
error: {
code: "decode_failed",
message: "Failed to decode token: Invalid token format"
}
};
}
return {
status: "success",
data: decoded
};
} catch (error) {
return {
status: "error",
error: {
code: "decode_failed",
message: `Failed to decode token: ${error instanceof Error ? error.message : "Unknown error"}`,
originalError: error instanceof Error ? error : void 0
}
};
}
}
function jwtIsExpired(input) {
const { token } = input;
const decoded = jwtDecode({ token });
if (decoded.status === "error") {
return decoded;
}
if (!decoded.data.exp) {
return {
status: "error",
error: {
code: "invalid_payload",
message: "Token does not contain expiration time (exp claim)"
}
};
}
const currentTime = Math.floor(Date.now() / 1e3);
return {
status: "success",
data: decoded.data.exp < currentTime
};
}
function jwtTimeUntilExpiry(input) {
const { token } = input;
const decoded = jwtDecode({ token });
if (decoded.status === "error") {
return decoded;
}
if (!decoded.data.exp) {
return {
status: "error",
error: {
code: "invalid_payload",
message: "Token does not contain expiration time (exp claim)"
}
};
}
const currentTime = Math.floor(Date.now() / 1e3);
const timeLeft = decoded.data.exp - currentTime;
return {
status: "success",
data: timeLeft > 0 ? timeLeft : 0
};
}
function isJwtSuccess(result) {
return result.status === "success";
}
function isJwtError(result) {
return result.status === "error";
}
function unwrapJwtResult(result) {
if (result.status === "success") {
return result.data;
}
throw new Error(`JWT ${result.error.code}: ${result.error.message}`);
}
var jwt = {
/**
* Verifies a JWT token and returns a result object.
* Alias for jwtVerify function.
*/
verify: jwtVerify,
/**
* Signs a payload and creates a JWT token, returns a result object.
* Alias for jwtSign function.
*/
sign: jwtSign,
/**
* Decodes a JWT token without verification, returns a result object.
* Alias for jwtDecode function.
*/
decode: jwtDecode,
/**
* Checks if a JWT token is expired, returns a result object.
* Alias for jwtIsExpired function.
*/
isExpired: jwtIsExpired,
/**
* Gets the remaining time until token expiration, returns a result object.
* Alias for jwtTimeUntilExpiry function.
*/
timeUntilExpiry: jwtTimeUntilExpiry
};
exports.isJwtError = isJwtError;
exports.isJwtSuccess = isJwtSuccess;
exports.jwt = jwt;
exports.jwtDecode = jwtDecode;
exports.jwtIsExpired = jwtIsExpired;
exports.jwtSign = jwtSign;
exports.jwtTimeUntilExpiry = jwtTimeUntilExpiry;
exports.jwtVerify = jwtVerify;
exports.unwrapJwtResult = unwrapJwtResult;
//# sourceMappingURL=index.cjs.map
//# sourceMappingURL=index.cjs.map