Common modules used by my nixos servers
Flake lock file updates: • Updated input 'nixpkgs': 'github:nixos/nixpkgs/42a1c966be226125b48c384171c44c651c236c22?narHash=sha256-rpqepOZ8Eo1zg%2BKJeWoq1HAOgoMCDloqv5r2EAa9TSA%3D' (2025-04-05) → 'github:nixos/nixpkgs/063dece00c5a77e4a0ea24e5e5a5bd75232806f8?narHash=sha256-nEo1t3Q0F%2B0jQ36HJfbJtiRU4OI%2B/0jX/iITURKe3EE%3D' (2025-04-06) |
||
---|---|---|
.gitea/workflows | ||
modules | ||
flake.lock | ||
flake.nix | ||
README.md |
common.nix
Nix modules i use on my servers
Usage
# flake.nix
inputs = {
common-modules.url = "git+https://forge.catnip.ee/batteredbunny/common.nix";
};
# configuration.nix
# import any modules you want to use
imports = [
inputs.common-modules.nixosModules.nixos-upgrade
inputs.common-modules.nixosModules.qbittorrent-nox
inputs.common-modules.nixosModules.unpackerr
];
Modules
Auto upgrade
Adds a few new options to system.autoUpgrade
updateFlake
pulls in new changes from git repo of your flake and updates the lock file. Make sure your flake parameter is a directory not a flake url, otherwise it wont work.
failureNotification
sends a notification to a ntfy topic on an auto upgrade failure
extraCommands
extra commands to run during auto upgrade
system.autoUpgrade = {
enable = true;
allowReboot = true;
flake = "/etc/nixos";
# New options
updateFlake = true;
failureNotification = {
enable = true;
# NTFY_URL=https://ntfy.example.com/topic
ntfyUrlFile = "/etc/secrets/failureNotification.env";
};
};
Unpackerr
services.unpackerr = {
enable = true;
# Stores your api keys and other sensitive things you dont want to include in nix config, example: UN_SONARR_0_API_KEY,UN_RADARR_0_API_KEY
environmentFile = "/etc/secrets/unpackerr.env";
# Defaults to unpackerr:unpackerr, so make sure the user has right file permissions
# user = "";
# group = "";
# Look up default unpackerr config, its in toml format
settings = {
sonarr = [{
url = "http://localhost:8989";
protocols = "torrent";
timeout = "100s";
delete_delay = "10m";
}];
radarr = [{
url = "http://localhost:7878";
protocols = "torrent";
timeout = "100s";
delete_delay = "10m";
}];
};
};
Qbittorrent
Becuase nixos doesnt have one yet, mostly the one from PR but slightly modified.
services.qbittorrent-nox = {
enable = true;
openFirewall = true;
webuiPort = 8080;
torrentingPort = 345677;
};