123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128 |
- <?php
- require_once "misc/search_engine.php";
- // Reset all cookies when resetting, or before saving new cookies
- if (isset($_REQUEST["reset"])) {
- // if (isset($_REQUEST["reset"]) || isset($_REQUEST["save"])) {
- // Removing isset($_REQUEST["save"])) fixes the problem that settings don't "stick" if you go back into settings page to make additional changes.
- if (isset($_SERVER["HTTP_COOKIE"])) {
- $cookies = explode(";", $_SERVER["HTTP_COOKIE"]);
- foreach($cookies as $cookie) {
- $parts = explode("=", $cookie);
- $name = trim($parts[0]);
- $domain = parse_url($_SERVER['SERVER_NAME']);
- setcookie($name, "", time() - 1000);
- }
- }
- }
- if (isset($_REQUEST["save"])) {
- foreach($_POST as $key=>$value) {
- if (!empty($value)) {
- setcookie($key, $value, [
- "expires" => time() + (86400 * 90), // Sets cookie to expire in 90 days
- "path" => "/",
- "domain" => "$domain",
- "secure" => true, // Ensure cookies are only sent over HTTPS
- "httponly" => true, // Prevent client-side JavaScript access to cookies
- "samesite" => "Strict" // Strict SameSite policy for better protection against CSRF attacks
- ]);
- } else {
- setcookie($key, "", time() - 1000);
- }
- }
- }
- if (isset($_REQUEST["save"]) || isset($_REQUEST["reset"])) {
- header("Location: ./");
- die();
- }
- require_once "misc/header.php";
- $opts = load_opts();
- ?>
- <title>LibreY - <?php printtext("settings_title");?></title>
- </head>
- <body>
- <div class="misc-container">
- <h1><?php printtext("settings_title");?></h1>
- <div class="instances-container">
- <form method="post" enctype="multipart/form-data" autocomplete="off">
- <div>
- <span><?php printtext("settings_preferred_engine");?></span>
- <select name="engine">
- <?php
- require_once "engines/text/text.php";
- $engines = get_engines();
- $options = "";
- $options .= "<option value=\"\" " . (!isset($opts->engine) ? "selected" : "") . ">auto</option>";
- foreach ($engines as $engine) {
- $selected = $opts->engine == $engine ? "selected" : "";
- $options .= "<option value=\"$engine\" $selected>$engine</option>";
- }
- echo $options;
- ?>
- </select>
- </div>
- <div class="instances-container">
- <div>
- <span><?php printtext("settings_language");?></span>
- <select name="language">
- <?php
- $languages = json_decode(file_get_contents("static/misc/languages.json"), true);
- $options = "";
- $options .= "<option value=\"\" " . (!isset($opts->language) ? "selected" : "") . ">Any</option>";
- foreach ($languages as $lang_code => $language) {
- $name = $language["name"];
- $selected = $opts->language == $lang_code ? "selected" : "";
- $options .= "<option value=\"$lang_code\" $selected>$name</option>";
- }
- echo $options;
- ?>
- </select>
- </div>
- <div>
- <label><?php printtext("settings_number_of_results");?></label>
- <input type="number" name="number_of_results" value="<?php echo htmlspecialchars($opts->number_of_results ?? "10") ?>" >
- </div> </div>
- <div>
- <div><label><?php printtext("settings_special_disabled");?></label>
- <input type="checkbox" name="disable_special" <?php echo $opts->disable_special ? "checked" : ""; ?> ></div>
- <div><label><?php printtext("settings_frontends_disable");?></label>
- <input type="checkbox" name="disable_frontends" <?php echo $opts->disable_frontends ? "checked" : ""; ?> ></div>
- <div><label><?php printtext("settings_safe_search");?></label>
- <input type="checkbox" name="safe_search" <?php echo $opts->safe_search ? "checked" : ""; ?> ></div>
- </div>
- </div>
- <h2><?php printtext("settings_frontends");?></h2>
- <p><?php printtext("settings_frontends_description");?></p>
- <div class="instances-container">
- <?php
- foreach($opts->frontends as $frontend => $data)
- {
- echo "<div>";
- echo "<a for=\"$frontend\" href=\"" . $data["project_url"] . "\" target=\"_blank\">" . ucfirst($frontend) . "</a>";
- echo "<input type=\"text\" name=\"$frontend\" placeholder=\"Replace " . $data["original_name"] . "\" value=";
- echo htmlspecialchars($opts->frontends["$frontend"]["instance_url"] ?? "");
- echo ">";
- echo "</div>";
- }
- ?>
- </div>
-
- <div>
- <button type="submit" name="save" value="1"><?php printtext("settings_save");?></button>
- <button type="submit" name="reset" value="1"><?php printtext("settings_reset");?></button>
- </div>
- </form>
- </div>
- <?php require_once "misc/footer.php"; ?>
|