Updated JF docs and added openssh vpn option

This commit is contained in:
rasmus-kirk
2024-02-26 15:02:29 +01:00
parent 81db952881
commit 10c674687a
2 changed files with 48 additions and 3 deletions
+6 -3
View File
@@ -25,7 +25,10 @@ in {
expose = {
enable = mkEnableOption ''
Enable expose for Jellyfin, exposing the web service to the internet.
Expose the Jellyfin web service to the internet.
**Important:** Do _not_ enable this without setting up Jellyfin
authentication through localhost first!
'';
upnp.enable = mkEnableOption ''
@@ -35,13 +38,13 @@ in {
domainName = mkOption {
type = types.nullOr types.str;
default = null;
description = "REQUIRED! The domain name to host Jellyfin on.";
description = "**REQUIRED:** The domain name to host Jellyfin on.";
};
acmeMail = mkOption {
type = types.nullOr types.str;
default = null;
description = "REQUIRED! The ACME mail required for the letsencrypt bot.";
description = "**REQUIRED:** The ACME mail required for the letsencrypt bot.";
};
};
};
+42
View File
@@ -0,0 +1,42 @@
# TODO: Dir creation and file permissions in nix
{
config,
lib,
...
}:
with lib; let
cfg = config.nixarr.openssh;
in {
options.nixarr.openssh.vpn.enable = {
type = types.bool;
default = false;
description = ''
Run the openssh service through a vpn.
**Note:** This option does _not_ enable the sshd service you still
need to setup sshd in your nixos configuration, fx:
```nix
services.openssh = {
enable = true;
settings.PasswordAuthentication = false;
};
users.extraUsers.username.openssh.authorizedKeys.keyFiles = [
./path/to/public/key/machine.pub}
];
```
'';
};
config = mkIf cfg.enable {
systemd.services.openssh = mkIf (cfg.vpn.enable && config.services.openssh.enable) {
bindsTo = [ "netns@wg.service" ];
requires = [ "network-online.target" ];
after = [ "wg.service" ];
serviceConfig = {
NetworkNamespacePath = "/var/run/netns/wg";
};
};
};
}