41 lines
1.2 KiB
JavaScript
41 lines
1.2 KiB
JavaScript
const express = require("express");
|
|
const { getAuthUrl, getTokenFromCode } = require("../service/authService");
|
|
|
|
const router = express.Router();
|
|
|
|
router.get("/login", (req, res) => {
|
|
return res.redirect(getAuthUrl());
|
|
});
|
|
|
|
router.get("/auth/callback", async (req, res) => {
|
|
console.log("[auth callback] query:", req.query);
|
|
const code = req.query.code;
|
|
|
|
if (!code) {
|
|
console.warn("[auth callback] código ausente");
|
|
return res.status(400).send("Código de autenticação não fornecido.");
|
|
}
|
|
|
|
try {
|
|
const tokens = await getTokenFromCode(code);
|
|
|
|
// sessão já existe (criada pelo express-session)
|
|
req.session.tokens = tokens;
|
|
req.session.user = { authenticated: true };
|
|
|
|
req.session.save((err) => {
|
|
if (err) {
|
|
console.error("[auth callback] erro ao salvar sessão:", err);
|
|
return res.status(500).send("Erro ao salvar sessão.");
|
|
}
|
|
console.log("[auth callback] sessão salva, redirecionando");
|
|
return res.redirect("/app");
|
|
});
|
|
} catch (error) {
|
|
console.error("[auth callback] Erro ao obter tokens:", error.response?.data || error.message || error);
|
|
return res.status(500).send("Erro ao processar a autenticação. Veja logs do servidor.");
|
|
}
|
|
});
|
|
|
|
module.exports = router;
|