Setup Perplexica (requires manual set up of docker image)

This commit is contained in:
pazpi 2025-01-07 22:32:35 +01:00
parent 293092473f
commit 28a0c514b1
2 changed files with 61 additions and 6 deletions

View file

@ -56,6 +56,8 @@ in
searx = { searx = {
enable = true; enable = true;
secretFile = config.age.secrets.searx-secret.path; secretFile = config.age.secrets.searx-secret.path;
enableAI = true;
perplexicaUrl = "portainer.internal";
proxy = { proxy = {
enable = true; enable = true;
domain = tsDomain; domain = tsDomain;
@ -107,9 +109,6 @@ in
cloudflareApiKeyFile = config.age.secrets.cloudflare-tegola-apiKey.path; cloudflareApiKeyFile = config.age.secrets.cloudflare-tegola-apiKey.path;
} }
]; ];
# email = "pasettodavide@gmail.com";
# domain = tsDomain;
# claudflareApiKeyFile = config.age.secrets.cloudflare-tegola-apiKey.path;
}; };
}; };

View file

@ -20,6 +20,22 @@ in
''; '';
}; };
enableAI = lib.mkOption {
default = false;
type = lib.types.bool;
description = ''
Enable alternative search engine with AI. Requires [Perplexica](https://github.com/ItzCrazyKns/Perplexica)
'';
};
perplexicaUrl = lib.mkOption {
default = "";
type = lib.types.str;
description = ''
URL to the Perplexica instance. It assumes that the Perplexica instance is running on port 3000 and the API on port 3001
'';
};
proxy = { proxy = {
enable = lib.mkEnableOption "Set the proxy entry for this service"; enable = lib.mkEnableOption "Set the proxy entry for this service";
@ -31,6 +47,22 @@ in
''; '';
}; };
subdomain = lib.mkOption {
default = "search";
type = lib.types.str;
description = ''
Search subdomain
'';
};
perplexicaSubdomain = lib.mkOption {
default = "sai";
type = lib.types.str;
description = ''
Perplexica subdomain
'';
};
host = lib.mkOption { host = lib.mkOption {
default = "localhost"; default = "localhost";
type = lib.types.str; type = lib.types.str;
@ -55,11 +87,19 @@ in
}; };
server = { server = {
base_url = "https://search.${cfg.proxy.domain}"; base_url = with cfg.proxy; "https://${subdomain}.${domain}";
bind_address = "::1"; bind_address = "0.0.0.0";
port = 8080; port = 8080;
secret_key = "@SEARX_SECRET_KEY@"; secret_key = "@SEARX_SECRET_KEY@";
}; };
search = {
formats = [
"html"
"json"
];
};
}; };
}; };
@ -69,10 +109,26 @@ in
(lib.mkIf cfg.proxy.enable { (lib.mkIf cfg.proxy.enable {
services.caddy = with cfg.proxy; { services.caddy = with cfg.proxy; {
virtualHosts."search.${domain}".extraConfig = '' virtualHosts."${subdomain}.${domain}".extraConfig = ''
reverse_proxy http://${host}:8080 reverse_proxy http://${host}:8080
import cloudflare_${domain} import cloudflare_${domain}
''; '';
virtualHosts."${perplexicaSubdomain}.${domain}".extraConfig = lib.mkIf cfg.enableAI ''
@websockets {
header Connection *Upgrade*
header Upgrade websocket
}
reverse_proxy ${cfg.perplexicaUrl}:3000
reverse_proxy /api* ${cfg.perplexicaUrl}:3001
reverse_proxy @websockets {
header_up Host ${cfg.perplexicaUrl}
to ${cfg.perplexicaUrl}:3001
}
import cloudflare_${domain}
'';
}; };
}) })
]; ];