Compare commits
No commits in common. "1c8bc1d422d8f8b200ceafcebde10ba13a418488" and "62f154e6ac8ffdf20a3900dbe85c77c6493ad580" have entirely different histories.
1c8bc1d422
...
62f154e6ac
9 changed files with 58 additions and 216 deletions
|
|
@ -51,7 +51,6 @@ in
|
||||||
matrix = ns1;
|
matrix = ns1;
|
||||||
chat = ns1;
|
chat = ns1;
|
||||||
turn = ns1;
|
turn = ns1;
|
||||||
search = ns1;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
TXT = [
|
TXT = [
|
||||||
|
|
@ -137,11 +136,6 @@ in
|
||||||
enable = true;
|
enable = true;
|
||||||
domain = "roundcube.${domain}";
|
domain = "roundcube.${domain}";
|
||||||
};
|
};
|
||||||
searxng = {
|
|
||||||
enable = true;
|
|
||||||
domain = "search.${domain}";
|
|
||||||
port = 8888;
|
|
||||||
};
|
|
||||||
synapse = {
|
synapse = {
|
||||||
enable = true;
|
enable = true;
|
||||||
element = {
|
element = {
|
||||||
|
|
|
||||||
|
|
@ -15,7 +15,6 @@
|
||||||
./prosody
|
./prosody
|
||||||
./redis
|
./redis
|
||||||
./roundcube
|
./roundcube
|
||||||
./searxng
|
|
||||||
./synapse
|
./synapse
|
||||||
./uptime-kuma
|
./uptime-kuma
|
||||||
./vaultwarden
|
./vaultwarden
|
||||||
|
|
|
||||||
|
|
@ -1,26 +0,0 @@
|
||||||
{
|
|
||||||
config,
|
|
||||||
lib,
|
|
||||||
...
|
|
||||||
}:
|
|
||||||
let
|
|
||||||
cfg = config.machine.searxng;
|
|
||||||
in
|
|
||||||
with lib;
|
|
||||||
mkIf enable {
|
|
||||||
networking.firewall = {
|
|
||||||
allowedTCPPorts = [ cfg.port ];
|
|
||||||
};
|
|
||||||
|
|
||||||
services.nginx.virtualHosts =
|
|
||||||
mkIf (cfg.domain != null) {
|
|
||||||
"${cfg.domain}" = {
|
|
||||||
forceSSL = true;
|
|
||||||
enableACME = true;
|
|
||||||
locations."/" = {
|
|
||||||
proxyPass = "http://[::1]:${toString cfg.port}";
|
|
||||||
proxyWebsockets = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
@ -1,17 +0,0 @@
|
||||||
{ lib, ... }:
|
|
||||||
with lib;
|
|
||||||
{
|
|
||||||
options.machine.searxng = {
|
|
||||||
enable = mkEnableOption "SearXNG";
|
|
||||||
domain = mkOption {
|
|
||||||
type = types.nullOr types.str;
|
|
||||||
default = null;
|
|
||||||
description = "Domain name. If not set, will be disabled, and use the localhost.";
|
|
||||||
};
|
|
||||||
port = mkOption {
|
|
||||||
type = types.port;
|
|
||||||
default = 8888;
|
|
||||||
description = "Listen port.";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
@ -1,163 +0,0 @@
|
||||||
{
|
|
||||||
config,
|
|
||||||
pkgs,
|
|
||||||
lib,
|
|
||||||
...
|
|
||||||
}:
|
|
||||||
let
|
|
||||||
cfg = config.machine.searxng;
|
|
||||||
in
|
|
||||||
with lib;
|
|
||||||
mkIf enable {
|
|
||||||
services.searx = {
|
|
||||||
enable = true;
|
|
||||||
redisCreateLocally = true;
|
|
||||||
|
|
||||||
# Rate limiting
|
|
||||||
limiterSettings = {
|
|
||||||
real_ip = {
|
|
||||||
x_for = 1;
|
|
||||||
ipv4_prefix = 32;
|
|
||||||
ipv6_prefix = 56;
|
|
||||||
};
|
|
||||||
|
|
||||||
botdetection = {
|
|
||||||
ip_limit = {
|
|
||||||
filter_link_local = true;
|
|
||||||
link_token = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
settings = {
|
|
||||||
# Instance settings
|
|
||||||
general = {
|
|
||||||
debug = false;
|
|
||||||
instance_name = "SearXNG Instance";
|
|
||||||
donation_url = false;
|
|
||||||
contact_url = false;
|
|
||||||
privacypolicy_url = false;
|
|
||||||
enable_metrics = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
# User interface
|
|
||||||
ui = {
|
|
||||||
static_use_hash = true;
|
|
||||||
default_locale = "en";
|
|
||||||
query_in_title = true;
|
|
||||||
infinite_scroll = false;
|
|
||||||
center_alignment = true;
|
|
||||||
default_theme = "simple";
|
|
||||||
theme_args.simple_style = "auto";
|
|
||||||
search_on_category_select = false;
|
|
||||||
hotkeys = "vim";
|
|
||||||
};
|
|
||||||
|
|
||||||
# Search engine settings
|
|
||||||
search = {
|
|
||||||
safe_search = 2;
|
|
||||||
autocomplete_min = 2;
|
|
||||||
autocomplete = "duckduckgo";
|
|
||||||
ban_time_on_fail = 5;
|
|
||||||
max_ban_time_on_fail = 120;
|
|
||||||
};
|
|
||||||
|
|
||||||
# Server configuration
|
|
||||||
server = {
|
|
||||||
base_url = cfg.domain != null ? "https://${cfg.domain}" : null;
|
|
||||||
port = cfg.port;
|
|
||||||
bind_address = "127.0.0.1";
|
|
||||||
limiter = true;
|
|
||||||
public_instance = true;
|
|
||||||
image_proxy = true;
|
|
||||||
method = "GET";
|
|
||||||
};
|
|
||||||
|
|
||||||
# Search engines
|
|
||||||
engines = lib.mapAttrsToList (name: value: { inherit name; } // value) {
|
|
||||||
"duckduckgo".disabled = true;
|
|
||||||
"brave".disabled = true;
|
|
||||||
"bing".disabled = false;
|
|
||||||
"mojeek".disabled = true;
|
|
||||||
"mwmbl".disabled = false;
|
|
||||||
"mwmbl".weight = 0.4;
|
|
||||||
"qwant".disabled = true;
|
|
||||||
"crowdview".disabled = false;
|
|
||||||
"crowdview".weight = 0.5;
|
|
||||||
"curlie".disabled = true;
|
|
||||||
"ddg definitions".disabled = false;
|
|
||||||
"ddg definitions".weight = 2;
|
|
||||||
"wikibooks".disabled = false;
|
|
||||||
"wikidata".disabled = false;
|
|
||||||
"wikiquote".disabled = true;
|
|
||||||
"wikisource".disabled = true;
|
|
||||||
"wikispecies".disabled = false;
|
|
||||||
"wikispecies".weight = 0.5;
|
|
||||||
"wikiversity".disabled = false;
|
|
||||||
"wikiversity".weight = 0.5;
|
|
||||||
"wikivoyage".disabled = false;
|
|
||||||
"wikivoyage".weight = 0.5;
|
|
||||||
"currency".disabled = true;
|
|
||||||
"dictzone".disabled = true;
|
|
||||||
"lingva".disabled = true;
|
|
||||||
"bing images".disabled = false;
|
|
||||||
"brave.images".disabled = true;
|
|
||||||
"duckduckgo images".disabled = true;
|
|
||||||
"google images".disabled = false;
|
|
||||||
"qwant images".disabled = true;
|
|
||||||
"1x".disabled = true;
|
|
||||||
"artic".disabled = false;
|
|
||||||
"deviantart".disabled = false;
|
|
||||||
"flickr".disabled = true;
|
|
||||||
"imgur".disabled = false;
|
|
||||||
"library of congress".disabled = false;
|
|
||||||
"material icons".disabled = true;
|
|
||||||
"material icons".weight = 0.2;
|
|
||||||
"openverse".disabled = false;
|
|
||||||
"pinterest".disabled = true;
|
|
||||||
"svgrepo".disabled = false;
|
|
||||||
"unsplash".disabled = false;
|
|
||||||
"wallhaven".disabled = false;
|
|
||||||
"wikicommons.images".disabled = false;
|
|
||||||
"yacy images".disabled = true;
|
|
||||||
"bing videos".disabled = false;
|
|
||||||
"brave.videos".disabled = true;
|
|
||||||
"duckduckgo videos".disabled = true;
|
|
||||||
"google videos".disabled = false;
|
|
||||||
"qwant videos".disabled = false;
|
|
||||||
"dailymotion".disabled = true;
|
|
||||||
"google play movies".disabled = true;
|
|
||||||
"invidious".disabled = true;
|
|
||||||
"odysee".disabled = true;
|
|
||||||
"peertube".disabled = false;
|
|
||||||
"piped".disabled = true;
|
|
||||||
"rumble".disabled = false;
|
|
||||||
"sepiasearch".disabled = false;
|
|
||||||
"vimeo".disabled = true;
|
|
||||||
"youtube".disabled = false;
|
|
||||||
"brave.news".disabled = true;
|
|
||||||
"google news".disabled = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
# Outgoing requests
|
|
||||||
outgoing = {
|
|
||||||
request_timeout = 5.0;
|
|
||||||
max_request_timeout = 15.0;
|
|
||||||
pool_connections = 100;
|
|
||||||
pool_maxsize = 15;
|
|
||||||
enable_http2 = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
# Enabled plugins
|
|
||||||
enabled_plugins = [
|
|
||||||
"Basic Calculator"
|
|
||||||
"Hash plugin"
|
|
||||||
"Tor check plugin"
|
|
||||||
"Open Access DOI rewrite"
|
|
||||||
"Hostnames plugin"
|
|
||||||
"Unit converter plugin"
|
|
||||||
"Tracker URL remover"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
@ -1,3 +1,5 @@
|
||||||
{
|
{
|
||||||
imports = [ ];
|
imports = [
|
||||||
|
./../modules/openclaw
|
||||||
|
];
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,6 @@
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
./network.nix
|
./secrets.nix
|
||||||
./options.nix
|
|
||||||
./service.nix
|
./service.nix
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
6
users/rus07tam/modules/openclaw/secrets.nix
Normal file
6
users/rus07tam/modules/openclaw/secrets.nix
Normal file
|
|
@ -0,0 +1,6 @@
|
||||||
|
{
|
||||||
|
sops.secrets = {
|
||||||
|
"rus07tam/openclaw/gatewayToken" = { };
|
||||||
|
"rus07tam/openclaw/telegramToken" = { };
|
||||||
|
};
|
||||||
|
}
|
||||||
48
users/rus07tam/modules/openclaw/service.nix
Normal file
48
users/rus07tam/modules/openclaw/service.nix
Normal file
|
|
@ -0,0 +1,48 @@
|
||||||
|
{
|
||||||
|
sec,
|
||||||
|
inputs,
|
||||||
|
...
|
||||||
|
}: {
|
||||||
|
imports = [
|
||||||
|
inputs.nix-openclaw.homeManagerModules.openclaw
|
||||||
|
];
|
||||||
|
|
||||||
|
programs.openclaw = {
|
||||||
|
enable = true;
|
||||||
|
installApp = false;
|
||||||
|
systemd.enable = true;
|
||||||
|
|
||||||
|
bundledPlugins = {
|
||||||
|
summarize.enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
instances.default = {
|
||||||
|
enable = true;
|
||||||
|
systemd.enable = true;
|
||||||
|
|
||||||
|
config = {
|
||||||
|
agents.defaults = {
|
||||||
|
model.primary = "openrouter/qwen/qwen3-coder:free";
|
||||||
|
sandbox.mode = "off";
|
||||||
|
};
|
||||||
|
|
||||||
|
gateway = {
|
||||||
|
mode = "local";
|
||||||
|
auth.token = sec."rus07tam/openclaw/gatewayToken".path;
|
||||||
|
};
|
||||||
|
|
||||||
|
channels.telegram = {
|
||||||
|
tokenFile = sec."rus07tam/openclaw/telegramToken".path;
|
||||||
|
allowFrom = [6146757977];
|
||||||
|
groups = {
|
||||||
|
"*" = {
|
||||||
|
requireMention = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
plugins.entries.telegram.enabled = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue