passport-jwt/auth/auth.mts

72 lines
1.8 KiB
TypeScript
Raw Permalink Normal View History

2024-05-28 20:22:41 +00:00
import passport from 'passport'
import { Strategy as localStrategy } from 'passport-local'
2024-06-03 10:21:54 +00:00
import { User, encryptPwd, pwdIsValid } from '../model/model.mjs'
2024-05-28 20:22:41 +00:00
import { Strategy as JWTstrategy, ExtractJwt } from 'passport-jwt'
2024-05-29 17:22:58 +00:00
import { userDb } from '../db.mjs'
2024-05-28 20:22:41 +00:00
passport.use('signup', new localStrategy(
{
2024-05-29 17:22:58 +00:00
usernameField: 'username',
2024-05-28 20:22:41 +00:00
passwordField: 'password'
},
2024-05-29 17:22:58 +00:00
async (username, password, done) => {
console.log("signup auth strategy has begun")
2024-05-28 20:22:41 +00:00
try {
2024-05-29 17:22:58 +00:00
const encryptedPwd = await encryptPwd(password)
const user = await userDb("users").insert({ username: username, password: encryptedPwd }).returning(["username", "password"])
console.log(`user: ${user}`)
2024-05-28 20:22:41 +00:00
return done(null, user)
} catch (err) {
2024-05-29 17:22:58 +00:00
console.error(err)
2024-05-28 20:22:41 +00:00
done(err)
}
}))
2024-05-29 09:34:21 +00:00
passport.use('login',
2024-05-28 20:22:41 +00:00
new localStrategy(
{
2024-05-29 17:22:58 +00:00
usernameField: "username",
2024-05-28 20:22:41 +00:00
passwordField: "password",
session: false
},
async (email, password, done) => {
2024-05-29 09:34:21 +00:00
console.log("local strategy called")
2024-05-28 20:22:41 +00:00
try {
2024-05-29 17:22:58 +00:00
let returnedUser: Array<User> = await userDb("users").select("username", "password").where({ username: email })
const user: User = returnedUser[0]
2024-05-28 20:22:41 +00:00
console.log(`user: ${user}`)
2024-05-29 17:22:58 +00:00
if (!user || returnedUser.length === 0) {
2024-05-28 20:22:41 +00:00
return done(null, false, { message: "user not found" })
}
2024-05-29 17:22:58 +00:00
const validate: boolean = await pwdIsValid(password, user)
2024-05-29 09:34:21 +00:00
console.log(`isValidPassword? ${validate}`)
2024-05-28 20:22:41 +00:00
if (!validate) {
return done(null, false, { message: "wrong password" })
}
2024-05-29 09:34:21 +00:00
return done(null, user, { message: "logged in successfully" })
2024-05-28 20:22:41 +00:00
} catch (error) {
return done(error)
}
}
)
)
passport.use(
new JWTstrategy(
{
secretOrKey: "TOP_SECRET",
2024-05-29 13:52:57 +00:00
jwtFromRequest: ExtractJwt.fromAuthHeaderWithScheme('secret_token')
2024-05-28 20:22:41 +00:00
},
async (token, done) => {
try {
return done(null, token.user)
} catch (error) {
done(error)
}
}
)
)