faster ip search in postgres

This commit is contained in:
Shish 2019-11-28 09:24:49 +00:00
parent a9993b47a8
commit 33a32d2287

View file

@ -63,7 +63,8 @@ class LogDatabase extends Extension
if (!empty($_GET["user"])) { if (!empty($_GET["user"])) {
if ($database->get_driver_name() == DatabaseDriver::PGSQL) { if ($database->get_driver_name() == DatabaseDriver::PGSQL) {
if (preg_match("#\d+\.\d+\.\d+\.\d+(/\d+)?#", $_GET["user"])) { if (preg_match("#\d+\.\d+\.\d+\.\d+(/\d+)?#", $_GET["user"])) {
$wheres[] = $database->scoreql_to_sql("(SCORE_STRNORM(username) = SCORE_STRNORM(:user1) OR SCORE_STRNORM(text(address)) = SCORE_STRNORM(:user2))"); # for some reason postgres won't use an index on lower(text(address)), but will text(address)?
$wheres[] = $database->scoreql_to_sql("(SCORE_STRNORM(username) = SCORE_STRNORM(:user1) OR text(address) = :user2)");
$args["user1"] = $_GET["user"]; $args["user1"] = $_GET["user"];
$args["user2"] = $_GET["user"] . "/32"; $args["user2"] = $_GET["user"] . "/32";
} else { } else {