2025-03-10 19:25:11 +01:00

52 lines
1.3 KiB
JavaScript

import express from "express";
import crypto from "crypto";
const SERVER_PORT = 5080;
const API_KEY = "meet-api-key";
const MAX_ELAPSED_TIME = 5 * 60 * 1000; // 5 minutes in milliseconds
const app = express();
app.use(express.json());
app.post("/webhook", (req, res) => {
const body = req.body;
const headers = req.headers;
if (!isWebhookEventValid(body, headers)) {
console.error("Invalid webhook signature");
return res.status(401).send("Invalid webhook signature");
}
console.log("Webhook received:", body);
res.status(200).send();
});
app.listen(SERVER_PORT, () =>
console.log("Webhook server listening on port 3000")
);
function isWebhookEventValid(body, headers) {
const signature = headers["x-signature"];
const timestamp = parseInt(headers["x-timestamp"], 10);
if (!signature || !timestamp || isNaN(timestamp)) {
return false;
}
const current = Date.now();
const diffTime = current - timestamp;
const signedPayload = `${timestamp}.${JSON.stringify(body)}`;
const expectedSignature = crypto
.createHmac("sha256", API_KEY)
.update(signedPayload)
.digest("hex");
return (
crypto.timingSafeEqual(
Buffer.from(expectedSignature, "utf-8"),
Buffer.from(signature, "utf-8")
) && diffTime < MAX_ELAPSED_TIME
);
}