2025-09-05 14:09:06 +02:00

61 lines
1.7 KiB
PHP

<?php
const MAX_WEBHOOK_AGE = 120 * 1000; // 2 minutes in milliseconds
const OPENVIDU_MEET_API_KEY = "meet-api-key";
$requestPath = parse_url($_SERVER['REQUEST_URI'], PHP_URL_PATH);
$requestMethod = $_SERVER['REQUEST_METHOD'] ?? 'GET';
if ($requestMethod === 'POST' && $requestPath === '/webhook') {
handleWebhook();
} else {
http_response_code(404);
echo "Not Found\n";
}
function handleWebhook()
{
$body = json_decode(file_get_contents('php://input'), true) ?? [];
$headers = array_change_key_case(getallheaders(), CASE_LOWER);
// Convert header keys to lowercase for consistent access
$headers = array_change_key_case($headers, CASE_LOWER);
if (!isWebhookEventValid($body, $headers)) {
http_response_code(401);
echo "Invalid webhook signature\n";
return;
}
http_response_code(200);
$msg = "Webhook received: " . json_encode($body);
echo $msg . "\n";
error_log($msg); // Log to server console
}
function isWebhookEventValid($body, $headers)
{
$signature = $headers['x-signature'] ?? null;
$timestampStr = $headers['x-timestamp'] ?? null;
if (!$signature || !$timestampStr) {
return false;
}
$timestamp = filter_var($timestampStr, FILTER_VALIDATE_INT);
if ($timestamp === false) {
return false;
}
$current = intval(microtime(true) * 1000);
$diffTime = $current - $timestamp;
if ($diffTime >= MAX_WEBHOOK_AGE) {
return false;
}
$signedPayload = $timestamp . '.' . json_encode($body, JSON_UNESCAPED_SLASHES);
$expected = hash_hmac('sha256', $signedPayload, OPENVIDU_MEET_API_KEY);
return hash_equals($expected, $signature);
}