npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@di-zed/yandex-smart-home

v1.6.1

Published

The Yandex Smart Home skills for the different device types.

Downloads

249

Readme

English Version | Русская Версия

Node.js (Express, TypeScript)

Yandex Smart Home

This module is specially designed to work with the Yandex.Dialogs service.

It is a bridge between the smart home service from Yandex and the MQTT server. The module can be used as main, and can also be installed as auxiliary in another project.

To work, you need to create and configure a skill in the developer console, and then link accounts, indicating correct links implemented in this module.

The essence of the module is that upon command, for example, "Alice, turn on the light", the required value is sent to the required MQTT topic, which can then be processed depending on the needs and capabilities. For example, you can have your own devices that work with MQTT, or you can run the script in a program like Node-RED, etc.

Implemented.

Installing and launching the module as the main one.

  1. Clone the project.

    git clone [email protected]:di-zed/yandex-smart-home.git
  2. SSL certificate. For this module, Yandex requires an SSL certificate. Generate it (self-signed certificates will not work) and put it in the ./volumes/etc/ssl folder.

  3. Copy the ./.env.sample file to the ./.env file. Check it and edit some parameters if necessary.

  4. Mosquitto. Copy the ./volumes/etc/mosquitto/passwd.sample file to the ./volumes/etc/mosquitto/passwd file to configure Mosquitto users.

  5. Mosquitto. The default user in the passwd file is root, password is 123456.

  6. Mosquitto. Copy the ./volumes/mosquitto/config/mosquitto.conf.sample file to the ./volumes/mosquitto/config/mosquitto.conf file to configure Mosquitto.

  7. Mosquitto. If you need to set up a secure connection, you can find examples of generating self-signed certificates at these links:

    https://manpages.ubuntu.com/manpages/bionic/man7/mosquitto-tls.7.html

    https://gist.github.com/suru-dissanaike/4344f572b14c108fc3312fc4fcc3d138

  8. Optional. If you want to add a new user to Mosquitto:

    docker-compose exec eclipse-mosquitto mosquitto_passwd -c /etc/mosquitto/passwd new_user_name
  9. Optional. If you get an error like Warning: File /etc/mosquitto/passwd has world readable permissions. Future versions will refuse to load this file. Please do:

    chmod 0700 volumes/etc/mosquitto/passwd
  10. Redis. Copy the ./volumes/usr/local/etc/redis/redis.conf.sample file to the ./volumes/usr/local/etc/redis/redis.conf file to configure Redis.

  11. Redis. Default user password - 123456. If you need to change, you need to do it in two files at the same time: .env, redis.conf.

  12. Configure devices, users and MQTT topics.

  13. Launch. The project is wrapped in Docker. To start, you need to do:

    docker-compose stop && docker-compose up -d

If the .env file contains the SERVER_TLS_KEY and SERVER_TLS_CERT parameters, then the module will try to use the SERVER_TLS_CONTAINER_PORT port, otherwise - SERVER_CONTAINER_PORT (may be needed for testing and development).

Installing and configuring the module as an auxiliary one.

  1. Installing the module in the project.
    npm install @di-zed/yandex-smart-home
  2. From the ./node_modules/@di-zed/yandex-smart-home folder, copy the following folders and files into the project:
    • config
    • .env.sample
  3. If you plan to use Docker, you can also copy:
  4. Review all the points (starting from 2) from the section Installing and launching the module as the main one. Apply as required.
  5. Before initializing the server, import and pass all the necessary parameters to the module.
    import express, { Application } from 'express';
    import yandexSmartHome from '@di-zed/yandex-smart-home';
      
    const app: Application = express();
      
    yandexSmartHome(app, {
       // ...
       configFileDevices: './config/devices.json',
       configFileUsers: './config/users.json',
       configFileMqtt: './config/mqtt.json',
       // ...
     });
    The full list of parameters can be found in the file src/interfaces/configInterface.ts .
  6. To automatically notify Yandex about changes in device parameters, be sure to use the "callbackRestUserDevicesAction" parameter from "configInterface".
    import express, { Application } from 'express';
    import yandexSmartHome from '@di-zed/yandex-smart-home';
    import yandexSkillRepository from '@di-zed/yandex-smart-home/dist/repositories/skillRepository';
       
    const app: Application = express();
       
    yandexSmartHome(app, {
       // ...
       callbackRestUserDevicesAction: yandexSkillRepository.execTempUserStateCallback.bind(yandexSkillRepository),
       // ...
     });

