2025-10-17 14:12:27 -03:00
|
|
|
const express = require("express");
|
|
|
|
|
const { getAuthUrl, getTokenFromCode } = require("../service/authService");
|
2025-10-17 10:48:40 -03:00
|
|
|
|
|
|
|
|
const router = express.Router();
|
|
|
|
|
|
|
|
|
|
// Rota para iniciar o fluxo de autenticação
|
|
|
|
|
router.get("/login", (req, res) => {
|
2025-10-17 14:12:27 -03:00
|
|
|
const authUrl = getAuthUrl();
|
|
|
|
|
return res.redirect(authUrl);
|
2025-10-17 10:48:40 -03:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// Rota de callback após autenticação
|
|
|
|
|
router.get("/auth/callback", async (req, res) => {
|
2025-10-17 14:12:27 -03:00
|
|
|
const code = req.query.code;
|
|
|
|
|
|
|
|
|
|
if (!code) {
|
|
|
|
|
return res.status(400).send("Código de autenticação não fornecido.");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
const tokens = await getTokenFromCode(code);
|
|
|
|
|
// Armazena os tokens na sessão do usuário
|
|
|
|
|
if (!req.session) req.session = {};
|
|
|
|
|
req.session.tokens = tokens;
|
2025-10-20 07:44:56 -03:00
|
|
|
return res.redirect("../public/index.html");
|
2025-10-17 14:12:27 -03:00
|
|
|
} catch (error) {
|
|
|
|
|
console.error("Erro ao obter tokens:", error);
|
|
|
|
|
return res.status(500).send("Erro ao processar a autenticação.");
|
|
|
|
|
}
|
|
|
|
|
});
|
2025-10-17 10:48:40 -03:00
|
|
|
|
2025-10-17 14:12:27 -03:00
|
|
|
module.exports = router;
|