Интегрируем охранную систему Honeywell (Ademco) VISTA 10 с домашней автоматизацией Fibaro

b54e794aea1d416d969d1748072f0fb6.jpgКомпания Honeywell (Ademco) разрабатывает популярные охранные системы VISTA, начиная от простых VISTA-10 до богатых функционалом VISTA-250. Многофункциональные охранные системы VISTA-128/250 содержат порт RS232, что позволяет интегрировать их в любую другую систему.
Мне была поставлена задача:»Интегрировать охранную систему VISTA-10 L в систему домашней автоматизации Fibaro, из одного мобильного приложения нужно управлять и освещением и гаражными воротами и ставить дом на охрану».

При беглом изучении VISTA-10 L, выяснилось, что никакого UART там нет и в помине. К счастью на просторах американского интернета была найдена компания www.alarmdecoder.com, которая занимается разработкой плат имитирующих работу пульта управления. Плата существует в 3-х вариантах подключения: USB, RS-232, UART шилд для Raspberry Pi. Я выбрал шилд AD2Pi для Raspberry Pi.
e14e5491e7f54733b7940bc4afb5016a.jpg
Плата AD2Pi подключается к клеммам пульта управления и для охранной системы представляется, как еще один пульт управления и индикации.
e50f48fef8574a3993dbd4fb27ebac1f.jpg
Пульт управления и индикации (control panel)

Схема подключения проста:

AD2Pi VISTA контрольная панель
- 4 — KEYPAD GROUND (-)
+ 5 — KEYPAD PWD (+)
DI 6 — DATA IN TO KEYPAD
DO 7 — DATA OUT TO KEYPAD


5a9d398300404448a30e52672bbdf1d0.jpg
82f28427842c41ca92d5650a89749b8d.JPG
После подключения AD2Pi к контрольной панели VISTA, переходим к работе с софтом. alarmdecoder позволяет полностью управлять и мониторить охранную систему.1) Установка python библиотеки alarmdecoder
alarmdecoder позволяет принимать все системные сообщения в распарсенном виде, отправлять команды управления и настройки.

pip install alarmdecoder


или из git

git clone https://github.com/nutechsoftware/alarmdecoder.git
cd alarmdecoder
python setup.py install


2) Установка ser2sock — Serial to Socket Redirector
ser2sock позволяет подключиться к serial порту удаленно, это нужно чтобы управлять охранной системой не только с Raspberry Pi, но и с любого другого компьютера/устройства напрямую.

git clone https://github.com/nutechsoftware/ser2sock.git


Подробности установки тут: https://github.com/nutechsoftware/ser2sock3) Настройка платы AD2Pi
Первым делом нужно настроить плату AD2Pi, чтобы оно передавала нам все интересующие события. Подключитесь к serial порту AD2Pi через minicom и для входа в режим настройки введите »!». Обратите внимание, что адрес виртуальной панели управления должен быть 31, LRR должен быть Y, и маска по адресам ffffffff, т.е. получать сообщения от всех.

sudo minicom -d /dev/ttyAMA0


29bc72ac9f514b76971d4ee46ebc0ea3.png
На пульте управления нужно активировать функцию отправки сообщений через LRR/GSM, тогда мы будем знать какой пользователь снял и поставил на охрану.
c0eed28609a64734a86c80f1a4b00d79.png4) Проверка работоспособности системы
Запускаем ser2sock и слушаем порт 10000

sudo /etc/init.d/ser2sock start
nc localhost 10000


Должны увидеть сообщения от системы
db09f58653934905a8fd6a582a514603.png5) Обработка сообщений от охранной системы
56b7ca401cfc40f7870ab0cb9199c888.png

Python cкрипт отправки сообщений от alarmdecoder на контроллер автоматизации Home Center 2
#!/usr/bin/python
# -*- coding: utf-8 -*-
import json
import base64
import time
from time import gmtime, strftime
import requests
from requests.auth import HTTPBasicAuth
from alarmdecoder import AlarmDecoder
from alarmdecoder.devices import SocketDevice

# Configuration values
HOSTNAME = 'localhost'
PORT = 10000

# Fibaro access
username = "admin"
password = "admin"

def main():
    """
    Example application that prints messages from the panel to the terminal.
    """
    try:
        # Retrieve an AD2 device that has been exposed with ser2sock on localhost:10000.
        device = AlarmDecoder(SocketDevice(interface=(HOSTNAME, PORT)))

        # Set up an event handler and open the device
        device.on_message += handle_message
        device.on_lrr_message += handle_lrr_message
        with device.open():
            while True:
                time.sleep(1)

    except Exception, ex:
        print 'Exception:', ex

