2024-01-11 10:14:21 +01:00
|
|
|
<?php
|
|
|
|
|
2024-04-28 22:37:23 +02:00
|
|
|
/**
|
|
|
|
* Includes a PHP file that returns metadata associated with a dynamic page.
|
|
|
|
* It simply scopes an external file into a function to prevent variable conflicts.
|
|
|
|
*
|
|
|
|
* @param string $file The file path to the PHP file that contains metadata.
|
|
|
|
* @return array Returns an associative array of metadata from the included PHP file.
|
|
|
|
*/
|
|
|
|
function getDynamicMetadata(string $file): array{
|
2024-02-15 10:49:27 +01:00
|
|
|
return include($file);
|
2024-02-15 10:49:19 +01:00
|
|
|
}
|
2024-04-28 22:37:23 +02:00
|
|
|
/**
|
|
|
|
* Extracts and validates the minimal permission level required to access certain content,
|
|
|
|
* defaulting to system configuration if not properly set or in case of an error.
|
|
|
|
*
|
|
|
|
* @param array $metadata Metadata array that should include a 'parameters' key with 'minimal_permission_level'.
|
|
|
|
* @return int Returns the minimal permission level required to access a page.
|
|
|
|
*@global array $routerConfig Global router configuration settings.
|
|
|
|
*/
|
|
|
|
function getDynamicPermission(array $metadata): int {
|
2024-02-03 16:34:42 +01:00
|
|
|
global $routerConfig;
|
2024-02-15 10:50:22 +01:00
|
|
|
$params = $metadata["parameters"];
|
2024-02-03 16:46:09 +01:00
|
|
|
try {
|
2024-02-15 10:49:19 +01:00
|
|
|
$permission_level = $params["minimal_permission_level"];
|
2024-02-03 16:34:42 +01:00
|
|
|
|
2024-02-03 16:46:09 +01:00
|
|
|
if (!is_numeric($permission_level) || $permission_level <= 0) {
|
2024-02-06 16:24:57 +01:00
|
|
|
$permission_level = $routerConfig["page"]["default_permissions"];
|
2024-02-03 16:46:09 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Exception){
|
2024-02-06 16:24:57 +01:00
|
|
|
$permission_level = $routerConfig["page"]["default_permissions"];
|
2024-02-03 16:46:09 +01:00
|
|
|
} finally {
|
|
|
|
return $permission_level;
|
2024-02-03 16:34:42 +01:00
|
|
|
}
|
2024-02-01 13:44:00 +01:00
|
|
|
}
|
2024-04-28 22:37:23 +02:00
|
|
|
/**
|
|
|
|
* Generates HTML navigation links for all sites and pages configured in the router,
|
|
|
|
* adjusting active states based on current request and filtering links by user permissions.
|
|
|
|
*
|
|
|
|
* @global array $routerConfig Global configuration that includes directory paths and default settings.
|
|
|
|
* @global array $routerRequest Current request details including site and page name.
|
|
|
|
* @return string Returns the HTML string of the navigation menu.
|
|
|
|
*/
|
2024-01-31 22:05:23 +01:00
|
|
|
function generateNavigation(): string
|
2024-01-12 16:20:17 +01:00
|
|
|
{
|
2024-01-16 20:43:57 +01:00
|
|
|
global $routerConfig;
|
|
|
|
global $routerRequest;
|
|
|
|
|
2024-02-05 22:26:02 +01:00
|
|
|
$nav = file_get_contents($routerConfig["template_dir"] . "nav.html");
|
2024-01-16 20:56:37 +01:00
|
|
|
$site_dirs = array_diff(scandir($routerConfig["page_dir"]), array('.', '..'));
|
2024-01-11 10:14:21 +01:00
|
|
|
|
2024-01-12 16:20:17 +01:00
|
|
|
$nav_out = "";
|
2024-01-11 10:14:21 +01:00
|
|
|
|
2024-01-12 16:20:17 +01:00
|
|
|
foreach ($site_dirs as $site_dir) {
|
2024-01-16 20:56:37 +01:00
|
|
|
$pages_dir = array_diff(scandir($routerConfig["page_dir"] . $site_dir), array('.', '..'));
|
2024-01-11 16:02:10 +01:00
|
|
|
|
2024-01-12 16:20:17 +01:00
|
|
|
$site_name = str_replace("_", " ", $site_dir);
|
2024-01-16 20:52:53 +01:00
|
|
|
|
2024-02-02 12:38:18 +01:00
|
|
|
$site_name = ucfirst($site_name);
|
|
|
|
|
2024-02-06 16:24:57 +01:00
|
|
|
$site_location = "/" . $site_dir . "/" . $routerConfig["default_page"];
|
2024-01-12 16:20:17 +01:00
|
|
|
|
2024-02-06 16:24:57 +01:00
|
|
|
if ($routerRequest["site_name"] == $site_dir) {
|
2024-01-12 16:20:17 +01:00
|
|
|
//this is the current page
|
|
|
|
$site_class = "class=\"navsite_link active\"";
|
|
|
|
}
|
2024-01-16 20:43:57 +01:00
|
|
|
else{
|
|
|
|
$site_class = "class=\"navsite_link\"";
|
|
|
|
}
|
|
|
|
|
2024-02-06 16:24:57 +01:00
|
|
|
$navigation_pages = "";
|
2024-02-02 00:37:10 +01:00
|
|
|
|
2024-02-01 10:14:49 +01:00
|
|
|
foreach ($pages_dir as $page_file) {
|
2024-02-03 16:08:26 +01:00
|
|
|
$page_file_tmp = explode(".", $page_file);
|
|
|
|
$page_basename = $page_file_tmp[0];
|
2024-01-12 16:20:17 +01:00
|
|
|
$page_class = "class=\"navpage_link\"";
|
2024-02-06 16:24:57 +01:00
|
|
|
if ($routerRequest["site_name"] == $site_dir && $routerRequest["page_name"] == $page_basename) {
|
2024-01-12 16:20:17 +01:00
|
|
|
$page_class = "class=\"navpage_link active\"";
|
|
|
|
}
|
2024-01-11 15:23:14 +01:00
|
|
|
|
2024-02-06 16:24:57 +01:00
|
|
|
$page_location = "/" . $site_dir . "/" . $page_basename;
|
2024-01-11 15:23:14 +01:00
|
|
|
|
2024-02-03 16:08:26 +01:00
|
|
|
$page_name = str_replace("_", " ", $page_basename);
|
2024-01-12 16:20:17 +01:00
|
|
|
$page_name = explode(".", $page_name)[0];
|
2024-01-17 11:06:02 +01:00
|
|
|
$page_name = ucfirst($page_name);
|
2024-02-15 10:49:19 +01:00
|
|
|
|
2024-02-02 00:37:10 +01:00
|
|
|
$page_file_path = $routerConfig["page_dir"] . $site_dir . "/" . $page_file ;
|
2024-02-03 16:08:26 +01:00
|
|
|
if($page_file_tmp[1] == "html"){
|
2024-02-02 00:37:10 +01:00
|
|
|
$page_tmp = file_get_contents($page_file_path);
|
2024-02-01 13:44:00 +01:00
|
|
|
|
|
|
|
$pageMetadata = parsePageTag($page_tmp);
|
|
|
|
if(!empty($pageMetadata["parameters"]["minimal_permission_level"])){
|
|
|
|
$page_required_permission = intval($pageMetadata["parameters"]["minimal_permission_level"]);
|
|
|
|
}
|
|
|
|
else{
|
2024-02-06 16:24:57 +01:00
|
|
|
$page_required_permission = $routerConfig["page"]["default_permissions"];
|
2024-02-01 13:44:00 +01:00
|
|
|
}
|
2024-02-15 10:49:19 +01:00
|
|
|
if(!empty($pageMetadata["parameters"]["page_title"])){
|
|
|
|
$page_name = $pageMetadata["parameters"]["page_title"];
|
|
|
|
}
|
2024-02-01 13:44:00 +01:00
|
|
|
}
|
2024-02-03 16:08:26 +01:00
|
|
|
elseif($page_file_tmp[1] == "php"){
|
2024-02-15 10:49:19 +01:00
|
|
|
$pageMetadata = getDynamicMetadata($page_file_path);
|
|
|
|
$page_required_permission = getDynamicPermission($pageMetadata);
|
|
|
|
|
|
|
|
if(!empty($pageMetadata["parameters"]["page_title"])){
|
|
|
|
$page_name = $pageMetadata["parameters"]["page_title"];
|
|
|
|
}
|
2024-02-01 10:14:49 +01:00
|
|
|
}
|
|
|
|
else{
|
2024-02-06 16:24:57 +01:00
|
|
|
$page_required_permission = $routerConfig["page"]["default_permissions"];
|
2024-02-01 10:14:49 +01:00
|
|
|
}
|
|
|
|
|
2024-02-06 16:24:57 +01:00
|
|
|
|
2024-02-03 16:08:26 +01:00
|
|
|
if($page_required_permission <= $_SESSION["privilege_level"]) {
|
2024-02-06 16:24:57 +01:00
|
|
|
$navpage_attributes = "data-site='$site_dir' data-page='$page_basename'";
|
|
|
|
$navigation_pages .= "<li class='navpage_item' $navpage_attributes ><a $navpage_attributes href='$page_location' $page_class>$page_name</a></li>";
|
2024-02-01 10:14:49 +01:00
|
|
|
}
|
|
|
|
}
|
2024-02-06 16:24:57 +01:00
|
|
|
if(!empty($navigation_pages)){
|
2024-02-05 21:29:29 +01:00
|
|
|
$default_page = $routerConfig["default_page"];
|
2024-02-06 16:24:57 +01:00
|
|
|
$navsite_attributes = "data-page='$default_page' data-site='$site_dir'";
|
|
|
|
$nav_out .= "<li class='navsite_item' ><a $navsite_attributes href='$site_location' $site_class>$site_name</a><ul class='navpage_list'>$navigation_pages</ul></li>";
|
2024-01-12 16:20:17 +01:00
|
|
|
}
|
2024-01-11 10:28:00 +01:00
|
|
|
}
|
|
|
|
|
2024-02-05 22:26:02 +01:00
|
|
|
return str_replace("__NAV_PAGES__", $nav_out, $nav);
|
2024-01-12 16:20:17 +01:00
|
|
|
}
|
2024-04-28 22:37:23 +02:00
|
|
|
/**
|
|
|
|
* Provides a simple API endpoint-like response for fetching generated navigation HTML.
|
|
|
|
* Wraps generateNavigation for an API.
|
|
|
|
*
|
|
|
|
* @return array Returns an associative array with the navigation HTML and a status indicating success.
|
|
|
|
*/
|
2024-02-05 21:21:04 +01:00
|
|
|
function getNavigationEndpoint() :array{
|
|
|
|
return [
|
|
|
|
"Status" => "Success",
|
|
|
|
"Navigation" => generateNavigation(),
|
|
|
|
];
|
|
|
|
}
|