-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathserver.js
More file actions
67 lines (51 loc) · 1.62 KB
/
server.js
File metadata and controls
67 lines (51 loc) · 1.62 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
import express from "express";
import cors from "cors";
import { WebSocketServer } from "ws";
import http from "http";
import { config } from "dotenv";
config();
const app = express();
const port = process.env.PORT || 5000;
app.use(cors({
origin: process.env.ALLOWED_ORIGINS?.split(",") || ["http://localhost:5173"],
methods: ["GET", "POST", "PUT"],
}));
app.use(express.json());
const server = http.createServer(app);
const wss = new WebSocketServer({ server });
const broadcast = (data) => {
console.log("Enviando dados para WebSocket:", data);
wss.clients.forEach((client) => {
if (client.readyState === client.OPEN) {
client.send(JSON.stringify(data));
}
});
};
app.get("/teste", (req, res) => {
console.log("Rota de teste acessada.");
res.send("<h1>Servidor rodando!</h1>");
});
app.post("/v1/webhook", (req, res) => {
console.log("Webhook recebido:", req.body);
const { action, data } = req.body;
if (action === "payment.updated") {
console.log(`Pagamento atualizado: ${data.id} - Enviando via WebSocket`);
broadcast({ paymentId: data.id, status: "Pago" });
}
res.json({ message: "Webhook processado com sucesso" });
});
wss.on("connection", (socket) => {
console.log("Novo cliente conectado ao WebSocket");
socket.on("message", (message) => {
console.log("Mensagem recebida do cliente:", message);
});
socket.on("close", () => {
console.log("Cliente desconectado do WebSocket");
});
socket.on("error", (err) => {
console.error("Erro no WebSocket:", err);
});
});
server.listen(port, () => {
console.log(`Servidor rodando em http://localhost:${port}`);
});