Skip to content

Node-RED nodes to Yandex Alice devices in Self-Hosting

License

Notifications You must be signed in to change notification settings

twocolors/node-red-contrib-alice-self-hosting

Repository files navigation

node-red-contrib-alice-self-hosting

platform Min Node Version GitHub version GitHub stars Package Quality

issues GitHub last commit NPM Total Downloads NPM Downloads per month Repo size

💡💬

Обсудить и общаться в душной обстановке можно тут https://t.me/alice_in_red_wonderland

Предупреждение

!!! ВНИМАНИЕ !!!

Проект в ранней альфа-стадии! Возможны существенные изменения функционала при выходе новых версий, которые всё сломают. Внимательно читайте описания к новым версиям!

Требуется помощь в написании документации.

Проект представляет набор нод (узлов) Node-RED для работы с Алисой от Яндекса без сторонних сервисов, напрямую с домашнего сервера. С требованиями можно ознакомиться здесь.

Благодарности

Это большой copy-paste из двух замечательный проектов node-red-contrib-alice и yandex2mqtt.

Спасибо им за идею и реализацию.

Принцип работы

Кроме нод для работы с Алисой, релизованных в других замечательных проектах, node-red-contrib-alice-self-hosting средствами самого Node-RED создает веб-сервер для авторизации и обработки команд.

В итоге для работы не требуется ничего кроме самого Node-RED и работоспособность не зависит ни от каких сторонных сервисов — только Яндекса и домашнего сервера, что также весьма положительно влияет на скорость работы.

Безопасность

The 'S' in IoT stands for Security

Нода должна быть спрятана за правильно настроенными сервисами типа nginx, traefik, caddy, ngrok, localtunnel, cloudflare и т.п., в противном случае любой может получить полный доступ к Node-RED. В случае, если доступ снаружи предоставлен ко всему Node-RED, необходимо добавить авторизацию.

