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);
|
|
|
|
|
});
|