nixos-config/modules/system/webServices/privatebin.nix

57 lines
1.2 KiB
Nix

{
config,
pkgs-unstable,
lib,
...
}:
let
cfg = config.custom.services.privatebin;
in
{
options.custom.services.privatebin = {
enable = lib.mkEnableOption "";
domain = lib.mkOption {
type = lib.types.nonEmptyStr;
default = "";
};
port = lib.mkOption {
type = lib.types.port;
default = 61009;
};
branding.name = lib.mkOption {
type = lib.types.nonEmptyStr;
default = "PrivateBin";
};
};
config = lib.mkIf cfg.enable {
warnings = lib.optional (lib.versionAtLeast lib.version "25.11") "TODO: Use privatebin package from stable nixpkgs";
meta = {
domains.list = [ cfg.domain ];
ports.tcp.list = [ cfg.port ];
};
services = {
privatebin = {
enable = true;
package = pkgs-unstable.privatebin; # Unstable to get version 2.0
enableNginx = true;
virtualHost = "privatebin";
settings.main = {
basepath = "https://${cfg.domain}";
inherit (cfg.branding) name;
};
};
nginx.virtualHosts.privatebin.listen = [
{
addr = "localhost";
inherit (cfg) port;
}
];
};
custom.persist.directories = [ config.services.privatebin.dataDir ];
};
}