Compare commits
5 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
2b89cbc188 | ||
|
|
23626a37d1 | ||
|
|
468d299e9e | ||
|
|
afc1124b64 | ||
|
|
17fe7c10c1 |
@@ -10,25 +10,25 @@
|
||||
<project>GenericApp</project>
|
||||
<configuration>Zintercom_Router</configuration>
|
||||
</member>
|
||||
<member>
|
||||
<project>GenericApp</project>
|
||||
<configuration>Zintercom_Router_PA1</configuration>
|
||||
</member>
|
||||
<member>
|
||||
<project>GenericApp</project>
|
||||
<configuration>Zintercom_Router_PA2</configuration>
|
||||
</member>
|
||||
<member>
|
||||
<project>GenericApp</project>
|
||||
<configuration>Zintercom_EndDevice</configuration>
|
||||
</member>
|
||||
<member>
|
||||
<project>GenericApp</project>
|
||||
<configuration>Zintercom_Router_CC2592</configuration>
|
||||
<configuration>Zintercom_EndDevice_PA1</configuration>
|
||||
</member>
|
||||
<member>
|
||||
<project>GenericApp</project>
|
||||
<configuration>Zintercom_EndDevice_CC2592</configuration>
|
||||
</member>
|
||||
<member>
|
||||
<project>GenericApp</project>
|
||||
<configuration>Zintercom_Router_CC2591</configuration>
|
||||
</member>
|
||||
<member>
|
||||
<project>GenericApp</project>
|
||||
<configuration>Zintercom_EndDevice_CC2591</configuration>
|
||||
<configuration>Zintercom_EndDevice_PA2</configuration>
|
||||
</member>
|
||||
</batchDefinition>
|
||||
</batchBuild>
|
||||
|
||||
55
README.md
@@ -1,5 +1,21 @@
|
||||
# Zintercom
|
||||
## Zigbee Intercom Automator
|
||||
##### Zigbee Intercom Automator
|
||||
This device is designed to control the matrix intercom using Zigbee.
|
||||
|
||||
Using zigbee2mqtt you can:
|
||||
1. Receive notification when the intercom rings. (also support **direct bind**)
|
||||
2. Mute the sound on the intercom handset.
|
||||
3. Automatically or manually open the door or hang up when the intercom rings.
|
||||
|
||||
There are 4 work modes:
|
||||
1. `Never` - ordinary work mode, use handset to control
|
||||
2. `Once` - one time open door when intercom rings
|
||||
3. `Always` - open door when intercom rings
|
||||
4. `Drop` - hangs up all intercom rings, right after start
|
||||
|
||||
You can change the operating mode with z2m or by pressing the button.
|
||||
After pressing the button, the LED will flash.
|
||||
The number of flashes indicates the current operating mode.
|
||||
|
||||
### How to join
|
||||
Reset to FN by reboot device 5 times with interval less than 10 seconds.
|
||||
@@ -7,14 +23,13 @@ Reset to FN by press and hold BTN for 5 seconds.
|
||||
|
||||
LED will flash during reset.
|
||||
|
||||
<img src="./images/z2m_dashboard.gif" width="45%">
|
||||
|
||||
### How to add device into zigbe2mqtt
|
||||
Use [external converters](https://www.zigbee2mqtt.io/information/configuration.html#external-converters-configuration) feature
|
||||
|
||||
Converter file located [here](./converters/DIY_Zintercom.js)
|
||||
|
||||
<img src="./images/z2m_dashboard.png" width="45%">
|
||||
|
||||
<img src="./images/z2m_exposes.png" width="90%">
|
||||
|
||||
### Schematic
|
||||
@@ -32,14 +47,40 @@ Converter file located [here](./converters/DIY_Zintercom.js)
|
||||
|
||||
Support `router` and `end device` modes.
|
||||
Install `E18-MS1PA1`, `E18-MS1PA2` or `E18-MS1-PCB`.
|
||||
|
||||
<img src="./images/front_side.png" width="70%">
|
||||
<img src="./images/back_DC_5-9V.png" width="35%">
|
||||
<img src="./images/back_microUSB.png" width="35%">
|
||||
|
||||
<img src="./images/back_DC_5-9V.png" width="70%">
|
||||
|
||||
|
||||
### Battery Power
|
||||
|
||||
Support only `end device` mode.
|
||||
Install `E18-MS1-PCB` only!
|
||||
<img src="./images/back_2xAAA.png" width="35%">
|
||||
<img src="./images/back_CR2032.png" width="35%">
|
||||
|
||||
Do not turn off `sound` because it turns U2 forever, which will drain the battery much faster.
|
||||
|
||||
Since the device is in sleep mode, it cannot receive commands.
|
||||
But you have the ability to set the button mode or at the time of the call.
|
||||
|
||||
If any commands are in the coordinator's queue, they will be executed after a button is pressed or a call is received.
|
||||
|
||||
<img src="./images/back_2xAAA.png" width="70%">
|
||||
|
||||
##### The mode set by the Zigbee command `overwrites` the mode set by the button.
|
||||
|
||||
### Binding
|
||||
The device supports direct binding of an incoming call to the onOff cluster.
|
||||
|
||||
For example, you can turn on the light while a call comes to the intercom, for notification in mute mode.
|
||||
|
||||
|
||||
### Files to reproduce
|
||||
* [Gerbers and BOM](https://github.com/diyruz/Zintercom/tree/master/hardware) by [xyzroe](https://t.me/xyzroe)
|
||||
* [Firmware](https://github.com/diyruz/Zintercom/releases) by [xyzroe](https://t.me/xyzroe)
|
||||
|
||||
|
||||
### Inspired by
|
||||
The original scheme of the intercom opener by [Alexander Vaidurov](https://easyeda.com/Alex_AW/domofon-with-battery)
|
||||
Various hardware solutions by [Jager](https://modkam.ru)
|
||||
Firmware for different Zigbee devices by [Anonymous](https://github.com/nurikk/)
|
||||
|
||||
@@ -249,7 +249,7 @@ extern void MAC_RfFrontendSetup(void);
|
||||
HAL_BOARD_RF_FRONTEND_SETUP(); \
|
||||
LED1_DDR |= LED1_BV; \
|
||||
LED2_DDR |= LED2_BV; \
|
||||
LED3_DDR |= LED3_BV;
|
||||
LED3_DDR |= LED3_BV; \
|
||||
LED4_DDR |= LED4_BV; \
|
||||
}
|
||||
|
||||
|
||||
@@ -7,11 +7,6 @@ const {
|
||||
const ep = exposes.presets;
|
||||
const ea = exposes.access;
|
||||
|
||||
const ZCL_DATATYPE_INT16 = 0x29;
|
||||
const ZCL_DATATYPE_UINT8 = 0x20;
|
||||
const ZCL_DATATYPE_UINT16 = 0x21;
|
||||
const ZCL_DATATYPE_BOOLEAN = 0x10;
|
||||
const ZCL_DATATYPE_INT32 = 0x2b;
|
||||
const bind = async (endpoint, target, clusters) => {
|
||||
for (const cluster of clusters) {
|
||||
await endpoint.bind(cluster, target);
|
||||
@@ -63,8 +58,6 @@ const repInterval = {
|
||||
MINUTE: 60,
|
||||
};
|
||||
|
||||
|
||||
|
||||
const fz = {
|
||||
diy_zintercom_config: {
|
||||
cluster: 'closuresDoorLock',
|
||||
@@ -150,11 +143,10 @@ const tz = {
|
||||
|
||||
const device = {
|
||||
zigbeeModel: ['DIY_Zintercom'],
|
||||
model: 'DIY_Zintercom',
|
||||
vendor: 'xyzroe',
|
||||
description: '[Intercom Auto Opener]',
|
||||
supports: '',
|
||||
//homeassistant: [hass.temperature, hass.presure, hass.humidity, hass.co2],
|
||||
model: 'DIYRuZ_Zintercom',
|
||||
vendor: 'DIYRuZ',
|
||||
description: '[Matrix intercom auto opener](https://diyruz.github.io/posts/zintercom/)',
|
||||
icon: 'https://github.com/diyruz/Zintercom/blob/master/images/z2m.png?raw=true',
|
||||
fromZigbee: [
|
||||
fromZigbeeConverters.battery,
|
||||
fz.diy_zintercom_config,
|
||||
@@ -169,37 +161,11 @@ const device = {
|
||||
configure: async (device, coordinatorEndpoint) => {
|
||||
const firstEndpoint = device.getEndpoint(1);
|
||||
|
||||
//await bind(firstEndpoint, coordinatorEndpoint, ['msCO2', 'closuresDoorLock', 'genOnOff']);
|
||||
|
||||
await bind(firstEndpoint, coordinatorEndpoint, ['closuresDoorLock', 'genPowerCfg']);
|
||||
|
||||
const overides = {min: 0, max: 3600, change: 0};
|
||||
await configureReporting.batteryVoltage(firstEndpoint, overides);
|
||||
await configureReporting.batteryPercentageRemaining(firstEndpoint, overides);
|
||||
/*
|
||||
if (device.applicationVersion < 3) { // Legacy PM2 firmwares
|
||||
const payload = [{
|
||||
attribute: 'batteryPercentageRemaining',
|
||||
minimumReportInterval: 0,
|
||||
maximumReportInterval: 3600,
|
||||
reportableChange: 0,
|
||||
}, {
|
||||
attribute: 'batteryVoltage',
|
||||
minimumReportInterval: 0,
|
||||
maximumReportInterval: 3600,
|
||||
reportableChange: 0,
|
||||
}];
|
||||
await firstEndpoint.configureReporting('genPowerCfg', payload);
|
||||
}
|
||||
*/
|
||||
/*
|
||||
const msBindPayload = [{
|
||||
attribute: 'measuredValue',
|
||||
minimumReportInterval: 0,
|
||||
maximumReportInterval: 3600,
|
||||
reportableChange: 0,
|
||||
}];
|
||||
await firstEndpoint.configureReporting('msCO2', msBindPayload);
|
||||
*/
|
||||
|
||||
const payload = [{
|
||||
attribute: {
|
||||
@@ -212,20 +178,6 @@ const device = {
|
||||
},
|
||||
];
|
||||
await firstEndpoint.configureReporting('closuresDoorLock', payload);
|
||||
/**/
|
||||
/*
|
||||
await firstEndpoint.configureReporting('msTemperatureMeasurement', msBindPayload);
|
||||
await firstEndpoint.configureReporting('msRelativeHumidity', msBindPayload);
|
||||
|
||||
const pressureBindPayload = [{
|
||||
attribute: 'scaledValue',
|
||||
minimumReportInterval: 0,
|
||||
maximumReportInterval: 3600,
|
||||
reportableChange: 0,
|
||||
}];
|
||||
await firstEndpoint.configureReporting('msPressureMeasurement', pressureBindPayload);
|
||||
*/
|
||||
|
||||
|
||||
},
|
||||
exposes: [
|
||||
|
Before Width: | Height: | Size: 330 KiB After Width: | Height: | Size: 313 KiB |
|
Before Width: | Height: | Size: 348 KiB After Width: | Height: | Size: 192 KiB |
|
Before Width: | Height: | Size: 347 KiB |
|
Before Width: | Height: | Size: 265 KiB After Width: | Height: | Size: 175 KiB |
|
Before Width: | Height: | Size: 400 KiB |
|
Before Width: | Height: | Size: 239 KiB After Width: | Height: | Size: 298 KiB |
|
Before Width: | Height: | Size: 188 KiB After Width: | Height: | Size: 198 KiB |
BIN
images/z2m.png
Normal file
|
After Width: | Height: | Size: 190 KiB |
BIN
images/z2m_dashboard.gif
Normal file
|
After Width: | Height: | Size: 559 KiB |
|
Before Width: | Height: | Size: 45 KiB |