Compare commits

...

1 Commits

Author SHA1 Message Date
Ingolf Wagner 7a371654de
wip 2023-01-15 10:43:10 +01:00
8 changed files with 141 additions and 127 deletions

View File

@ -816,11 +816,11 @@
"private_assets": {
"flake": false,
"locked": {
"lastModified": 1666443661,
"narHash": "sha256-8cAQush+8XSIa4UZi3MtJljaUjg/tUUBypny/CHvGBQ=",
"lastModified": 1673774076,
"narHash": "sha256-lKzJ0lpLPR/zm7JvnMeISAGk3Au1RKxKXO6t6cn5gW8=",
"ref": "main",
"rev": "ff82fc815f2699a29ed549337e77d77971ad6cfe",
"revCount": 3,
"rev": "f51b139fd76988e9c31792e39bfd88085477654a",
"revCount": 4,
"type": "git",
"url": "ssh://gitea@git.ingolf-wagner.de/palo/nixos-private-assets.git"
},

View File

@ -7,6 +7,7 @@
./mail-fetcher.nix
./packages.nix
./hass.nix
#./home-assistant.nix
#./kodi.nix
./syncthing.nix

View File

@ -0,0 +1,20 @@
{ config, lib, pkgs, ... }:
{
imports = [
./home-assistant/zigbee2mqtt.nix
];
virtualisation.oci-containers = {
backend = "podman";
containers.homeassistant = {
volumes = [ "home-assistant:/config" ];
environment.TZ = "Europe/Berlin";
image = "ghcr.io/home-assistant/home-assistant:stable"; # Warning: if the tag does not change, the image will not be updated
extraOptions = [
"--network=host"
];
};
};
}

View File

@ -3,15 +3,15 @@
imports = [
#./home-assistant/mpd.nix
#./home-assistant/timer.nix
./home-assistant/light-control.nix
./home-assistant/iot-control.nix
./home-assistant/chaospott.nix
./home-assistant/kodi.nix
./home-assistant/mqtt.nix
./home-assistant/sonoff.nix
./home-assistant/stocks.nix
./home-assistant/weather.nix
./home-assistant/workday.nix
#./home-assistant/light-control.nix
#./home-assistant/iot-control.nix
#./home-assistant/chaospott.nix
#./home-assistant/kodi.nix
#./home-assistant/mqtt.nix
#./home-assistant/sonoff.nix
#./home-assistant/stocks.nix
#./home-assistant/weather.nix
#./home-assistant/workday.nix
./home-assistant/zigbee2mqtt.nix
];

View File

@ -1,31 +1,32 @@
{ lib, ... }: {
services.homeAssistantConfig.mqtt = {
# discovery = false;
# for mosquitto
broker = "127.0.0.1";
username = lib.fileContents <secrets/home-assistant/mqtt-user>;
password = lib.fileContents <secrets/home-assistant/mqtt-password>;
# services.mosquitto = {
# enable = true;
# host = "0.0.0.0";
# users = {
# homeassistant = {
# password = lib.fileContents <secrets/mosquitto/password>;
# acl = [ "topic readwrite #" ];
# };
# zigbee = {
# password = lib.fileContents <secrets/zigbee/password>;
# acl = [ "topic readwrite #" ];
# };
# #lightcontrol = {
# # password = "password";
# # acl = [ "topic readwrite #" ];
# #};
# };
# };
};
services.mosquitto = {
enable = true;
host = "0.0.0.0";
users = {
homeassistant = {
password = lib.fileContents <secrets/mosquitto/password>;
acl = [ "topic readwrite #" ];
};
zigbee = {
password = lib.fileContents <secrets/zigbee/password>;
acl = [ "topic readwrite #" ];
};
lightcontrol = {
password = "password";
acl = [ "topic readwrite #" ];
};
};
};
enable = true;
listeners = [ {
acl = [ "pattern readwrite #" ];
omitPasswordAuth = true;
settings.allow_anonymous = true;
} ];
};
}

View File

