jilo-web/app/pages/security.php

116 lines
5.1 KiB
PHP
Raw Normal View History

2025-01-04 10:30:44 +00:00
<?php
// Check if user has any of the required rights
if (!($userObject->hasRight($user_id, 'superuser') ||
$userObject->hasRight($user_id, 'edit whitelist') ||
$userObject->hasRight($user_id, 'edit blacklist') ||
$userObject->hasRight($user_id, 'edit ratelimiting'))) {
include '../app/templates/error-unauthorized.php';
exit;
}
// Include Messages class
require_once '../app/classes/messages.php';
2025-01-04 11:41:02 +00:00
// Initialize variables for feedback messages
$messages = [];
// Get current section
$section = isset($_POST['section']) ? $_POST['section'] : (isset($_GET['section']) ? $_GET['section'] : 'whitelist');
2025-01-04 10:30:44 +00:00
// Handle form submissions
2025-01-04 11:41:02 +00:00
if ($_SERVER['REQUEST_METHOD'] === 'POST' && isset($_POST['action'])) {
$action = $_POST['action'];
try {
switch ($action) {
case 'add_whitelist':
if (!$userObject->hasRight($user_id, 'superuser') && !$userObject->hasRight($user_id, 'edit whitelist')) {
throw new Exception(Messages::get('SECURITY', 'PERMISSION_DENIED')['message']);
2025-01-04 11:41:02 +00:00
}
if (empty($_POST['ip_address'])) {
throw new Exception(Messages::get('SECURITY', 'IP_REQUIRED')['message']);
2025-01-04 11:41:02 +00:00
}
2025-01-04 10:30:44 +00:00
$is_network = isset($_POST['is_network']) ? 1 : 0;
2025-01-04 11:41:02 +00:00
if (!$rateLimiter->addToWhitelist($_POST['ip_address'], $is_network, $_POST['description'] ?? '', $currentUser, $user_id)) {
throw new Exception(Messages::get('SECURITY', 'WHITELIST_ADD_ERROR')['message']);
2025-01-04 11:41:02 +00:00
}
Messages::flash('SECURITY', 'WHITELIST_ADD_SUCCESS');
2025-01-04 11:41:02 +00:00
break;
case 'remove_whitelist':
if (!$userObject->hasRight($user_id, 'superuser') && !$userObject->hasRight($user_id, 'edit whitelist')) {
throw new Exception(Messages::get('SECURITY', 'PERMISSION_DENIED')['message']);
2025-01-04 11:41:02 +00:00
}
if (empty($_POST['ip_address'])) {
throw new Exception(Messages::get('SECURITY', 'IP_REQUIRED')['message']);
2025-01-04 11:41:02 +00:00
}
if (!$rateLimiter->removeFromWhitelist($_POST['ip_address'], $currentUser, $user_id)) {
throw new Exception(Messages::get('SECURITY', 'WHITELIST_REMOVE_ERROR')['message']);
2025-01-04 11:41:02 +00:00
}
Messages::flash('SECURITY', 'WHITELIST_REMOVE_SUCCESS');
2025-01-04 11:41:02 +00:00
break;
case 'add_blacklist':
if (!$userObject->hasRight($user_id, 'superuser') && !$userObject->hasRight($user_id, 'edit blacklist')) {
throw new Exception(Messages::get('SECURITY', 'PERMISSION_DENIED')['message']);
2025-01-04 11:41:02 +00:00
}
if (empty($_POST['ip_address'])) {
throw new Exception(Messages::get('SECURITY', 'IP_REQUIRED')['message']);
2025-01-04 11:41:02 +00:00
}
2025-01-04 10:30:44 +00:00
$is_network = isset($_POST['is_network']) ? 1 : 0;
2025-01-04 11:41:02 +00:00
$expiry_hours = !empty($_POST['expiry_hours']) ? intval($_POST['expiry_hours']) : null;
if (!$rateLimiter->addToBlacklist($_POST['ip_address'], $is_network, $_POST['reason'] ?? '', $currentUser, $user_id, $expiry_hours)) {
throw new Exception(Messages::get('SECURITY', 'BLACKLIST_ADD_ERROR')['message']);
2025-01-04 11:41:02 +00:00
}
Messages::flash('SECURITY', 'BLACKLIST_ADD_SUCCESS');
2025-01-04 11:41:02 +00:00
break;
case 'remove_blacklist':
if (!$userObject->hasRight($user_id, 'superuser') && !$userObject->hasRight($user_id, 'edit blacklist')) {
throw new Exception(Messages::get('SECURITY', 'PERMISSION_DENIED')['message']);
2025-01-04 11:41:02 +00:00
}
if (empty($_POST['ip_address'])) {
throw new Exception(Messages::get('SECURITY', 'IP_REQUIRED')['message']);
2025-01-04 11:41:02 +00:00
}
if (!$rateLimiter->removeFromBlacklist($_POST['ip_address'], $currentUser, $user_id)) {
throw new Exception(Messages::get('SECURITY', 'BLACKLIST_REMOVE_ERROR')['message']);
2025-01-04 11:41:02 +00:00
}
Messages::flash('SECURITY', 'BLACKLIST_REMOVE_SUCCESS');
2025-01-04 11:41:02 +00:00
break;
}
} catch (Exception $e) {
$messages[] = ['category' => 'SECURITY', 'key' => 'CUSTOM_ERROR', 'custom_message' => $e->getMessage()];
2025-01-04 10:30:44 +00:00
}
2025-01-04 11:41:02 +00:00
if (empty($messages)) {
// Only redirect if there were no errors
header("Location: {$app_root}?page=security&section={$section}");
2025-01-04 11:41:02 +00:00
exit;
}
}
// Get flash messages from previous request
$flash_messages = Messages::getFlash();
$messages = array_merge($messages, array_map(function($flash) {
return [
'category' => $flash['category'],
'key' => $flash['key'],
'custom_message' => $flash['custom_message']
];
}, $flash_messages));
// Always show rate limit info message for rate limiting section
if ($section === 'ratelimit') {
$messages[] = ['category' => 'SECURITY', 'key' => 'RATE_LIMIT_INFO'];
2025-01-04 10:30:44 +00:00
}
2025-01-04 11:41:02 +00:00
// Get current lists
2025-01-04 10:30:44 +00:00
$whitelisted = $rateLimiter->getWhitelistedIps();
$blacklisted = $rateLimiter->getBlacklistedIps();
2025-01-04 11:41:02 +00:00
// Include template
2025-01-04 10:30:44 +00:00
include '../app/templates/security.php';
2025-01-04 11:41:02 +00:00
2025-01-04 10:30:44 +00:00
?>