feat(library): add nginx service, add acme

This commit is contained in:
514fpv 2024-01-05 00:36:49 +08:00
parent 411bd483f5
commit d423fae9db
Signed by: koishi
SSH key fingerprint: SHA256:axz0uIzzY+5W19i7QOUuiw5LSqhKfCBKPf3L4xFRxLw
2 changed files with 55 additions and 0 deletions

18
spec/library/acme.nix Normal file
View file

@ -0,0 +1,18 @@
{
security.acme = {
acceptTerms = true;
defaults.email = "koishi@514fpv.one";
defaults.group = "nginx";
certs = let
cloudflare = {
dnsProvider = "cloudflare";
credentialsFile = "/nix/persist/secret/cloudflare";
};
in {
"514fpv.io" = cloudflare;
".514fpv.io" = cloudflare // { domain = "*.514fpv.io"; };
};
};
environment.persistence."/nix/persist/fhs".directories = [ "/var/lib/acme" ];
}

37
spec/library/nginx.nix Normal file
View file

@ -0,0 +1,37 @@
{
services.nginx = {
enable = true;
# enable all recommended settings
recommendedTlsSettings = true;
recommendedOptimisation = true;
recommendedGzipSettings = true;
recommendedProxySettings = true;
# set a reasonable default
clientMaxBodySize = "64m";
# proxy services running on TrueNAS
virtualHosts = {
"_" = {
addSSL = true;
useACMEHost = ".514fpv.io";
extraConfig = "return 444;";
};
"home.514fpv.io" = {
useACMEHost = ".514fpv.io";
addSSL = true;
extraConfig = ''
proxy_buffering off;
'';
locations."/" = {
proxyPass = "http://192.168.1.250:8123";
proxyWebsockets = true;
};
};
};
};
networking.firewall.allowedTCPPorts = [ 80 443 ];
}