forked from pub-solar/infra
Merge pull request 'feat: searx' (#35) from feat/searx into main
Reviewed-on: pub-solar/infra-new#35 Reviewed-by: teutat3s <teutates@mailbox.org>
This commit is contained in:
commit
5f32669fe8
69
hosts/nachtigall/apps/searx.nix
Normal file
69
hosts/nachtigall/apps/searx.nix
Normal file
|
@ -0,0 +1,69 @@
|
|||
{
|
||||
flake,
|
||||
config,
|
||||
lib,
|
||||
pkgs,
|
||||
...
|
||||
}:
|
||||
{
|
||||
age.secrets.searx-environment = {
|
||||
file = "${flake.self}/secrets/searx-environment.age";
|
||||
mode = "700";
|
||||
};
|
||||
|
||||
services.nginx.virtualHosts."search.pub.solar" = {
|
||||
enableACME = true;
|
||||
forceSSL = true;
|
||||
|
||||
locations."/".proxyPass = "http://unix:/run/searx/searx.socket";
|
||||
};
|
||||
|
||||
users.users.nginx.extraGroups = [ "searx" ];
|
||||
|
||||
services.searx = {
|
||||
enable = true;
|
||||
runInUwsgi = true;
|
||||
package = searxng;
|
||||
|
||||
uwsgiConfig = {
|
||||
disable-logging = true;
|
||||
socket = "/run/searx/searx.sock";
|
||||
chmod-socket = "660";
|
||||
};
|
||||
|
||||
environmentFile = config.age.secrets.searx-environment.path;
|
||||
|
||||
settings = {
|
||||
use_default_settings: true;
|
||||
server.secret_key = "@SEARX_SECRET_KEY@";
|
||||
|
||||
general = {
|
||||
instance_name = "search.pub.solar";
|
||||
privacypolicy_url: "https://pub.solar/privacy";
|
||||
# use true to use your own donation page written in searx/info/en/donate.md
|
||||
# use false to disable the donation link
|
||||
donation_url: false
|
||||
# mailto:contact@example.com
|
||||
contact_url: false
|
||||
enable_metrics: false
|
||||
};
|
||||
|
||||
search = {
|
||||
# Existing autocomplete backends: "dbpedia", "duckduckgo", "google", "yandex", "mwmbl",
|
||||
# "seznam", "startpage", "swisscows", "qwant", "wikipedia" - leave blank to turn it off
|
||||
# by default.
|
||||
autocomplete: "duckduckgo"
|
||||
# minimun characters to type before autocompleter starts
|
||||
autocomplete_min: 4
|
||||
};
|
||||
|
||||
ui = {
|
||||
# query_in_title: When true, the result page's titles contains the query
|
||||
# it decreases the privacy, since the browser can records the page titles.
|
||||
query_in_title = false;
|
||||
# infinite_scroll: When true, automatically loads the next page when scrolling to bottom of the current page.
|
||||
infinite_scroll = true;
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
|
@ -21,6 +21,7 @@
|
|||
./apps/nginx-website.nix
|
||||
./apps/opensearch.nix
|
||||
./apps/postgresql.nix
|
||||
./apps/searx.nix
|
||||
|
||||
./apps/matrix/mautrix-telegram.nix
|
||||
./apps/matrix/synapse.nix
|
||||
|
|
BIN
secrets/searx-environment.age
Normal file
BIN
secrets/searx-environment.age
Normal file
Binary file not shown.
|
@ -38,4 +38,6 @@ in {
|
|||
|
||||
"nextcloud-secrets.age".publicKeys = nachtigallKeys ++ baseKeys;
|
||||
"nextcloud-admin-pass.age".publicKeys = nachtigallKeys ++ baseKeys;
|
||||
|
||||
"searx-environment.age".publicKeys = nachtigallKeys ++ baseKeys;
|
||||
}
|
||||
|
|
|
@ -113,6 +113,11 @@ resource "namecheap_domain_records" "pub-solar" {
|
|||
type = "CNAME"
|
||||
address = "nachtigall.pub.solar."
|
||||
}
|
||||
record {
|
||||
hostname = "search"
|
||||
type = "CNAME"
|
||||
address = "nachtigall.pub.solar."
|
||||
}
|
||||
record {
|
||||
hostname = "mastodon"
|
||||
type = "CNAME"
|
||||
|
|
Loading…
Reference in a new issue