wip
parent
c48bda2ac4
commit
7a371654de
|
@ -816,11 +816,11 @@
|
||||||
"private_assets": {
|
"private_assets": {
|
||||||
"flake": false,
|
"flake": false,
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1666443661,
|
"lastModified": 1673774076,
|
||||||
"narHash": "sha256-8cAQush+8XSIa4UZi3MtJljaUjg/tUUBypny/CHvGBQ=",
|
"narHash": "sha256-lKzJ0lpLPR/zm7JvnMeISAGk3Au1RKxKXO6t6cn5gW8=",
|
||||||
"ref": "main",
|
"ref": "main",
|
||||||
"rev": "ff82fc815f2699a29ed549337e77d77971ad6cfe",
|
"rev": "f51b139fd76988e9c31792e39bfd88085477654a",
|
||||||
"revCount": 3,
|
"revCount": 4,
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "ssh://gitea@git.ingolf-wagner.de/palo/nixos-private-assets.git"
|
"url": "ssh://gitea@git.ingolf-wagner.de/palo/nixos-private-assets.git"
|
||||||
},
|
},
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
|
|
||||||
./mail-fetcher.nix
|
./mail-fetcher.nix
|
||||||
./packages.nix
|
./packages.nix
|
||||||
|
./hass.nix
|
||||||
#./home-assistant.nix
|
#./home-assistant.nix
|
||||||
#./kodi.nix
|
#./kodi.nix
|
||||||
./syncthing.nix
|
./syncthing.nix
|
||||||
|
|
|
@ -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"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
|
@ -3,15 +3,15 @@
|
||||||
imports = [
|
imports = [
|
||||||
#./home-assistant/mpd.nix
|
#./home-assistant/mpd.nix
|
||||||
#./home-assistant/timer.nix
|
#./home-assistant/timer.nix
|
||||||
./home-assistant/light-control.nix
|
#./home-assistant/light-control.nix
|
||||||
./home-assistant/iot-control.nix
|
#./home-assistant/iot-control.nix
|
||||||
./home-assistant/chaospott.nix
|
#./home-assistant/chaospott.nix
|
||||||
./home-assistant/kodi.nix
|
#./home-assistant/kodi.nix
|
||||||
./home-assistant/mqtt.nix
|
#./home-assistant/mqtt.nix
|
||||||
./home-assistant/sonoff.nix
|
#./home-assistant/sonoff.nix
|
||||||
./home-assistant/stocks.nix
|
#./home-assistant/stocks.nix
|
||||||
./home-assistant/weather.nix
|
#./home-assistant/weather.nix
|
||||||
./home-assistant/workday.nix
|
#./home-assistant/workday.nix
|
||||||
./home-assistant/zigbee2mqtt.nix
|
./home-assistant/zigbee2mqtt.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
|
@ -1,31 +1,32 @@
|
||||||
{ lib, ... }: {
|
{ lib, ... }: {
|
||||||
services.homeAssistantConfig.mqtt = {
|
|
||||||
|
|
||||||
# discovery = false;
|
# services.mosquitto = {
|
||||||
# for mosquitto
|
# enable = true;
|
||||||
broker = "127.0.0.1";
|
# host = "0.0.0.0";
|
||||||
username = lib.fileContents <secrets/home-assistant/mqtt-user>;
|
# users = {
|
||||||
password = lib.fileContents <secrets/home-assistant/mqtt-password>;
|
# 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 = {
|
services.mosquitto = {
|
||||||
enable = true;
|
enable = true;
|
||||||
host = "0.0.0.0";
|
listeners = [ {
|
||||||
users = {
|
acl = [ "pattern readwrite #" ];
|
||||||
homeassistant = {
|
omitPasswordAuth = true;
|
||||||
password = lib.fileContents <secrets/mosquitto/password>;
|
settings.allow_anonymous = true;
|
||||||
acl = [ "topic readwrite #" ];
|
} ];
|
||||||
};
|
};
|
||||||
zigbee = {
|
|
||||||
password = lib.fileContents <secrets/zigbee/password>;
|
|
||||||
acl = [ "topic readwrite #" ];
|
|
||||||
};
|
|
||||||
lightcontrol = {
|
|
||||||
password = "password";
|
|
||||||
acl = [ "topic readwrite #" ];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,43 +1,41 @@
|
||||||
{ pkgs, lib, config, ... }:
|
{ pkgs, lib, config, private_assets, ... }:
|
||||||
# no need to set ZIGBEE2MQTT_DATA anymore
|
|
||||||
assert lib.versionOlder lib.version "21.03";
|
|
||||||
|
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
./mqtt.nix
|
./mqtt.nix
|
||||||
./zigbee2mqtt/service.nix
|
#./zigbee2mqtt/service.nix
|
||||||
./zigbee2mqtt/buttons.nix
|
#./zigbee2mqtt/buttons.nix
|
||||||
./zigbee2mqtt/configurationHelper.nix
|
#./zigbee2mqtt/configurationHelper.nix
|
||||||
./zigbee2mqtt/doors.nix
|
#./zigbee2mqtt/doors.nix
|
||||||
./zigbee2mqtt/fyrtur.nix
|
#./zigbee2mqtt/fyrtur.nix
|
||||||
./zigbee2mqtt/heater.nix
|
#./zigbee2mqtt/heater.nix
|
||||||
./zigbee2mqtt/leds.nix
|
#./zigbee2mqtt/leds.nix
|
||||||
./zigbee2mqtt/lights.nix
|
#./zigbee2mqtt/lights.nix
|
||||||
./zigbee2mqtt/motion.nix
|
#./zigbee2mqtt/motion.nix
|
||||||
./zigbee2mqtt/repeater.nix
|
#./zigbee2mqtt/repeater.nix
|
||||||
./zigbee2mqtt/temperatur.nix
|
#./zigbee2mqtt/temperatur.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
custom.services.zigbee2mqtt = {
|
services.zigbee2mqtt = {
|
||||||
enable = true;
|
enable = true;
|
||||||
#package = pkgs.own_zigbee2mqtt;
|
#package = pkgs.own_zigbee2mqtt;
|
||||||
#package = unstable.zigbee2mqtt;
|
#package = unstable.zigbee2mqtt;
|
||||||
package = pkgs.unstable.zigbee2mqtt.overrideAttrs (old: rec {
|
#package = pkgs.unstable.zigbee2mqtt.overrideAttrs (old: rec {
|
||||||
version = "1.18.1";
|
# version = "1.18.1";
|
||||||
src = pkgs.fetchFromGitHub {
|
# src = pkgs.fetchFromGitHub {
|
||||||
owner = "Koenkk";
|
# owner = "Koenkk";
|
||||||
repo = "zigbee2mqtt";
|
# repo = "zigbee2mqtt";
|
||||||
rev = version;
|
# rev = version;
|
||||||
sha256 = "1x73k346ayik5hv5axa3nvmd82mgwyrpxqv3dxnffi8aa1r8pf8x";
|
# sha256 = "1x73k346ayik5hv5axa3nvmd82mgwyrpxqv3dxnffi8aa1r8pf8x";
|
||||||
};
|
# };
|
||||||
});
|
#});
|
||||||
config = {
|
settings = {
|
||||||
|
|
||||||
# Home Assistant integration (MQTT discovery)
|
# Home Assistant integration (MQTT discovery)
|
||||||
homeassistant = false;
|
homeassistant = true;
|
||||||
|
|
||||||
# allow new devices to join
|
# allow new devices to join
|
||||||
permit_join = false;
|
permit_join = true;
|
||||||
|
|
||||||
# MQTT settings
|
# MQTT settings
|
||||||
mqtt = {
|
mqtt = {
|
||||||
|
@ -47,7 +45,7 @@ assert lib.versionOlder lib.version "21.03";
|
||||||
server = "mqtt://127.0.0.1:1883";
|
server = "mqtt://127.0.0.1:1883";
|
||||||
# MQTT server authentication, uncomment if required:
|
# MQTT server authentication, uncomment if required:
|
||||||
user = "zigbee";
|
user = "zigbee";
|
||||||
password = lib.fileContents <secrets/zigbee/password>;
|
password = lib.fileContents "${private_assets}/zigbee/home-assistant-password";
|
||||||
};
|
};
|
||||||
|
|
||||||
# Serial settings
|
# Serial settings
|
||||||
|
@ -61,11 +59,9 @@ assert lib.versionOlder lib.version "21.03";
|
||||||
# you own network key,
|
# you own network key,
|
||||||
# 16 numbers between 0 and 255
|
# 16 numbers between 0 and 255
|
||||||
# see https://www.zigbee2mqtt.io/how_tos/how_to_secure_network.html
|
# 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.log_output = [ "console" ];
|
||||||
|
|
||||||
advanced.pan_id = 1337;
|
advanced.pan_id = 1337;
|
||||||
|
|
||||||
# add last seen information
|
# add last seen information
|
||||||
advanced.last_seen = "ISO_8601_local";
|
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 = {
|
services.nginx = {
|
||||||
enable = true;
|
enable = true;
|
||||||
recommendedProxySettings = true;
|
recommendedProxySettings = true;
|
||||||
|
@ -89,7 +81,7 @@ assert lib.versionOlder lib.version "21.03";
|
||||||
serverAliases = [ "zigbee.pepe.private" ];
|
serverAliases = [ "zigbee.pepe.private" ];
|
||||||
locations."/" = {
|
locations."/" = {
|
||||||
proxyPass = "http://localhost:${
|
proxyPass = "http://localhost:${
|
||||||
toString config.custom.services.zigbee2mqtt.config.frontend.port
|
toString config.services.zigbee2mqtt.settings.frontend.port
|
||||||
}";
|
}";
|
||||||
proxyWebsockets = true;
|
proxyWebsockets = true;
|
||||||
};
|
};
|
||||||
|
|
|
@ -8,5 +8,5 @@ in {
|
||||||
device definitions
|
device definitions
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
config = { services.zigbee2mqtt.config.devices = cfg; };
|
config = { services.zigbee2mqtt.settings.devices = cfg; };
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,7 +16,7 @@ let
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
|
|
||||||
services.zigbee2mqttConfiguration = lib.mapAttrs'
|
services.zigbee2mqtt.settings = lib.mapAttrs'
|
||||||
(name:
|
(name:
|
||||||
{ id, ... }: {
|
{ id, ... }: {
|
||||||
name = id;
|
name = id;
|
||||||
|
@ -27,59 +27,59 @@ in
|
||||||
})
|
})
|
||||||
allDevices;
|
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
|
# create groups
|
||||||
# -------------
|
# -------------
|
||||||
|
|
Loading…
Reference in New Issue