mirror of
https://github.com/hex248/sprint.git
synced 2026-02-08 02:33:01 +00:00
use HS256 for JWT signing
This commit is contained in:
@@ -2,12 +2,16 @@ import bcrypt from "bcrypt";
|
|||||||
import * as jwt from "jsonwebtoken";
|
import * as jwt from "jsonwebtoken";
|
||||||
|
|
||||||
const JWT_EXPIRES_IN = (process.env.JWT_EXPIRES_IN ?? "7d") as jwt.SignOptions["expiresIn"];
|
const JWT_EXPIRES_IN = (process.env.JWT_EXPIRES_IN ?? "7d") as jwt.SignOptions["expiresIn"];
|
||||||
|
const JWT_ALGORITHM = "HS256";
|
||||||
|
|
||||||
const requireJwtSecret = () => {
|
const requireJwtSecret = () => {
|
||||||
const secret = process.env.JWT_SECRET;
|
const secret = process.env.JWT_SECRET;
|
||||||
if (!secret) {
|
if (!secret) {
|
||||||
throw new Error("JWT_SECRET is required");
|
throw new Error("JWT_SECRET is required");
|
||||||
}
|
}
|
||||||
|
if (secret.length < 32) {
|
||||||
|
throw new Error("JWT_SECRET must be at least 32 characters");
|
||||||
|
}
|
||||||
return secret;
|
return secret;
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -17,10 +21,15 @@ export const verifyPassword = (password: string, hash: string) => bcrypt.compare
|
|||||||
|
|
||||||
export const generateToken = (userId: number) => {
|
export const generateToken = (userId: number) => {
|
||||||
const secret = requireJwtSecret();
|
const secret = requireJwtSecret();
|
||||||
return jwt.sign({ userId }, secret, { expiresIn: JWT_EXPIRES_IN });
|
return jwt.sign({ userId }, secret, {
|
||||||
|
expiresIn: JWT_EXPIRES_IN,
|
||||||
|
algorithm: JWT_ALGORITHM,
|
||||||
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
export const verifyToken = (token: string) => {
|
export const verifyToken = (token: string) => {
|
||||||
const secret = requireJwtSecret();
|
const secret = requireJwtSecret();
|
||||||
return jwt.verify(token, secret) as { userId: number };
|
return jwt.verify(token, secret, {
|
||||||
|
algorithms: [JWT_ALGORITHM],
|
||||||
|
}) as { userId: number };
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user