2020-04-21 14:21:17 +02:00
|
|
|
{config, pkgs, lib, ...}: let
|
|
|
|
|
2020-12-24 22:00:21 +01:00
|
|
|
unstable-pkgs = import <nixpkgs-unstable> {};
|
2020-04-21 14:21:17 +02:00
|
|
|
|
|
|
|
in {
|
|
|
|
# symlink the zigbee controller
|
|
|
|
services.udev.extraRules = ''
|
2020-12-24 22:00:21 +01:00
|
|
|
SUBSYSTEM=="tty", ATTRS{idVendor}=="0451", ATTRS{idProduct}=="16a8", SYMLINK+="cc2531", MODE="0660", GROUP="dialout"
|
|
|
|
SUBSYSTEM=="tty", ATTRS{idVendor}=="10c4", ATTRS{idProduct}=="ea60", SYMLINK+="cc2652", MODE="0660", GROUP="dialout"
|
2020-04-21 14:21:17 +02:00
|
|
|
'';
|
|
|
|
|
2020-12-24 22:00:21 +01:00
|
|
|
# needed to use unstable package
|
|
|
|
systemd.services.zigbee2mqtt.environment.ZIGBEE2MQTT_DATA = "/var/lib/zigbee2mqtt";
|
2020-04-21 14:21:17 +02:00
|
|
|
|
2020-12-24 22:00:21 +01:00
|
|
|
services.zigbee2mqtt = {
|
|
|
|
enable = true;
|
|
|
|
package = unstable-pkgs.zigbee2mqtt;
|
|
|
|
config = {
|
|
|
|
homeassistant = true;
|
|
|
|
frontend.port = 1337;
|
|
|
|
experimental.new_api = true;
|
|
|
|
permit_join = false;
|
|
|
|
mqtt = {
|
|
|
|
discovery = true;
|
|
|
|
base_topic = "zigbee";
|
|
|
|
server = "mqtt://10.42.0.1";
|
|
|
|
user = "gg23";
|
|
|
|
password = "gg23-mqtt";
|
|
|
|
};
|
|
|
|
serial = {
|
|
|
|
port = "/dev/cc2652";
|
|
|
|
# disable_led = true;
|
|
|
|
};
|
|
|
|
advanced = {
|
|
|
|
pan_id = 4222;
|
|
|
|
};
|
|
|
|
};
|
2020-04-21 14:21:17 +02:00
|
|
|
};
|
|
|
|
|
2020-11-19 18:49:04 +01:00
|
|
|
services.home-assistant.config = {
|
2020-04-21 14:21:17 +02:00
|
|
|
sensor = [
|
|
|
|
# Sensor for monitoring the bridge state
|
|
|
|
{
|
|
|
|
platform = "mqtt";
|
|
|
|
name = "Zigbee2mqtt Bridge state";
|
2020-05-16 17:21:34 +02:00
|
|
|
state_topic = "/zigbee2mqtt/bridge/state";
|
2020-04-21 14:21:17 +02:00
|
|
|
icon = "mdi:router-wireless";
|
|
|
|
}
|
|
|
|
# Sensor for Showing the Zigbee2mqtt Version
|
|
|
|
{
|
|
|
|
platform = "mqtt";
|
|
|
|
name = "Zigbee2mqtt Version";
|
2020-05-16 17:21:34 +02:00
|
|
|
state_topic = "/zigbee2mqtt/bridge/config";
|
2020-04-21 14:21:17 +02:00
|
|
|
value_template = "{{ value_json.version }}";
|
|
|
|
icon = "mdi:zigbee";
|
|
|
|
}
|
|
|
|
# Sensor for Showing the Coordinator Version
|
|
|
|
{
|
|
|
|
platform = "mqtt";
|
|
|
|
name = "Coordinator Version";
|
2020-05-16 17:21:34 +02:00
|
|
|
state_topic = "/zigbee2mqtt/bridge/config";
|
2020-04-21 14:21:17 +02:00
|
|
|
value_template = "{{ value_json.coordinator }}";
|
|
|
|
icon = "mdi:chip";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
switch = [
|
|
|
|
{
|
|
|
|
platform = "mqtt";
|
2020-05-16 17:21:34 +02:00
|
|
|
name = "zigbee2mqtt_join";
|
|
|
|
state_topic = "/zigbee2mqtt/bridge/config/permit_join";
|
|
|
|
command_topic = "/zigbee2mqtt/bridge/config/permit_join";
|
2020-04-21 14:21:17 +02:00
|
|
|
payload_on = "true";
|
|
|
|
payload_off = "false";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
automation = [
|
2020-05-16 17:21:34 +02:00
|
|
|
#{
|
|
|
|
# alias = "Zigbee2mqtt Log Level";
|
|
|
|
# initial_state = "on";
|
|
|
|
# trigger = {
|
|
|
|
# platform = "state";
|
|
|
|
# entity_id = "input_select.zigbee2mqtt_log_level";
|
|
|
|
# };
|
|
|
|
# action = [
|
|
|
|
# {
|
|
|
|
# service = "mqtt.publish";
|
|
|
|
# data = {
|
|
|
|
# payload_template = "{{ states('input_select.zigbee2mqtt_log_level') }}";
|
|
|
|
# topic = "/zigbee2mqtt/bridge/config/log_level";
|
|
|
|
# };
|
|
|
|
# }
|
|
|
|
# ];
|
|
|
|
#}
|
2020-04-21 14:21:17 +02:00
|
|
|
# Automation to start timer when enable join is turned on
|
|
|
|
{
|
|
|
|
id = "zigbee_join_enabled";
|
2020-05-16 17:21:34 +02:00
|
|
|
alias = "";
|
2020-04-21 14:21:17 +02:00
|
|
|
trigger = {
|
|
|
|
platform = "state";
|
2020-05-16 17:21:34 +02:00
|
|
|
entity_id = "switch.zigbee2mqtt_join";
|
2020-04-21 14:21:17 +02:00
|
|
|
to = "on";
|
|
|
|
};
|
|
|
|
action = {
|
|
|
|
service = "timer.start";
|
|
|
|
entity_id = "timer.zigbee_permit_join";
|
|
|
|
};
|
|
|
|
}
|
|
|
|
# Automation to stop timer when switch turned off and turn off switch when timer finished
|
|
|
|
{
|
|
|
|
id = "zigbee_join_disabled";
|
|
|
|
trigger = [
|
|
|
|
{
|
|
|
|
platform = "event";
|
|
|
|
event_type = "timer.finished";
|
|
|
|
event_data.entity_id = "timer.zigbee_permit_join";
|
|
|
|
}
|
|
|
|
{
|
|
|
|
platform = "state";
|
2020-05-16 17:21:34 +02:00
|
|
|
entity_id = "switch.zigbee2mqtt_join";
|
2020-04-21 14:21:17 +02:00
|
|
|
to = "off";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
action = [
|
|
|
|
{ service = "timer.cancel";
|
|
|
|
data.entity_id = "timer.zigbee_permit_join";
|
|
|
|
}
|
|
|
|
{ service = "switch.turn_off";
|
2020-05-16 17:21:34 +02:00
|
|
|
entity_id = "switch.zigbee2mqtt_join";
|
2020-04-21 14:21:17 +02:00
|
|
|
}
|
|
|
|
];
|
|
|
|
}
|
|
|
|
];
|
2020-05-16 17:21:34 +02:00
|
|
|
#input_select.zigbee2mqtt_log_level = {
|
|
|
|
# name = "Zigbee2mqtt Log Level";
|
|
|
|
# options = [
|
|
|
|
# "debug"
|
|
|
|
# "info"
|
|
|
|
# "warn"
|
|
|
|
# "error"
|
|
|
|
# ];
|
|
|
|
# initial = "info";
|
|
|
|
# icon = "mdi:format-list-bulleted";
|
|
|
|
#};
|
2020-04-21 14:21:17 +02:00
|
|
|
|
|
|
|
timer.zigbee_permit_join = {
|
|
|
|
name = "Zigbee Time remaining";
|
|
|
|
duration = 120;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|