microservices/auth-service/passport.js

52 lines
1.2 KiB
JavaScript
Raw Normal View History

2025-05-02 12:41:41 -07:00
require("dotenv").config();
2025-04-16 10:49:46 -07:00
const GoogleStrategy = require("passport-google-oauth20").Strategy;
const passport = require("passport");
2025-05-02 12:41:41 -07:00
const CustomStrategy = require("passport-custom").Strategy;
2025-04-16 10:49:46 -07:00
passport.use(
2025-05-02 12:41:41 -07:00
new GoogleStrategy(
{
clientID: process.env.GOOGLE_CLIENT_ID,
clientSecret: process.env.GOOGLE_CLIENT_SECRET,
callbackURL: process.env.GOOGLE_CALLBACK_URL,
scope: ["profile", "email"],
},
function (accessToken, refreshToken, profile, callback) {
callback(null, profile);
}
)
);
passport.use(
"student-auth",
new CustomStrategy(async (req, done) => {
const { assignment, password } = req.body;
2025-04-16 10:49:46 -07:00
2025-05-02 12:41:41 -07:00
try {
// Call your external auth service
const response = await axios.post("http://localhost:8082/student/verify", {
assignment,
password,
});
2025-04-16 10:49:46 -07:00
2025-05-02 12:41:41 -07:00
if (response.data && response.data.success) {
const user = response.data.user;
return done(null, user); // success
} else {
return done(null, false, { message: "Invalid credentials" });
}
} catch (err) {
return done(err);
}
})
2025-04-16 10:49:46 -07:00
);
passport.serializeUser((user, done) => {
2025-05-02 12:41:41 -07:00
done(null, user);
2025-04-16 10:49:46 -07:00
});
passport.deserializeUser((user, done) => {
2025-05-02 12:41:41 -07:00
done(null, user);
});