diff options
| author | Vidhu Kant Sharma <vidhukant@vidhukant.com> | 2025-04-13 18:26:41 +0530 |
|---|---|---|
| committer | Vidhu Kant Sharma <vidhukant@vidhukant.com> | 2025-04-13 18:26:41 +0530 |
| commit | 13bf1d14499e9cbb9d99c8bbc350e3cb5a7a4fd2 (patch) | |
| tree | 3b6a3aba7543f38b142fc4ab52870ad88b46ff99 /src/util/auth.ts | |
first commit
Diffstat (limited to 'src/util/auth.ts')
| -rw-r--r-- | src/util/auth.ts | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/src/util/auth.ts b/src/util/auth.ts new file mode 100644 index 0000000..d892bc3 --- /dev/null +++ b/src/util/auth.ts @@ -0,0 +1,39 @@ +import jwt from 'jsonwebtoken'; + +const getAccessToken = (userId: Number) => + // @ts-ignore + jwt.sign({ userId: userId }, process.env.ACCESS_TOKEN_SECRET, { expiresIn: "5m" }); + +const getRefreshToken = (userId: Number, version: Number) => + // @ts-ignore + jwt.sign({ userId: userId, version: version, }, process.env.REFRESH_TOKEN_SECRET, { expiresIn: "15d" }); + +const verifyRefreshToken = (token: string) => { + try { + // @ts-ignore + return jwt.verify(token, process.env.REFRESH_TOKEN_SECRET); + } catch (error) { + throw error; + } +} + +const getFriendToken = (userId: Number) => + // @ts-ignore + jwt.sign({ userId: userId }, process.env.FRIEND_TOKEN_SECRET, { expiresIn: "2m" }); + +const verifyFriendToken = (token: string) => { + try { + // @ts-ignore + return jwt.verify(token, process.env.FRIEND_TOKEN_SECRET); + } catch (error) { + throw error; + } +} + +export { + getAccessToken, + getRefreshToken, + verifyRefreshToken, + getFriendToken, + verifyFriendToken, +};
\ No newline at end of file |