jilo-web/public_html/index.php

221 lines
5.9 KiB
PHP
Raw Normal View History

<?php
2024-07-01 09:45:07 +00:00
/**
* Jilo web logs observer
*
* Description: A web interface to Jilo (JItsi Logs Observer), written in PHP
* Author: Yasen Pramatarov
* License: GPLv2
* Project URL: https://lindeas.com/jilo
2025-01-15 17:06:12 +00:00
* Year: 2024-2025
* Version: 0.3
2024-07-01 09:45:07 +00:00
*/
2024-08-19 10:25:09 +00:00
// we start output buffering and.
// flush it later only when there is no redirect
ob_start();
2024-10-04 11:18:28 +00:00
// sanitize all input vars that may end up in URLs or forms
require '../app/includes/sanitize.php';
2024-10-04 08:36:45 +00:00
// Initialize message system
require_once '../app/classes/messages.php';
$messages = [];
2025-01-07 11:02:57 +00:00
//include '../app/includes/messages.php';
require '../app/includes/errors.php';
// error reporting, comment out in production
ini_set('display_errors', 1);
ini_set('display_startup_errors', 1);
error_reporting(E_ALL);
2024-07-01 09:45:07 +00:00
// list of available pages
// edit accordingly, add 'pages/PAGE.php'
$allowed_urls = [
2024-09-13 11:02:59 +00:00
'dashboard',
'conferences',
'participants',
2024-07-08 09:17:35 +00:00
'components',
2024-09-13 11:02:59 +00:00
'data',
2024-10-08 10:23:38 +00:00
'latest',
2024-09-13 11:02:59 +00:00
'agents',
'profile',
'config',
2024-10-19 13:09:16 +00:00
'status',
2024-09-13 11:02:59 +00:00
'logs',
2025-01-04 10:30:44 +00:00
'security',
2024-10-07 07:00:15 +00:00
'help',
2024-09-13 11:02:59 +00:00
'login',
'logout',
'register',
2024-07-01 09:45:07 +00:00
];
// cnfig file
2024-08-01 08:20:31 +00:00
// possible locations, in order of preference
$config_file_locations = [
2024-08-12 11:12:24 +00:00
__DIR__ . '/../app/config/jilo-web.conf.php',
2024-08-01 08:20:31 +00:00
__DIR__ . '/../jilo-web.conf.php',
'/srv/jilo-web/jilo-web.conf.php',
'/opt/jilo-web/jilo-web.conf.php'
];
$config_file = null;
// try to find the config file
foreach ($config_file_locations as $location) {
if (file_exists($location)) {
$config_file = $location;
break;
}
}
// if found, use it
if ($config_file) {
2024-08-13 14:53:52 +00:00
$config = require $config_file;
2024-07-01 09:45:07 +00:00
} else {
die('Config file not found');
}
2024-10-04 15:13:55 +00:00
$app_root = $config['folder'];
2024-08-10 18:42:44 +00:00
session_name('jilo');
2024-07-01 09:45:07 +00:00
session_start();
2024-07-03 06:37:35 +00:00
// check if logged in
unset($currentUser);
2024-07-03 06:37:35 +00:00
if (isset($_COOKIE['username'])) {
if ( !isset($_SESSION['username']) ) {
$_SESSION['username'] = $_COOKIE['username'];
}
$currentUser = htmlspecialchars($_SESSION['username']);
2024-07-01 09:45:07 +00:00
}
2024-07-01 09:45:07 +00:00
// redirect to login
2024-07-03 15:15:32 +00:00
if ( !isset($_COOKIE['username']) && ($page !== 'login' && $page !== 'register') ) {
2024-10-23 12:28:45 +00:00
header('Location: ' . htmlspecialchars($app_root) . '?page=login');
exit();
}
// connect to db of Jilo Web
require '../app/classes/database.php';
require '../app/includes/database.php';
try {
$response = connectDB($config);
if (!$response['db']) {
throw new Exception('Could not connect to database: ' . $response['error']);
}
2024-11-09 11:06:43 +00:00
$dbWeb = $response['db'];
} catch (Exception $e) {
Messages::flash('ERROR', 'DEFAULT', getError('Error connecting to the database.', $e->getMessage()));
include '../app/templates/page-header.php';
include '../app/includes/messages.php';
include '../app/includes/messages-show.php';
include '../app/templates/page-footer.php';
exit();
2024-11-09 11:06:43 +00:00
}
2024-09-16 14:09:37 +00:00
// start logging
require '../app/classes/log.php';
2024-09-17 11:22:43 +00:00
include '../app/helpers/logs.php';
2024-09-16 14:09:37 +00:00
$logObject = new Log($dbWeb);
2024-09-17 11:22:43 +00:00
$user_IP = getUserIP();
2024-09-16 14:09:37 +00:00
// init rate limiter
require '../app/classes/ratelimiter.php';
// get platforms details
require '../app/classes/platform.php';
$platformObject = new Platform($dbWeb);
$platformsAll = $platformObject->getPlatformDetails();
2024-08-17 08:20:08 +00:00
// by default we connect ot the first configured platform
2024-10-04 08:36:45 +00:00
if ($platform_id == '') {
$platform_id = $platformsAll[0]['id'];
}
$platformDetails = $platformObject->getPlatformDetails($platform_id);
2024-08-17 08:20:08 +00:00
2024-09-16 16:08:03 +00:00
// init user functions
require '../app/classes/user.php';
include '../app/helpers/profile.php';
$userObject = new User($dbWeb);
// logout is a special case, as we can't use session vars for notices
if ($page == 'logout') {
// clean up session
session_unset();
session_destroy();
setcookie('username', "", time() - 100, $config['folder'], $config['domain'], isset($_SERVER['HTTPS']), true);
// Log successful logout
2024-09-30 09:52:06 +00:00
$user_id = $userObject->getUserId($currentUser)[0]['id'];
$logObject->insertLog($user_id, "Logout: User \"$currentUser\" logged out. IP: $user_IP", 'user');
// Set success message
Messages::flash('LOGIN', 'LOGOUT_SUCCESS');
2025-01-04 10:30:44 +00:00
include '../app/templates/page-header.php';
include '../app/templates/page-menu.php';
include '../app/pages/login.php';
2025-01-04 10:30:44 +00:00
} else {
// if user is logged in, we need user details and rights
2024-09-13 10:49:17 +00:00
if (isset($currentUser)) {
2024-10-18 12:41:15 +00:00
2024-10-23 12:28:45 +00:00
// If by error a logged in user requests the login page
if ($page === 'login') {
header('Location: ' . htmlspecialchars($app_root));
exit();
}
2025-01-06 17:28:19 +00:00
$user_id = $userObject->getUserId($currentUser)[0]['id'];
$userDetails = $userObject->getUserDetails($user_id);
$userRights = $userObject->getUserRights($user_id);
$userTimezone = isset($userDetails[0]['timezone']) ? $userDetails[0]['timezone'] : 'UTC'; // Default to UTC if no timezone is set
2024-10-23 12:28:45 +00:00
2024-10-23 12:13:01 +00:00
// check if the Jilo Server is running
require '../app/classes/server.php';
$serverObject = new Server($dbWeb);
$server_host = '127.0.0.1';
$server_port = '8080';
$server_endpoint = '/health';
$server_status = $serverObject->getServerStatus($server_host, $server_port, $server_endpoint);
if (!$server_status) {
2025-01-07 11:02:57 +00:00
Messages::flash('ERROR', 'DEFAULT', 'The Jilo Server is not running. Some data may be old and incorrect.', false, true);
2024-10-23 12:13:01 +00:00
}
2024-10-18 12:41:15 +00:00
}
// page building
2024-09-13 11:02:59 +00:00
include '../app/templates/page-header.php';
include '../app/templates/page-menu.php';
if (isset($currentUser)) {
include '../app/templates/page-sidebar.php';
}
if (in_array($page, $allowed_urls)) {
// all normal pages
include "../app/pages/{$page}.php";
2024-07-01 09:45:07 +00:00
} else {
2024-09-13 11:02:59 +00:00
// the page is not in allowed urls, loading "not found" page
include '../app/templates/error-notfound.php';
2024-08-06 07:40:52 +00:00
}
}
// end with the footer
2024-08-12 11:12:24 +00:00
include '../app/templates/page-footer.php';
2024-08-19 10:25:09 +00:00
// flush the output buffer and show the page
ob_end_flush();
2024-07-01 09:45:07 +00:00
// clear errors and notices before next page just in case
unset($_SESSION['error']);
unset($_SESSION['notice']);
?>