def handle_message(sender, message):
    """
    Handles message events from the AlarmDecoder.
    """
    print message.text

    jsonData = {"value":message.text}
    requests.put('http://10.0.1.43/api/globalVariables/AlarmStatus', json = jsonData, auth=HTTPBasicAuth(username, password))

def handle_lrr_message(sender, message):
    """
    Handles message events from the AlarmDecoder.
    """
    lrr_message = message.event_data + " " + message.event_type  
    print lrr_message
    jsonData = {"value":lrr_message}
    requests.put('http://10.0.1.43/api/globalVariables/AlarmUsers', json = jsonData, auth=HTTPBasicAuth(username, password))

if __name__ == '__main__':
    main()


Для обработки сообщения я написал небольшой python скрипт, который поставил в автозагрузку.
Скрипт подключается к сервису ser2sock, получает от него сообщения и отправляет их на контроллер автоматизации Home Center 2. На контроллере я обрабатываю сообщения, отображаю их в виртуальном устройстве и отправляю push notification о статусе охранной системы.6) Виджет для управления охранной системой Home Center 2
2545c46e970448d3889a46d2eaca0572.jpg
На Home Center 2 я создал виртуальное устройство, с помощью которого можно ставить на охрану в разных режимах, снимать с охраны и на который выводится статус системы и информация о том кто поставил или снял с охраны.
Чтобы поставить или снять с охраны, нужно всего лишь отправить TCP запрос с кодом постановки/снятия.
97e33af8b5544dfd87f155179fe8fbe6.png

Lua скрипт для обработки сообщений от alarmdecoder
-- Check alarm status
securityStatus = fibaro:getGlobalValue('AlarmStatus')
lastSecurityStatus = fibaro:getGlobalValue('lastSecurityStatus')

-- Show messages from alarm system
if (lastSecurityStatus ~= securityStatus) then
  fibaro:call(108, "setProperty", "ui.Label1.value", os.date("%x %X ") .. securityStatus)
  fibaro:setGlobal('lastSecurityStatus',securityStatus)
  fibaro:debug(fibaro:getValue(108, 'ui.Label1.value'))
end


-- Check alarm user and event
alarmUsers = fibaro:getGlobalValue('AlarmUsers')
lastAlarmUsers = fibaro:getGlobalValue('lastAlarmUsers')

-- If security status changed then show new status and send push
if (lastAlarmUsers ~= alarmUsers) then
  fibaro:setGlobal('lastAlarmUsers',alarmUsers)
  
  userID = string.sub(alarmUsers, 3, 3)
  event =  string.sub(alarmUsers, 5)
  
  -- set user name
  if userID == "4" then
      userID = "Raspberry"
  elseif userID == "3" then
      userID = "Жена"
  elseif userID == "2" then
      userID = "Муж"
  end
  
  -- set translated event
  if event == "ARM_AWAY" then
      event = "Поставил на охрану"
  elseif event == "ARM_STAY" then
      event = "Частично поставил на охрану"
  elseif event == "OPEN" then
      event = "Снял с охраны"
  end
  
  fibaro:call(108, "setProperty", "ui.Label2.value", event .. " " .. userID)
  fibaro:debug(fibaro:getValue(108, 'ui.Label2.value'))
  fibaro:call(100, "sendPush", fibaro:getValue(108, 'ui.Label2.value'))
  fibaro:call(25, "sendPush", fibaro:getValue(108, 'ui.Label2.value'))
end
  


Также потребовалось завести несколько глобальный переменных на Home Center 2, которые хранят текущее состояние системы и пользователей.
85681b05650241c699f9d6d1b7c13ca9.png

Всю информация, которая выводится на панель управления: снято/поставлено на охрану, сработка датчика, низкий заряд батареи датчика, переход на резервное питание и др, можно обрабатывать и отправлять в систему автоматизации для дальнейших действий.
Все устройства Home Center 2 транслируются в homebridge, что позволяет ставить на охрану и снимать с помощью голосового ассистента Siri.
Платы от alarmdecoder можно использовать с любой системой автоматизации, подробная документация и удобный API позволяют удобно и быстро интегрировать охранную систему в любой умный дом!

© Geektimes