Существуют ноды для ngrok (версия на 21.12.2023 нода банит аккаунт, ждем решения (подробнее тут issues/30) и localtunnel, которые позволяют получить доступ к установке Node-RED из интернета без проброса портов на роутере и установки дополнительного ПО. Самое простое решение — ngrok, так как помимо прочего даже в бесплатной версии позволяет автоматизировать получение TLS сертификата.

Требования

Для работы требуется несколько обязательных условий:

Белый IP-адрес

Если ваш роутер говорит что провайдер дал адрес из этого диапазона — он не белый.

Яндекс требует постоянного доступа к машине с Node-RED из внешнего интернета и сделать с этим ничего нельзя.

Постоянный IP-адрес или собственный домен

Домен может быть бесплатным и любым, например от Duck DNS или любых других сервисов.

Яндекс требует указать URL для ноды и если указать свой динамический IP, то после каждого переподключения к провайдеру потребуется заново настраивать навык Алисы.

Валидный TLS сертификат

Который настроен для использования с Node-RED или обратным прокси-сервером. Бесплатный всегда можно получить у LetsEncrypt. Яндекс не позволяет использовать самоподписанные сертификаты.

Открытый порт и маршрут

При домашнем использовании необходимо на роутере открыть порт и создать маршрут до сервера с Node-RED (Эта манипуляция известна как проброс порта).

Без этого Яндекс никак не сможет получить доступ к Node-RED.

Альтернативы

Существует несколько сервисов которые позволяют опубликовать в интернете локальное веб-приложение, но такие решения имеют существенные недостатки в увеличении времени отклика Алисы из-за того, что данные передаются через сторонний сервер (минимум плюс 30-200 мсек), а также возникает зависимость от стабильности работы выбранного сервиса.

  • Ngrok - самый популярный, это хорошее в своей простоте решение, так как снимает все вышеуказанные требования к белому IP-адресу, домену, настройке роутера и TLS-сертификата, существенно увеличивает безопасность.
  • KeenDNS - если у вас есть роутер Keenetic, но нет статического IP адреса, то сервис KeenDNS поможет вам получить удаленный доступ к вашему устройству. С его помощью вы можете легко включить поддержку DDNS прямо на вашем роутере. KeenDNS бесплатный и обеспечивает защищенное SSL соединение. Даже если ваш IP адрес не входит в «белый список», вы все равно сможете настроить KeenDNS без проблем. Пример удаленного доступа к веб-приложениям домашней сети через KeenDNS

Установка

Установка ноды

Обычная установка из палитры Node-RED. После установки перезапуск обязателен, как и после любого обновления.

Настройка доступа для Яндекса

Это самое сложное в настройке и индивидуально для каждого пользователя.

Концепция такова:

  • домен mydomain.ru резолвит адрес домашнего роутера

  • роутер настроен на т.н. пробрасывание порта (TCP) до машины с установленным Node-RED

    • настоятельнейше рекомендуется использовать обратный прокси-сервер (самый простой — Nginx Proxy Manager), при этом открыть доступ не к всему Node-RED, а только до определенного пути в нём — WebHook URL (см. ниже)

    • если используется авторизация (белые списки и т.п.), она должна быть отключена до WebHook URL, этот адрес и те, что глубже него должны быть полностью открыты. Например https://mydomain.ru/0123abcdef/webhook и все что дальше — https://mydomain.ru/0123abcdef/webhook/anything/absulutely/completely/any/url. Всё что выше: https://mydomain.ru/0123abcdef/ или https://mydomain.ru/ должно быть закрыто, это прямой доступ к админке Node-RED для любого пользователя интернета

  • Node-RED создает WebHook URL, через который и происходит общение с Алисой

  • возможно использование ngrock, localtunnel или аналогичного сервиса. Стоит отметить что указанный способ позволит избежать обязательного требования белого IP-адреса.

Использование туннеля (сторонние сервисы)

ngrok

Специально для node-red-contrib-alice-self-hosting создан ngrok flow для Node-RED. Не требует внешней установки пакетов и достаточно стабильно работает.

Требует регистрации бесплатного аккаунта в сервисе ngrok, создания постоянного домена и токена. Так как в бесплатной версии доступны только один домен и один токен, рекомендуется зарегистрировать новый аккаунт ngrok для этой ноды.

Вся настройка сводится к указанию данных в ноде (кубике) ngrok: необходимо заполнить authtoken, addr и domain


// token from ngrok https://dashboard.ngrok.com/get-started/your-authtoken
const authtoken = "YOUR_TOKEN_HERE";
// server and port ('localhost:1880' or '1880')
const addr = "1880";
// static domain https://dashboard.ngrok.com/cloud-edge/domains
const domain = "YOUR_NGROK_DOMAIN_HERE.ngrok-free.app";

После этого сделать deploy и отправить "Start tunnel". Внимание! Сразу после этого любой может получить доступ к Node-RED, поэтому стоит озаботиться настройкой авторизации заранее.

Необходимый для Яндекса Endpoint URL будет выглядеть как https://YOUR_NGROK_DOMAIN_HERE.ngrok-free.app/abcd000000/webhook (комбинация из домена ngrok и WebHook URL из настроек ноды). Так как выше мы указали порт Node-RED (1880), указывать его в Endpoint URL не требуется, ngrok пробрасывает его из 1880 в 443.

Примеры настройки reverse proxy

Примеры настройки обратного прокси-сервера. Адрес сервера Node-RED 192.168.0.2, порт 1880, домен alice.mydomain.ru указывает на внешний IP-адрес (роутера), на роутере проброшен порт 443 (https) до сервера с traefik (во всех примерах он установлен на том же сервере 192.168.0.2).

Подразумевается, что уже получен TLS сертификат для домена от letsencrypt или аналогичного сервиса (в примере используется wildcard сертификат для всех поддоменов *.example.ru, в реальных условиях и при использовании DDNS можно использовать любой домен, например ursecretdomain.duckdns.org). Почти все современные обратные прокси-серверы позволяют существенно упростить этот процесс и автоматически продлевать бесплатные сертификаты.

Traefik

В этом примере соблюдены требования безопасности — доступен только Webhook URL, Node-RED закрыт от доступа снаружи.

Настройка для Traefik в файле конфигурации
http:
  routers:
    nodered-alice:
      entrypoints:
        - websecure
      rule: Host(`alice.mydomain.ru`) && PathPrefix(`/0123abcdef/webhook`)
      service: nodered-alice
      tls: true

services:
    nodered-alice:
      loadBalancer:
        servers:
        - url: "http://192.168.0.2:1880"
Настройка для Traefik через labels в docker compose
labels:
      - "traefik.enable=true"
      - "traefik.http.routers.nodered-alice.rule=Host(`alice.mydomain.ru`) && PathPrefix(`/0123abcdef/webhook`)"
      - "traefik.http.routers.nodered-alice.entrypoints=websecure"
      - "traefik.http.routers.nodered-alice.tls.certResolver=letsencrypt"
      - "traefik.http.services.nodered-alice.loadbalancer.server.port=1880"

Nginx proxy manager

Nginx proxy manager — самый простой и дружелюбный из всех обратных прокси и не требует работы в консоли, все настройки осуществляются через веб-интерфейс.

Пример настройки

Внимание! Эти настройки не ограничивают доступ к Node-RED! Любой пользователь может получить полный доступ к панели управления по адресу https://alice.mydomain.ru.

Caddy

TBD

Получение WebHook URL

После перезапуска перетаскиваем любую ноду на сетку и в свойствах нового узла (Credentials) запоминаем адрес (WebHook URL) из примечания (вида http://192.168.0.2:1880/0123abcdef/webhook). Это тот самый адрес который должен быть доступен из интернета для Яндекса.

Для большей гибкости и в случае отсутствия reverse proxy настоятельно рекомендуется изменить порт на отличный от стандартного порта Node-RED (1880). Часть URL вида 0123abcdef генерируется случайно для каждого пользователя, её тоже можно изменить если в одной инсталяции Node-RED используется несколько аккаунтов Яндекса (например несколько "домов").

Реализация OAuth использует сервис Яндекс подробнее на Хабре

Создание OAuth

  • Здесь создаем новое приложение.

    • Для каких платформ нужно приложение — Веб-сервисы

    • Доступ к данным — что угодно, можно оставить только "Доступ к портрету пользователя"

    • Redirect URIhttps://social.yandex.net/broker/redirect

    • Почта для связи — почта для связи

  • Сохраняем ClientID и Client secret

  • Создаем Приватный диалог на Яндекс

    • Тип диалога — Умный дом

    • Название — любое

    • BackendEndpoint URL — адрес из ноды (WebHook URL)

    • Тип доступа — Приватный

    • Остальные поля со звездочкой — на свой вкус

    • В разделе Связка аккаунтов

      • Идентификатор приложения — ранее полученный ClientID

      • Секрет приложения — ранее полученный Client secret

      • URL авторизацииhttps://oauth.yandex.ru/authorize

      • URL для получения токенаhttps://oauth.yandex.ru/token

      • URL для обновления токенаhttps://oauth.yandex.ru/token

Настройки ноды

TBD

Настройка сети

Сервер с Node-RED или с reverse proxy должны быть доступны из интернета.

TBD

OpenWRT

TBD

Keenetic

Настройки — Сетевые правила — Переадресация — Правила переадресации портов — Добавить правило

Выход: Выбрать из списка устройств сервер с Node-RED или reverse proxy

Открыть порт: Порт, к которому будет открыт доступ извне, рекомендуется использовать случайный из диапазона 40000-50000, но можно использовать и стандартный 443 (https)

Порт назначения: Порт Node-RED (1880) или порт, который слушает reverse proxy

TP-Link

TBD

Использование

Создание устройства

TBD

Примеры

Примеры

on_off

toggle

range

color

mode

sensor