32 lines
816 B
JavaScript
32 lines
816 B
JavaScript
const jwt = require('jsonwebtoken');
|
|
|
|
exports.handleCallback = async (req, res) => {
|
|
try {
|
|
if (!req.user.isAccountSetupComplete) {
|
|
res.redirect('/register');
|
|
} else {
|
|
const sessionExpiration = parseInt(process.env.SESSION_EXPIRATION, 10);
|
|
const token = jwt.sign(
|
|
{ userId: req.user.id },
|
|
process.env.JWT_SECRET,
|
|
{ expiresIn: sessionExpiration }
|
|
);
|
|
|
|
// JWTトークンをクッキーに保存
|
|
res.cookie('jwt', token, { httpOnly: true, maxAge: sessionExpiration * 1000 });
|
|
|
|
// Dashboardへリダイレクト
|
|
res.redirect('/dashboard');
|
|
}
|
|
} catch (err) {
|
|
console.error(err);
|
|
res.status(500).send('Internal Server Error');
|
|
}
|
|
};
|
|
|
|
exports.logout = (req, res) => {
|
|
req.logout(() => {
|
|
res.redirect('/');
|
|
});
|
|
};
|