Files
easystream-main/f_modules/api/srs_webhook.php
SamiAhmed7777 0b7e2d0a5b feat: Add comprehensive documentation suite and reorganize project structure
- Created complete documentation in docs/ directory
- Added PROJECT_OVERVIEW.md with feature highlights and getting started guide
- Added ARCHITECTURE.md with system design and technical details
- Added SECURITY.md with comprehensive security implementation guide
- Added DEVELOPMENT.md with development workflows and best practices
- Added DEPLOYMENT.md with production deployment instructions
- Added API.md with complete REST API documentation
- Added CONTRIBUTING.md with contribution guidelines
- Added CHANGELOG.md with version history and migration notes
- Reorganized all documentation files into docs/ directory for better organization
- Updated README.md with proper documentation links and quick navigation
- Enhanced project structure with professional documentation standards
2025-10-21 00:39:45 -07:00

129 lines
3.8 KiB
PHP

<?php
/*******************************************************************************************************************
| SRS Webhook Handler
| Handles callbacks from SRS server for live streaming events
|*******************************************************************************************************************/
define('_ISVALID', true);
require_once '../../f_core/config.core.php';
// Set JSON response headers
header('Content-Type: application/json');
header('Access-Control-Allow-Origin: *');
header('Access-Control-Allow-Methods: POST, GET, OPTIONS');
header('Access-Control-Allow-Headers: Content-Type');
// Handle preflight requests
if ($_SERVER['REQUEST_METHOD'] === 'OPTIONS') {
http_response_code(200);
exit;
}
try {
$liveStreaming = new VLiveStreaming();
$logger = VLogger::getInstance();
// Get request data
$input = file_get_contents('php://input');
$data = json_decode($input, true);
if (!$data) {
throw new Exception('Invalid JSON data');
}
// Determine action from URL path
$path = $_SERVER['REQUEST_URI'] ?? '';
$action = '';
// Parse SRS webhook action
if (isset($data['action'])) {
$action = $data['action'];
} elseif (strpos($path, 'on_connect') !== false) {
$action = 'on_connect';
} elseif (strpos($path, 'on_close') !== false) {
$action = 'on_close';
} elseif (strpos($path, 'on_publish') !== false) {
$action = 'on_publish';
} elseif (strpos($path, 'on_unpublish') !== false) {
$action = 'on_unpublish';
} elseif (strpos($path, 'on_play') !== false) {
$action = 'on_play';
} elseif (strpos($path, 'on_stop') !== false) {
$action = 'on_stop';
} elseif (strpos($path, 'on_dvr') !== false) {
$action = 'on_dvr';
} elseif (strpos($path, 'on_hls') !== false) {
$action = 'on_hls';
} elseif (strpos($path, 'heartbeat') !== false) {
$action = 'heartbeat';
}
$logger->info('SRS webhook received', [
'action' => $action,
'data' => $data,
'path' => $path
]);
// Handle heartbeat separately
if ($action === 'heartbeat') {
// Update SRS server status
updateSRSStatus($data);
echo json_encode(['code' => 0, 'message' => 'heartbeat received']);
exit;
}
// Handle stream webhooks
$response = $liveStreaming->handleSRSWebhook($action, $data);
echo json_encode($response);
} catch (Exception $e) {
$logger->error('SRS webhook error', [
'error' => $e->getMessage(),
'input' => $input ?? '',
'path' => $_SERVER['REQUEST_URI'] ?? ''
]);
// Return error response
echo json_encode([
'code' => 1,
'message' => $e->getMessage()
]);
}
/**
* Update SRS server status
* @param array $data Heartbeat data
*/
function updateSRSStatus($data)
{
try {
$db = VDatabase::getInstance();
$statusData = [
'server_id' => $data['device_id'] ?? 'srs-server',
'status' => 'online',
'last_heartbeat' => date('Y-m-d H:i:s'),
'data' => json_encode($data),
'updated_at' => date('Y-m-d H:i:s')
];
// Insert or update server status
$existing = $db->doQuery("SELECT id FROM db_srs_servers WHERE server_id = ?", [$statusData['server_id']]);
if ($db->doFetch($existing)) {
$db->doUpdate('db_srs_servers', 'server_id', $statusData, $statusData['server_id']);
} else {
$statusData['created_at'] = date('Y-m-d H:i:s');
$db->doInsert('db_srs_servers', $statusData);
}
} catch (Exception $e) {
VLogger::getInstance()->error('Failed to update SRS status', [
'error' => $e->getMessage(),
'data' => $data
]);
}
}
?>