@ -1,43 +1,41 @@
{ pkgs, lib, config, ... }:
# no need to set ZIGBEE2MQTT_DATA anymore
assert lib.versionOlder lib.version "21.03";
{ pkgs, lib, config, private_assets, ... }:
{
imports = [
./mqtt.nix
./zigbee2mqtt/service.nix
./zigbee2mqtt/buttons.nix
./zigbee2mqtt/configurationHelper.nix
./zigbee2mqtt/doors.nix
./zigbee2mqtt/fyrtur.nix
./zigbee2mqtt/heater.nix
./zigbee2mqtt/leds.nix
./zigbee2mqtt/lights.nix
./zigbee2mqtt/motion.nix
./zigbee2mqtt/repeater.nix
./zigbee2mqtt/temperatur.nix
#./zigbee2mqtt/service.nix
#./zigbee2mqtt/buttons.nix
#./zigbee2mqtt/configurationHelper.nix
#./zigbee2mqtt/doors.nix
#./zigbee2mqtt/fyrtur.nix
#./zigbee2mqtt/heater.nix
#./zigbee2mqtt/leds.nix
#./zigbee2mqtt/lights.nix
#./zigbee2mqtt/motion.nix
#./zigbee2mqtt/repeater.nix
#./zigbee2mqtt/temperatur.nix
];
custom.services.zigbee2mqtt = {
services.zigbee2mqtt = {
enable = true;
#package = pkgs.own_zigbee2mqtt;
#package = unstable.zigbee2mqtt;
package = pkgs.unstable.zigbee2mqtt.overrideAttrs (old: rec {
version = "1.18.1";
src = pkgs.fetchFromGitHub {
owner = "Koenkk";
repo = "zigbee2mqtt";
rev = version;
sha256 = "1x73k346ayik5hv5axa3nvmd82mgwyrpxqv3dxnffi8aa1r8pf8x";
};
});
config = {
#package = pkgs.unstable.zigbee2mqtt.overrideAttrs (old: rec {
# version = "1.18.1";
# src = pkgs.fetchFromGitHub {
# owner = "Koenkk";
# repo = "zigbee2mqtt";
# rev = version;
# sha256 = "1x73k346ayik5hv5axa3nvmd82mgwyrpxqv3dxnffi8aa1r8pf8x";
# };
#});
settings = {
# Home Assistant integration (MQTT discovery)
homeassistant = false;
homeassistant = true;
# allow new devices to join
permit_join = false;
permit_join = true;
# MQTT settings
mqtt = {
@ -47,7 +45,7 @@ assert lib.versionOlder lib.version "21.03";
server = "mqtt://127.0.0.1:1883";
# MQTT server authentication, uncomment if required:
user = "zigbee";
password = lib.fileContents <secrets/zigbee/password>;
password = lib.fileContents "${private_assets}/zigbee/home-assistant-password";
};
# Serial settings
@ -61,11 +59,9 @@ assert lib.versionOlder lib.version "21.03";
# you own network key,
# 16 numbers between 0 and 255
# see https://www.zigbee2mqtt.io/how_tos/how_to_secure_network.html
advanced.network_key = import <secrets/home-assistant/zigbee/networkKey>;
advanced.network_key = import "${private_assets}/zigbee/networkKey.nix";
advanced.log_output = [ "console" ];
advanced.pan_id = 1337;
# add last seen information
advanced.last_seen = "ISO_8601_local";
@ -77,10 +73,6 @@ assert lib.versionOlder lib.version "21.03";
};
};
#systemd.services.zigbee2mqtt.environment = {
# ZIGBEE2MQTT_DATA = "/var/lib/zigbee2mqtt";
#};
services.nginx = {
enable = true;
recommendedProxySettings = true;
@ -89,7 +81,7 @@ assert lib.versionOlder lib.version "21.03";
serverAliases = [ "zigbee.pepe.private" ];
locations."/" = {
proxyPass = "http://localhost:${
toString config.custom.services.zigbee2mqtt.config.frontend.port
toString config.services.zigbee2mqtt.settings.frontend.port
}";
proxyWebsockets = true;
};

View File

@ -8,5 +8,5 @@ in {
device definitions
'';
};
config = { services.zigbee2mqtt.config.devices = cfg; };
config = { services.zigbee2mqtt.settings.devices = cfg; };
}

View File

@ -16,7 +16,7 @@ let
in
{
services.zigbee2mqttConfiguration = lib.mapAttrs'
services.zigbee2mqtt.settings = lib.mapAttrs'
(name:
{ id, ... }: {
name = id;
@ -27,59 +27,59 @@ in
})
allDevices;
services.homeAssistantConfig = {
#services.homeAssistantConfig = {
# # define meta information sensors
# sensor = lib.flatten (lib.mapAttrsToList
# (name:
# { ... }: [
# {
# platform = "mqtt";
# name = name;
# state_topic = "zigbee2mqtt/${name}";
# availability_topic = "zigbee2mqtt/bridge/state";
# unit_of_measurement = "°C";
# device_class = "temperature";
# value_template = "{{ value_json.temperature }}";
# }
# {
# platform = "mqtt";
# name = "humidity_${name}";
# state_topic = "zigbee2mqtt/${name}";
# availability_topic = "zigbee2mqtt/bridge/state";
# unit_of_measurement = "%";
# device_class = "humidity";
# value_template = "{{ value_json.humidity }}";
# }
# #{
# # platform = "mqtt";
# # name = "pressure_${name}";
# # state_topic = "zigbee2mqtt/${name}";
# # availability_topic = "zigbee2mqtt/bridge/state";
# # unit_of_measurement = "hPa";
# # device_class = "pressure";
# # value_template = "{{ value_json.pressure }}";
# #}
# {
# name = "battery_${name}";
# platform = "mqtt";
# state_topic = "zigbee2mqtt/${name}";
# availability_topic = "zigbee2mqtt/bridge/state";
# unit_of_measurement = "%";
# icon = "mdi:battery-10";
# value_template = "{{ value_json.battery }}";
# }
# {
# name = "link_${name}";
# platform = "mqtt";
# state_topic = "zigbee2mqtt/${name}";
# availability_topic = "zigbee2mqtt/bridge/state";
# icon = "mdi:signal";
# unit_of_measurement = "lqi";
# value_template = "{{ value_json.linkquality }}";
# }
# ])
# allDevices);
# define meta information sensors
sensor = lib.flatten (lib.mapAttrsToList
(name:
{ ... }: [
{
platform = "mqtt";
name = name;
state_topic = "zigbee2mqtt/${name}";
availability_topic = "zigbee2mqtt/bridge/state";
unit_of_measurement = "°C";
device_class = "temperature";
value_template = "{{ value_json.temperature }}";
}
{
platform = "mqtt";
name = "humidity_${name}";
state_topic = "zigbee2mqtt/${name}";
availability_topic = "zigbee2mqtt/bridge/state";
unit_of_measurement = "%";
device_class = "humidity";
value_template = "{{ value_json.humidity }}";
}
#{
# platform = "mqtt";
# name = "pressure_${name}";
# state_topic = "zigbee2mqtt/${name}";
# availability_topic = "zigbee2mqtt/bridge/state";
# unit_of_measurement = "hPa";
# device_class = "pressure";
# value_template = "{{ value_json.pressure }}";
#}
{
name = "battery_${name}";
platform = "mqtt";
state_topic = "zigbee2mqtt/${name}";
availability_topic = "zigbee2mqtt/bridge/state";
unit_of_measurement = "%";
icon = "mdi:battery-10";
value_template = "{{ value_json.battery }}";
}
{
name = "link_${name}";
platform = "mqtt";
state_topic = "zigbee2mqtt/${name}";
availability_topic = "zigbee2mqtt/bridge/state";
icon = "mdi:signal";
unit_of_measurement = "lqi";
value_template = "{{ value_json.linkquality }}";
}
])
allDevices);
# create groups
# -------------