X-Git-Url: https://jfr.im/git/irc/unrealircd/unrealircd-webpanel.git/blobdiff_plain/8234307335b735fb724ac5da469c276cb476002a..0d62343db7cf98dda603d338e1948a9a09af5862:/inc/connection.php
diff --git a/inc/connection.php b/inc/connection.php
index f66d750..0272138 100644
--- a/inc/connection.php
+++ b/inc/connection.php
@@ -8,9 +8,17 @@ function connect_to_ircd()
GLOBAL $rpc;
GLOBAL $config;
+ $is_api_page = str_contains($_SERVER['SCRIPT_FILENAME'], "/api/") ? true : false;
+
+ $options = []; /* options that we pass to new UnrealIRCd\Connection */
+
+ $rpc = null; /* Initialize, mostly for API page failures */
+
$server = get_active_rpc_server();
if (!$server)
{
+ if ($is_api_page)
+ return;
Message::Fail("No RPC server configured. Go to Settings - RPC Servers.");
die;
}
@@ -20,42 +28,50 @@ function connect_to_ircd()
$rpc_password = $config["unrealircd"][$server]["rpc_password"];
if (str_starts_with($rpc_password, "secret:"))
$rpc_password = secret_decrypt($rpc_password);
- $tls_verify = $config["unrealircd"][$server]["tls_verify_cert"];
+ if (isset($config["unrealircd"][$server]["tls_verify_cert"]))
+ $options["tls_verify"] = $config["unrealircd"][$server]["tls_verify_cert"];
if (!$host || !$port || !$rpc_user)
+ {
+ if ($is_api_page)
+ return;
die("RPC Server is missing credentials");
+ }
if ($rpc_password === null)
{
+ if ($is_api_page)
+ return;
Message::Fail("Your RPC password in the DB was encrypted with a different key than config/config.php contains.
\n".
"Either restore your previous config/config.php or start with a fresh database.
\n");
die;
}
+ $user = unreal_get_current_user();
+ if ($user)
+ {
+ /* Set issuer for all the RPC commands */
+ $options['issuer'] = $user->username;
+ }
+
/* Connect now */
try {
$rpc = new UnrealIRCd\Connection
(
"wss://$host:$port",
"$rpc_user:$rpc_password",
- ["tls_verify" => $tls_verify]
+ $options
);
}
catch (Exception $e)
{
+ if ($is_api_page)
+ return;
Message::Fail("Unable to connect to UnrealIRCd: ".$e->getMessage() . "
".
- "Verify your connection details in config.php (rpc user, rpc password, host) and ".
- "verify your UnrealIRCd configuration (listen block with listen::options::rpc and ".
- "an rpc-user block with the correct IP allowed and the correct username and password).");
+ "Verify that the connection details from Settings - RPC Servers match the ones in UnrealIRCd ".
+ "and that UnrealIRCd is up and running");
throw $e;
}
-
- $user = unreal_get_current_user();
- if ($user)
- {
- /* Set issuer for all the RPC commands */
- $rpc->rpc()->set_issuer($user->username);
- }
}
connect_to_ircd();