]> jfr.im git - irc/unrealircd/unrealircd-webpanel.git/blobdiff - inc/common.php
Add simple way to deal with IRC server configuration required.
[irc/unrealircd/unrealircd-webpanel.git] / inc / common.php
index bd812e9eb467992cf5a37735bddfd9e85a353273..44967879fb73393a81827b36b3cc831ae90160ec 100644 (file)
@@ -24,6 +24,34 @@ function get_config($setting)
        return $item;
 }
 
+function get_current_page_helper($name, $p)
+{
+       if (isset($p["script"]))
+       {
+               if (($p["script"] != '') && str_ends_with($_SERVER['SCRIPT_FILENAME'],$p["script"]))
+                       return $p;
+               return null;
+       }
+       foreach ($p as $k=>$v)
+       {
+               $ret = get_current_page_helper($k, $v);
+               if ($ret !== null)
+                       return $ret;
+       }
+       return null;
+}
+
+function get_current_page()
+{
+       GLOBAL $pages;
+       foreach ($pages as $k=>$v)
+       {
+               $ret = get_current_page_helper($k, $v);
+               if ($ret !== null)
+                       return $ret;
+       }
+}
+
 function page_requires_no_config()
 {
        if (str_ends_with($_SERVER['SCRIPT_FILENAME'],"install.php") ||
@@ -211,9 +239,12 @@ function generate_secrets()
 
 function get_active_rpc_server()
 {
+       $servers = get_config("unrealircd");
+       if (empty($servers))
+               return;
        // TODO: make user able to override this - either in user or in session
 
-       foreach (get_config("unrealircd") as $displayname=>$e)
+       foreach ($servers as $displayname=>$e)
        {
                if (isset($e["default"]) && $e["default"])
                        return $displayname;
@@ -407,25 +438,25 @@ if (!page_requires_no_config())
 }
 
 $pages = [
-       "Overview"     => "",
-       "Users"        => "users",
-       "Channels"     => "channels",
-       "Servers"      => "servers",
+       "Overview"     => ["script"=>""],
+       "Users"        => ["script"=>"users/index.php"],
+       "Channels"     => ["script"=>"channels/index.php"],
+       "Servers"      => ["script"=>"servers/index.php"],
        "Server Bans"  => [
-               "Server Bans" => "server-bans",
-               "Name Bans" => "server-bans/name-bans.php",
-               "Ban Exceptions" => "server-bans/ban-exceptions.php"
+               "Server Bans" => ["script" => "server-bans/index.php"],
+               "Name Bans" => ["script" => "server-bans/name-bans.php"],
+               "Ban Exceptions" => ["script" => "server-bans/ban-exceptions.php"],
        ],
-       "Spamfilter"   => "spamfilter.php",
+       "Spamfilter"   => ["script" => "spamfilter.php"],
        "Tools" => [
-               "IP WHOIS" => "tools/ip-whois.php",
+               "IP WHOIS" => ["script" => "tools/ip-whois.php","no_irc_server_required"=>true],
        ],
        "Settings" => [
-               "Plugins" => "settings/plugins.php",
-               "RPC Servers" => "settings/rpc-servers.php",
+               "Plugins" => ["script" => "settings/plugins.php","no_irc_server_required"=>true],
+               "RPC Servers" => ["script" => "settings/rpc-servers.php","no_irc_server_required"=>true],
        ],
        
-       "News" => "news.php",
+       "News" => ["script" => "news.php","no_irc_server_required"=>true],
 ];
 
 if (!panel_start_session())
@@ -439,14 +470,25 @@ if (!panel_start_session())
                die;
        }
 } else {
-       $pages["Settings"]["Accounts"] = "settings";
+       $pages["Settings"]["Accounts"] = [
+               "script" => "settings/index.php",
+               "no_irc_server_required"=>true
+       ];
        if (current_user_can(PERMISSION_MANAGE_USERS))
-               $pages["Settings"]["Role Editor"] = "settings/user-role-edit.php";
+       {
+               $pages["Settings"]["Role Editor"] = [
+                       "script"=>"settings/user-role-edit.php",
+                       "no_irc_server_required"=>true
+               ];
+       }
        $user = unreal_get_current_user();
        if ($user)
        {
                /* Add logout page, if logged in */
-               $pages["Logout"] = "login/?logout=true";
+               $pages["Logout"] = [
+                       "script"=>"login/?logout=true",
+                       "no_irc_server_required"=>true
+               ];
        }
 }
 
@@ -469,4 +511,6 @@ Hook::run(HOOKTYPE_NAVBAR, $pages);
  *               $pages[$page_name] = $page_link;
  *       }
  * }
-*/
\ No newline at end of file
+*/
+
+$current_page = get_current_page();