Authorization in the skill.

Protocol for the operation of the smart home platform.

Devices configuration.

In the root of the module, in the config folder, you need to copy the file devices.sample.json into the same folder named devices.json.

Next, describe the available devices by analogy.

On the Yandex Dialogs website you can familiarize yourself with device types, skills and properties.

Information about the user's devices will be taken from this file.

As an alternative, special hooks can be used if the module has been installed in the project, and not used as the main one.

Users configuration.

In the root of the module, in the config folder, you need to copy the file users.sample.json into the same folder named users.json.

Next, by analogy, describe the existing users.

Authorization in the skill will target users from this file.

As an alternative, special hooks can be used if the module has been installed in the project, and not used as the main one.

Configuration of MQTT topics.

In the root of the module, in the config folder, you need to copy the file mqtt.sample.json into the same folder named mqtt.json.

Next, by analogy, describe the existing topics.

The module will listen to topics described in this file.

As an alternative, special hooks can be used if the module has been installed in the project, and not used as the main one.

Яндекс Умный Дом

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

Он является мостом между сервисом умного дома от Яндекса и MQTT-сервером. Модуль может быть использован как основной, а также может быть установлен в качестве вспомогательного в другом проекте.

Для работы необходимо создать и настроить навык в консоли разработчика, а затем связать аккаунты, указав корректные ссылки, реализованные в данном модуле.

Суть модуля заключается в том, чтобы по команде, например, "Алиса, включи свет", в требуемый топик MQTT отправлялось нужное значение, которое затем может быть обработано в зависимости от потребностей и возможностей. Например, вы можете иметь свои собственные устройства, которые работают с MQTT, или же можно обработать сценарий в программе типа Node-RED и т.д.

Реализовано.

Установка и запуск модуля, как основного.

  1. Клонируйте проект.

    git clone [email protected]:di-zed/yandex-smart-home.git
  2. SSL-сертификат. Для данного модуля Яндекс требует наличие SSL-сертификата. Сгенерируйте его (самоподписанные сертификаты работать не будут) и положите в папку ./volumes/etc/ssl.

  3. Скопируйте файл ./.env.sample в файл ./.env. Проверьте его и при необходимости отредактируйте некоторые параметры.

  4. Mosquitto. Скопируйте файл ./volumes/etc/mosquitto/passwd.sample в файл ./volumes/etc/mosquitto/passwd для настройки пользователей Mosquitto.

  5. Mosquitto. Пользователь по умолчанию в файле passwdroot, пароль — 123456.

  6. Mosquitto. Скопируйте файл ./volumes/mosquitto/config/mosquitto.conf.sample в файл ./volumes/mosquitto/config/mosquitto.conf для конфигурации Mosquitto.

  7. Mosquitto. При необходимости настроить защищенное соединение, можно найти примеры генерации самоподписных сертификатов по этим ссылкам:

    https://manpages.ubuntu.com/manpages/bionic/man7/mosquitto-tls.7.html

    https://gist.github.com/suru-dissanaike/4344f572b14c108fc3312fc4fcc3d138

  8. Необязательно. Если вы хотите добавить нового пользователя в Mosquitto:

    docker-compose exec eclipse-mosquitto mosquitto_passwd -c /etc/mosquitto/passwd new_user_name
  9. Необязательно. Если у вас возникла ошибка, типа Warning: File /etc/mosquitto/passwd has world readable permissions. Future versions will refuse to load this file. Пожалуйста, выполните:

    chmod 0700 volumes/etc/mosquitto/passwd
  10. Redis. Скопируйте файл ./volumes/usr/local/etc/redis/redis.conf.sample в файл ./volumes/usr/local/etc/redis/redis.conf для конфигурации Redis.

  11. Redis. Пароль пользователя по умолчанию - 123456. Изменять нужно в двух файлах одновременно: .env, redis.conf.

  12. Сконфигурируйте устройства, пользователей и MQTT-топики.

  13. Запуск. Проект обернут в Docker. Для запуска, необходимо выполнить:

    docker-compose stop && docker-compose up -d

