]> jfr.im git - irc/unrealircd/unrealircd-webpanel.git/blobdiff - common.php
Exempt test_connection.php from requiring config as well - this adds page_requires_no...
[irc/unrealircd/unrealircd-webpanel.git] / common.php
index 68c6e0e5dab6aaba062bfa0c785c78e913326a8a..dced580029e74dfc5f15b0b7b1eceeac19acedd1 100644 (file)
@@ -8,8 +8,51 @@ if (version_compare(PHP_VERSION, '8.0.0', '<'))
            "You may also need to choose again the PHP module to load in apache via <code>a2enmod php8.2</code>");
 
 define('UPATH', dirname(__FILE__));
-require_once UPATH . "/config.php";
-if (!defined('BASE_URL')) die("You need to define BASE_URL in config.php (see config.php.sample for documentation)");
+
+function get_config($setting)
+{
+       GLOBAL $config;
+
+       $item = $config;
+       foreach(explode("::", $setting) as $x)
+       {
+               if (isset($item[$x]))
+                       $item = $item[$x];
+               else
+                       return NULL;
+       }
+       return $item;
+}
+
+function page_requires_no_config()
+{
+       if (str_ends_with($_SERVER['SCRIPT_FILENAME'],"install.php") ||
+           str_ends_with($_SERVER['SCRIPT_FILENAME'],"test_connection.php"))
+       {
+               return TRUE;
+       }
+       return FALSE;
+}
+
+
+/* Load config defaults */
+$config = Array();
+require_once UPATH . "/config/config.defaults.php";
+
+if (!file_exists(UPATH."/config/config.php") && file_exists(UPATH."/config.php"))
+{
+       require_once UPATH . "/config.php";
+       require_once UPATH . "/config/compat.php";
+} else
+if (page_requires_no_config())
+{
+       /* Allow empty conf */
+} else
+{
+       require_once UPATH . "/config/config.php";
+}
+
+if (!get_config("base_url")) die("You need to define the base_url in config/config.php");
 require_once "Classes/class-hook.php";
 if (!is_dir(UPATH . "/vendor"))
        die("The vendor/ directory is missing. Most likely the admin forgot to run 'composer install'\n");
@@ -42,19 +85,23 @@ $pages = [
                "IP WHOIS" => "tools/ip-whois.php",
        ],
        "Settings" => [
-               "Panel Access" => "settings",
                "Plugins" => "settings/plugins.php",
        ],
        
-       "News"         => "news.php",
+       "News" => "news.php",
 ];
-$user = unreal_get_current_user();
-if ($user)
+
+if (is_auth_provided())
 {
-       /* Add logout page, if logged in */
-       $pages["Logout"] = "login/?logout=true";
-}
+       $pages["Settings"]["Panel Access"] = "settings";
 
+       $user = unreal_get_current_user();
+       if ($user)
+       {
+               /* Add logout page, if logged in */
+               $pages["Logout"] = "login/?logout=true";
+       }
+}
 Hook::run(HOOKTYPE_NAVBAR, $pages);
 
 /* Example to add new menu item: