2024-10-28 09:20:09 +00:00
|
|
|
<?php
|
|
|
|
|
2025-01-13 08:45:31 +00:00
|
|
|
// Get any new messages
|
|
|
|
include '../app/includes/messages.php';
|
|
|
|
include '../app/includes/messages-show.php';
|
|
|
|
|
2024-10-28 09:20:09 +00:00
|
|
|
$action = $_REQUEST['action'] ?? '';
|
|
|
|
$agent = $_REQUEST['agent'] ?? '';
|
|
|
|
|
|
|
|
require '../app/classes/config.php';
|
|
|
|
require '../app/classes/agent.php';
|
2025-01-14 13:37:20 +00:00
|
|
|
require '../app/classes/conference.php';
|
2024-10-28 09:20:09 +00:00
|
|
|
|
|
|
|
$configObject = new Config();
|
|
|
|
$agentObject = new Agent($dbWeb);
|
|
|
|
|
2025-01-14 13:37:20 +00:00
|
|
|
// connect to Jilo database
|
|
|
|
$response = connectDB($config, 'jilo', $platformDetails[0]['jilo_database'], $platform_id);
|
|
|
|
|
|
|
|
// if DB connection has error, display it and stop here
|
|
|
|
if ($response['db'] === null) {
|
|
|
|
$error = $response['error'];
|
|
|
|
include '../app/templates/block-message.php';
|
|
|
|
|
|
|
|
// otherwise if DB connection is OK, go on
|
|
|
|
} else {
|
|
|
|
$db = $response['db'];
|
|
|
|
|
|
|
|
$conferenceObject = new Conference($db);
|
|
|
|
|
|
|
|
switch ($item) {
|
|
|
|
|
|
|
|
case 'graphs':
|
|
|
|
// Connect to Jilo database for log data
|
|
|
|
$jilo_response = connectDB($config, 'jilo', $platformDetails[0]['jilo_database'], $platform_id);
|
|
|
|
if ($jilo_response['db'] === null) {
|
|
|
|
$error = $jilo_response['error'];
|
|
|
|
include '../app/templates/block-message.php';
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
$jilo_db = $jilo_response['db'];
|
|
|
|
|
|
|
|
// Get date range for the last 7 days
|
|
|
|
$from_time = date('Y-m-d', strtotime('-7 days'));
|
|
|
|
$until_time = date('Y-m-d');
|
|
|
|
|
|
|
|
// Define graphs to show
|
|
|
|
$graphs = [
|
|
|
|
[
|
|
|
|
'graph_name' => 'conferences',
|
|
|
|
'graph_title' => 'Conferences in "' . htmlspecialchars($platformDetails[0]['name']) . '" over time',
|
|
|
|
'datasets' => []
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'graph_name' => 'participants',
|
|
|
|
'graph_title' => 'Participants in "' . htmlspecialchars($platformDetails[0]['name']) . '" over time',
|
|
|
|
'datasets' => []
|
|
|
|
]
|
2025-01-13 15:54:42 +00:00
|
|
|
];
|
2025-01-14 12:09:28 +00:00
|
|
|
|
2025-01-14 13:37:20 +00:00
|
|
|
// Get Jitsi API data
|
|
|
|
$conferences_api = $agentObject->getHistoricalData(
|
|
|
|
$platform_id,
|
|
|
|
'jicofo',
|
|
|
|
'conferences',
|
|
|
|
$from_time,
|
|
|
|
$until_time
|
|
|
|
);
|
|
|
|
$graphs[0]['datasets'][] = [
|
|
|
|
'data' => $conferences_api,
|
|
|
|
'label' => 'Conferences from Jitsi API',
|
|
|
|
'color' => 'rgba(75, 192, 192, 1)'
|
|
|
|
];
|
|
|
|
|
|
|
|
// Get conference data from logs
|
|
|
|
$conferences_logs = $conferenceObject->conferenceNumber(
|
|
|
|
$from_time,
|
|
|
|
$until_time
|
|
|
|
);
|
|
|
|
$graphs[0]['datasets'][] = [
|
|
|
|
'data' => $conferences_logs,
|
|
|
|
'label' => 'Conferences from Logs',
|
|
|
|
'color' => 'rgba(255, 99, 132, 1)'
|
|
|
|
];
|
|
|
|
|
|
|
|
// Get participants data
|
|
|
|
$participants_api = $agentObject->getHistoricalData(
|
|
|
|
$platform_id,
|
|
|
|
'jicofo',
|
|
|
|
'participants',
|
|
|
|
$from_time,
|
|
|
|
$until_time
|
|
|
|
);
|
|
|
|
$graphs[1]['datasets'][] = [
|
|
|
|
'data' => $participants_api,
|
|
|
|
'label' => 'Participants from Jitsi API',
|
|
|
|
'color' => 'rgba(75, 192, 192, 1)'
|
|
|
|
];
|
|
|
|
|
|
|
|
// Prepare data for template
|
|
|
|
$graph = $graphs;
|
|
|
|
|
2025-01-14 13:46:43 +00:00
|
|
|
// prepare the widget
|
|
|
|
$widget['full'] = false;
|
|
|
|
$widget['name'] = 'Graphs';
|
|
|
|
$widget['title'] = 'Jitsi graphs';
|
|
|
|
|
2025-01-14 13:37:20 +00:00
|
|
|
include '../app/templates/graphs-combined.php';
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'latest':
|
|
|
|
// Define metrics to display
|
|
|
|
$metrics = [
|
|
|
|
'Basic stats' => [
|
|
|
|
'conferences' => ['label' => 'Current conferences', 'link' => 'conferences'],
|
|
|
|
'participants' => ['label' => 'Current participants', 'link' => 'participants'],
|
|
|
|
'total_conferences_created' => ['label' => 'Total conferences created'],
|
|
|
|
'total_participants' => ['label' => 'Total participants']
|
|
|
|
],
|
|
|
|
'Bridge stats' => [
|
|
|
|
'bridge_selector.bridge_count' => ['label' => 'Bridge count'],
|
|
|
|
'bridge_selector.operational_bridge_count' => ['label' => 'Operational bridges'],
|
|
|
|
'bridge_selector.in_shutdown_bridge_count' => ['label' => 'Bridges in shutdown']
|
|
|
|
],
|
|
|
|
'Jibri stats' => [
|
|
|
|
'jibri_detector.count' => ['label' => 'Jibri count'],
|
|
|
|
'jibri_detector.available' => ['label' => 'Jibri idle'],
|
|
|
|
'jibri.live_streaming_active' => ['label' => 'Jibri active streaming'],
|
|
|
|
'jibri.recording_active' => ['label' => 'Jibri active recording'],
|
|
|
|
|
|
|
|
],
|
|
|
|
'System stats' => [
|
|
|
|
'threads' => ['label' => 'Threads'],
|
|
|
|
'stress_level' => ['label' => 'Stress level'],
|
|
|
|
'version' => ['label' => 'Version']
|
|
|
|
]
|
|
|
|
];
|
|
|
|
|
|
|
|
// Get latest data for all the agents
|
|
|
|
$agents = ['jvb', 'jicofo', 'jibri', 'prosody', 'nginx'];
|
|
|
|
$widget['records'] = [];
|
|
|
|
|
|
|
|
// Initialize records for each agent
|
|
|
|
foreach ($agents as $agent) {
|
|
|
|
$record = [
|
|
|
|
'table_headers' => strtoupper($agent),
|
|
|
|
'metrics' => [],
|
|
|
|
'timestamp' => null
|
|
|
|
];
|
|
|
|
|
|
|
|
// Fetch all metrics for this agent
|
|
|
|
foreach ($metrics as $section => $section_metrics) {
|
2025-01-15 16:22:09 +00:00
|
|
|
foreach ($section_metrics as $metric => $metricConfig) {
|
2025-01-14 13:37:20 +00:00
|
|
|
$data = $agentObject->getLatestData($platform_id, $agent, $metric);
|
|
|
|
if ($data !== null) {
|
|
|
|
$record['metrics'][$section][$metric] = [
|
|
|
|
'value' => $data['value'],
|
2025-01-15 16:22:09 +00:00
|
|
|
'label' => $metricConfig['label'],
|
|
|
|
'link' => isset($metricConfig['link']) ? $metricConfig['link'] : null
|
2025-01-14 13:37:20 +00:00
|
|
|
];
|
|
|
|
// Use the most recent timestamp
|
|
|
|
if ($record['timestamp'] === null || strtotime($data['timestamp']) > strtotime($record['timestamp'])) {
|
|
|
|
$record['timestamp'] = $data['timestamp'];
|
|
|
|
}
|
2025-01-14 12:09:28 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2025-01-14 13:37:20 +00:00
|
|
|
|
|
|
|
if (!empty($record['metrics'])) {
|
|
|
|
$widget['records'][] = $record;
|
|
|
|
}
|
2025-01-14 12:09:28 +00:00
|
|
|
}
|
|
|
|
|
2025-01-14 13:37:20 +00:00
|
|
|
// prepare the widget
|
|
|
|
$widget['full'] = false;
|
|
|
|
$widget['name'] = 'LatestData';
|
|
|
|
$widget['title'] = 'Latest data from Jilo Agents';
|
|
|
|
$widget['collapsible'] = false;
|
|
|
|
$widget['collapsed'] = false;
|
|
|
|
$widget['filter'] = false;
|
|
|
|
$widget['metrics'] = $metrics; // Pass metrics configuration to template
|
|
|
|
if (!empty($widget['records'])) {
|
|
|
|
$widget['full'] = true;
|
2025-01-14 12:09:28 +00:00
|
|
|
}
|
2025-01-14 13:37:20 +00:00
|
|
|
$widget['pagination'] = false;
|
|
|
|
|
|
|
|
include '../app/templates/latest-data.php';
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'configjs':
|
|
|
|
$mode = $_REQUEST['mode'] ?? '';
|
|
|
|
$raw = ($mode === 'raw');
|
|
|
|
$platformConfigjs = $configObject->getPlatformConfigjs($platformDetails[0]['jitsi_url'], $raw);
|
|
|
|
include '../app/templates/data-configjs.php';
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'interfaceconfigjs':
|
|
|
|
$mode = $_REQUEST['mode'] ?? '';
|
|
|
|
$raw = ($mode === 'raw');
|
|
|
|
$platformInterfaceConfigjs = $configObject->getPlatformInterfaceConfigjs($platformDetails[0]['jitsi_url'], $raw);
|
|
|
|
include '../app/templates/data-interfaceconfigjs.php';
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
}
|
|
|
|
|
2024-10-29 11:15:14 +00:00
|
|
|
}
|
2024-10-28 09:20:09 +00:00
|
|
|
|
|
|
|
?>
|