1
0
Fork 0
dotfiles/container/weewx/default.nix

118 lines
2.6 KiB
Nix
Raw Normal View History

2023-07-17 00:17:50 +02:00
{ config, ... }:
2023-03-17 21:58:31 +01:00
2022-07-31 00:36:06 +02:00
let
2023-03-17 21:58:31 +01:00
secret = import ../../secret/container/weewx;
data-dir = "/var/lib/weewx";
2022-07-31 00:36:06 +02:00
in
{
2023-03-19 00:14:03 +01:00
virtualisation.oci-containers.containers.weewx = {
2023-12-10 12:46:39 +01:00
image = "git.kempkens.io/daniel/weewx-docker:latest";
2023-03-19 00:14:03 +01:00
ports = [ "127.0.0.1:8000:8000" ];
environment = {
"TZ" = "Europe/Berlin";
2022-07-31 00:36:06 +02:00
};
2023-03-19 00:14:03 +01:00
volumes = [
"${data-dir}:/data"
];
extraOptions = [
"--label=com.centurylinklabs.watchtower.enable=true"
"--label=io.containers.autoupdate=registry"
];
2022-07-31 00:36:06 +02:00
};
2023-03-06 22:20:26 +01:00
2023-05-25 19:15:54 +02:00
systemd.services.podman-weewx.restartTriggers = [
"${config.age.secrets.weewx-config.file}"
"${config.age.secrets.weewx-skin.file}"
];
2023-03-17 21:58:31 +01:00
systemd.tmpfiles.rules = [
"d ${data-dir} 0755 421 421"
"d ${data-dir}/html 0755 421 421"
2023-03-25 14:08:09 +01:00
"d ${data-dir}/skin-wdc 0755 421 421"
2023-03-17 21:58:31 +01:00
];
2023-03-25 00:06:34 +01:00
services.mosquitto.listeners = [
{
address = "0.0.0.0";
port = 1883;
settings = {
protocol = "mqtt";
2023-03-17 22:08:56 +01:00
};
2023-03-17 21:58:31 +01:00
2023-03-25 00:06:34 +01:00
users = {
weewx-proxy = {
hashedPasswordFile = config.age.secrets.mosquitto-password-weewx-proxy.path;
acl = [ "write weewx/+" ];
};
weewx = {
hashedPasswordFile = config.age.secrets.mosquitto-password-weewx.path;
acl = [ "read weewx/+" "write weather/+" ];
};
2023-03-17 21:58:31 +01:00
};
2023-03-25 00:06:34 +01:00
}
{
address = "127.0.0.1";
port = 9883;
settings = {
protocol = "websockets";
allow_anonymous = true;
2023-03-25 00:06:34 +01:00
};
acl = [ "topic read weather/+" ];
2023-03-25 00:06:34 +01:00
}
];
2023-03-17 21:58:31 +01:00
2023-03-17 22:20:33 +01:00
networking.firewall.interfaces =
let
mosquittoPorts = [ 1883 ];
in
{
"tailscale0".allowedTCPPorts = mosquittoPorts;
"podman+".allowedTCPPorts = mosquittoPorts;
};
2023-03-17 21:58:31 +01:00
services.nginx.virtualHosts."${secret.container.weewx.hostname}" = {
2023-04-03 15:03:52 +02:00
quic = true;
2023-03-06 22:20:26 +01:00
http3 = true;
2023-03-12 12:22:44 +01:00
kTLS = true;
2023-03-06 22:20:26 +01:00
2023-03-17 21:58:31 +01:00
root = "${data-dir}/html/wdc";
2023-03-06 22:20:26 +01:00
forceSSL = true;
useACMEHost = "kempkens.io";
2023-03-06 22:21:22 +01:00
extraConfig = ''
index index.html;
2023-03-06 23:39:49 +01:00
add_header Strict-Transport-Security "max-age=31536000; includeSubDomains; preload" always;
2023-03-06 22:21:22 +01:00
'';
2023-03-06 22:22:15 +01:00
locations."~* \.html$".extraConfig = ''
2023-03-06 22:20:26 +01:00
expires modified 120s;
'';
2023-03-06 22:22:15 +01:00
locations."~* \.(js|css)$".extraConfig = ''
2023-03-06 22:20:26 +01:00
expires 1h;
'';
locations."~ ^/dwd/(icons|warn_icons)/" = {
root = "${data-dir}/static_html";
2023-03-24 22:30:50 +01:00
extraConfig = ''
expires 7d;
'';
2023-03-06 22:20:26 +01:00
};
2023-03-06 22:22:15 +01:00
locations."~ ^/dwd/[\w]+\.(gif|png)".extraConfig = ''
2023-03-06 22:20:26 +01:00
expires modified 1h;
'';
2023-03-25 00:31:06 +01:00
locations."/mqtt" = {
recommendedProxySettings = true;
proxyPass = "http://127.0.0.1:9883";
proxyWebsockets = true;
};
2023-03-06 22:20:26 +01:00
};
2023-03-17 21:58:31 +01:00
}