Refactor
This commit is contained in:
@@ -4,62 +4,63 @@ let
|
||||
serverCfg = config.syscfg.server;
|
||||
|
||||
in {
|
||||
vm = {
|
||||
portForward = [ 8123 ];
|
||||
cfg = {cfg,...}:{
|
||||
services.home-assistant = {
|
||||
enable = true;
|
||||
openFirewall = true;
|
||||
|
||||
extraComponents = [
|
||||
"matter" "thread" "cast" "zha"
|
||||
"default_config" "met" "esphome" "radio_browser"
|
||||
"telegram_bot" "swiss_public_transport" "nextcloud" "jellyfin"
|
||||
] ++ (if containerCfg.extra ? components then containerCfg.extra.components else []);
|
||||
|
||||
|
||||
extraPackages = pp: with pp; [
|
||||
python-telegram gtts
|
||||
];
|
||||
lovelaceConfig = {};
|
||||
|
||||
config = {
|
||||
homeassistant = {
|
||||
name = "Home";
|
||||
latitude = "${if containerCfg.extra ? latitude then toString containerCfg.extra.latitude else toString 0}";
|
||||
longitude = "${if containerCfg.extra ? longitude then toString containerCfg.extra.longitude else toString 0}";
|
||||
elevation = "${if containerCfg.extra ? elevation then toString containerCfg.extra.elevation else toString 0}";
|
||||
unit_system = "metric";
|
||||
time_zone = config.time.timeZone;
|
||||
};
|
||||
lovelace = { mode = "yaml"; };
|
||||
customLovelaceModules = [];
|
||||
runtime = {
|
||||
vm = {
|
||||
portForward = [ 8123 ];
|
||||
cfg = {cfg,...}: {
|
||||
services.home-assistant = {
|
||||
enable = true;
|
||||
openFirewall = true;
|
||||
|
||||
# default_config = {};
|
||||
http = {
|
||||
use_x_forwarded_for = true;
|
||||
trusted_proxies = [ "10.0.0.0/8" "127.0.0.1" ];
|
||||
extraComponents = [
|
||||
"matter" "thread" "cast" "zha"
|
||||
"default_config" "met" "esphome" "radio_browser"
|
||||
"telegram_bot" "swiss_public_transport" "nextcloud" "jellyfin"
|
||||
] ++ (if containerCfg.extra ? components then containerCfg.extra.components else []);
|
||||
|
||||
|
||||
extraPackages = pp: with pp; [
|
||||
python-telegram gtts
|
||||
];
|
||||
lovelaceConfig = {};
|
||||
|
||||
config = {
|
||||
homeassistant = {
|
||||
name = "Home";
|
||||
latitude = "${if containerCfg.extra ? latitude then toString containerCfg.extra.latitude else toString 0}";
|
||||
longitude = "${if containerCfg.extra ? longitude then toString containerCfg.extra.longitude else toString 0}";
|
||||
elevation = "${if containerCfg.extra ? elevation then toString containerCfg.extra.elevation else toString 0}";
|
||||
unit_system = "metric";
|
||||
time_zone = config.time.timeZone;
|
||||
};
|
||||
lovelace = { mode = "yaml"; };
|
||||
customLovelaceModules = [];
|
||||
|
||||
# default_config = {};
|
||||
http = {
|
||||
use_x_forwarded_for = true;
|
||||
trusted_proxies = [ "10.0.0.0/8" "127.0.0.1" ];
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
containers = {
|
||||
dummy = builder.mkContainer {
|
||||
subdomain = containerCfg.subdomain;
|
||||
image = "alpine:latest";
|
||||
extraLabels = {
|
||||
"traefik.http.services.${containerCfg.subdomain}.loadbalancer.server.url" = "http://${builder.hostIp}:8123";
|
||||
containers = {
|
||||
dummy = builder.mkContainer {
|
||||
subdomain = containerCfg.subdomain;
|
||||
image = "alpine:latest";
|
||||
extraLabels = {
|
||||
"traefik.http.services.${containerCfg.subdomain}.loadbalancer.server.url" = "http://${builder.hostIp}:8123";
|
||||
};
|
||||
overrides = {cmd = [ "sleep" "infinity" ];};
|
||||
};
|
||||
overrides = {cmd = [ "sleep" "infinity" ];};
|
||||
};
|
||||
};
|
||||
|
||||
setup = {
|
||||
trigger = "dummy";
|
||||
envFile = config.sops.secrets."CUSTOM".path;
|
||||
script = pkgs.writeShellScript "setup" ''
|
||||
setup = {
|
||||
trigger = "dummy";
|
||||
envFile = config.sops.secrets."CUSTOM".path;
|
||||
script = pkgs.writeShellScript "setup" ''
|
||||
|
||||
HASS_URL="https://${containerCfg.subdomain}.${serverCfg.domain}"
|
||||
until [[ "$(${pkgs.curl}/bin/curl -s -o /dev/null -w "%{http_code}" "$HASS_URL/manifest.json")" =~ (200|301|302) ]]; do
|
||||
@@ -95,7 +96,7 @@ in {
|
||||
-H "Content-Type: application/json" \
|
||||
-d '{"client_id":"'"$HASS_URL"'","redirect_uri":"'"$HASS_URL"'/?auth_callback=1"}' > /dev/null 2>&1 || true
|
||||
fi
|
||||
'';
|
||||
'';
|
||||
};
|
||||
};
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user