Если в файле .env указаны параметры SERVER_TLS_KEY и SERVER_TLS_CERT, то модуль будет пытаться использовать порт SERVER_TLS_CONTAINER_PORT, в противном случае - SERVER_CONTAINER_PORT (может понадобиться для тестирования и разработки).

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

  1. Установка модуля в проект.
    npm install @di-zed/yandex-smart-home
  2. Из папки ./node_modules/@di-zed/yandex-smart-home скопировать в проект следующие папки и файлы:
    • config
    • .env.sample
  3. Если планируете использовать Docker, так же можно скопировать:
  4. Просмотрите все пункты (начиная с 2), из секции Установка и запуск модуля, как основного. Примените, которые требуются.
  5. До инициализации сервера, подключите и передайте все необходимые параметры в модуль.
    import express, { Application } from 'express';
    import yandexSmartHome from '@di-zed/yandex-smart-home';
       
    const app: Application = express();
       
    yandexSmartHome(app, {
       // ...
       configFileDevices: './config/devices.json',
       configFileUsers: './config/users.json',
       configFileMqtt: './config/mqtt.json',
       // ...
     });
    С полным списком параметров можно ознакомиться в файле src/interfaces/configInterface.ts.
  6. Для автоматического уведомления Яндекса об изменении параметров устройств, обязательно используйте "callbackRestUserDevicesAction" параметр из "configInterface".
    import express, { Application } from 'express';
    import yandexSmartHome from '@di-zed/yandex-smart-home';
    import yandexSkillRepository from '@di-zed/yandex-smart-home/dist/repositories/skillRepository';
       
    const app: Application = express();
       
    yandexSmartHome(app, {
       // ...
       callbackRestUserDevicesAction: yandexSkillRepository.execTempUserStateCallback.bind(yandexSkillRepository),
       // ...
     });

Авторизация в навыке.

Протокол работы платформы умного дома.

  • Проверка доступности Endpoint URL провайдера: /v1.0.
  • Оповещение о разъединении аккаунтов: /v1.0/user/unlink.
  • Информация об устройствах пользователя: /v1.0/user/devices.
  • Информация о состояниях устройств пользователя: /v1.0/user/devices/query.
  • Изменение состояния у устройств: /v1.0/user/devices/action.

Конфигурация устройств.

В корне модуля, в папке config, необходимо скопировать файл devices.sample.json в ту же самую папку с именем devices.json.

Далее, по аналогии описать имеющиеся устройства.

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

Информация об устройствах пользователя будет браться из этого файла.

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

Конфигурация пользователей.

В корне модуля, в папке config, необходимо скопировать файл users.sample.json в ту же самую папку с именем users.json.

Далее, по аналогии описать имеющихся пользователей.

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

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

Конфигурация MQTT-топиков.

В корне модуля, в папке config, необходимо скопировать файл mqtt.sample.json в ту же самую папку с именем mqtt.json.

Далее, по аналогии описать имеющиеся топики.

Модуль будет слушать топики, описанные в этом файле.

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

Docker

Node (18.18.0)

  • Host: node18
  • Ports: 3000, 443
  • URL: http://localhost:3000/
docker-compose exec node18 /bin/bash

Eclipse Mosquitto (2.0.18)

  • Host: eclipse-mosquitto
  • Ports: 1883, 9001

Redis (7.4-rc1-alpine3.20)

  • Host: redis
  • Port: 6379
docker-compose exec redis redis-cli -h redis -p 6379