diff --git a/technology/applications/web/zigbee2mqtt.md b/technology/applications/web/zigbee2mqtt.md index 6f00e09..bc98d0b 100644 --- a/technology/applications/web/zigbee2mqtt.md +++ b/technology/applications/web/zigbee2mqtt.md @@ -5,4 +5,108 @@ website: https://www.zigbee2mqtt.io --- # zigbee2mqtt -#wip #🐇 #notnow \ No newline at end of file +Zigbee to [MQTT](../../internet/MQTT.md) bridge, get rid of your proprietary Zigbee bridges. +See [this](https://www.zigbee2mqtt.io/supported-devices/) for a list of supported devices. + +![Screenshot][Screenshot] + +## Setup +In order to run zigbee2mqtt you need a [MQTT](../../internet/MQTT.md) server and a zigbee adapter for talking to the zigbee devices. + +## Configuration +zigbee2mqtt is configured with `configuration.yml` + +Adapter configuration: +```yml +# Required: serial settings +serial: + # Required: location of the adapter (e.g. CC2531). + # USB adapters - use format "port: /dev/ttyACM0" + # To autodetect the USB port, set 'port: null'. + # Ethernet adapters - use format "port: tcp://192.168.1.12:6638" + port: /dev/ttyACM0 + # Optional: disable LED of the adapter if supported (default: false) + disable_led: false + # Optional: adapter type, not needed unless you are experiencing problems (default: shown below, options: zstack, deconz, ezsp) + adapter: null + # Optional: Baud rate speed for serial port, this can be anything firmware support but default is 115200 for Z-Stack and EZSP, 38400 for Deconz, however note that some EZSP firmware need 57600. + baudrate: 115200 + # Optional: RTS / CTS Hardware Flow Control for serial port (default: false) + rtscts: false +``` + +MQTT: +```yml +# Required: MQTT settings +mqtt: + # Required: MQTT server URL (use mqtts:// for SSL/TLS connection) + server: 'mqtt://localhost:1883' + # Optional: MQTT base topic for Zigbee2MQTT MQTT messages (default: zigbee2mqtt) + base_topic: zigbee2mqtt + # Optional: absolute path to SSL/TLS certificate of CA used to sign server and client certificates (default: nothing) + ca: '/etc/ssl/mqtt-ca.crt' + # Optional: absolute paths to SSL/TLS key and certificate for client-authentication (default: nothing) + key: '/etc/ssl/mqtt-client.key' + cert: '/etc/ssl/mqtt-client.crt' + # Optional: MQTT server authentication user (default: nothing) + user: my_user + # Optional: MQTT server authentication password (default: nothing) + password: my_password + # Optional: MQTT client ID (default: nothing) + client_id: 'MY_CLIENT_ID' + # Optional: disable self-signed SSL certificates (default: true) + reject_unauthorized: true + # Optional: Include device information to mqtt messages (default: false) + include_device_information: true + # Optional: MQTT keepalive in seconds (default: 60) + keepalive: 60 + # Optional: MQTT protocol version (default: 4), set this to 5 if you + # use the 'retention' device specific configuration + version: 4 + # Optional: Disable retain for all send messages. ONLY enable if you MQTT broker doesn't + # support retained message (e.g. AWS IoT core, Azure IoT Hub, Google Cloud IoT core, IBM Watson IoT Platform). + # Enabling will break the Home Assistant integration. (default: false) + force_disable_retain: false +``` + +Frontend: +```yml +frontend: + # Optional, default 8080 + port: 8080 + # Optional, empty by default to listen on both IPv4 and IPv6. Opens a unix socket when given a path instead of an address (e.g. '/run/zigbee2mqtt/zigbee2mqtt.sock') + host: 0.0.0.0 + # Optional, enables authentication, disabled by default + auth_token: your-secret-token + # Optional, url on which the frontend can be reached, currently only used for the Home Assistant device configuration page + url: 'https://zigbee2mqtt.myhouse.org' + # Optional, certificate file path for exposing HTTPS. The sibling property 'ssl_key' must be set for HTTPS to be activated + ssl_cert: /config/etc/letsencrypt/live/mydomain.com/fullchain.pem + # Optional, private key file path for exposing HTTPS. The sibling property 'ssl_cert' must be set for HTTPS to be activated + ssl_key: /config/etc/letsencrypt/live/mydomain.com/privkey.pem +``` + +To enable integration with [Home Assistant](Home%20Assistant.md), add this to config: +```yml +homeassistant: true +``` + +## Docker Compose +```yml +version: '3' +services: + zigbee2mqtt: + restart: unless-stopped + image: koenkk/zigbee2mqtt + volumes: + - ./zigbee2mqtt-data:/app/data + - /run/udev:/run/udev:ro + ports: + - 8080:8080 + environment: + - TZ=Europe/Berlin + devices: + - /dev/ttyUSB0:/dev/ttyUSB0 +``` + +[Screenshot]:  \ No newline at end of file diff --git a/technology/bsd/OpenBSD.md b/technology/bsd/OpenBSD.md index 1ea1ebd..e7f3c44 100644 --- a/technology/bsd/OpenBSD.md +++ b/technology/bsd/OpenBSD.md @@ -1,7 +1,7 @@ --- obj: os -website: https://www.openbsd.org/ +website: https://www.openbsd.org --- #refactor #notnow # OpenBSD -The OpenBSD project produces a FREE, multi-platform 4.4BSD-based UNIX-like operating system. Our efforts emphasize portability, standardization, correctness, proactive security and integrated cryptography. As an example of the effect OpenBSD has, the popular [OpenSSH](../applications/SSH.md) software comes from OpenBSD. \ No newline at end of file +The OpenBSD project produces a free, multi-platform BSD-based UNIX-like operating system. Our efforts emphasize portability, standardization, correctness, proactive security and integrated cryptography. As an example of the effect OpenBSD has, the popular [OpenSSH](../applications/SSH.md) software comes from OpenBSD. \ No newline at end of file diff --git a/technology/internet/MQTT.md b/technology/internet/MQTT.md index bc24549..8e2bcb9 100644 --- a/technology/internet/MQTT.md +++ b/technology/internet/MQTT.md @@ -34,7 +34,7 @@ Each message is inside a topic allowing for organizing them. ### 1. **IoT (Internet of Things):** - MQTT is widely used in IoT scenarios for efficient communication between devices. ### 2. **Home Automation:** -- Smart homes leverage MQTT for controlling and monitoring devices. For example zigbee2mqtt with [Home Assistant](../applications/web/Home%20Assistant.md). +- Smart homes leverage MQTT for controlling and monitoring devices. For example [zigbee2mqtt](../applications/web/zigbee2mqtt.md) with [Home Assistant](../applications/web/Home%20Assistant.md). ### 3. **Messaging in Remote Locations:** - Suitable for scenarios with low bandwidth, high latency, or unreliable connections. diff --git a/technology/linux/filesystems/Filesystems.md b/technology/linux/filesystems/Filesystems.md index ffdb458..9abd830 100644 --- a/technology/linux/filesystems/Filesystems.md +++ b/technology/linux/filesystems/Filesystems.md @@ -3,6 +3,7 @@ arch-wiki: https://wiki.archlinux.org/title/File_systems tags: ["meta"] obj: meta/collection --- + ## Filesystems - [ZFS](ZFS.md) - [Btrfs](Btrfs.md) @@ -10,4 +11,5 @@ obj: meta/collection - [SquashFS](SquashFS.md) - [MergerFS](MergerFS.md) - [exFAT](exFAT.md) -- [SSHFS](SSHFS.md) \ No newline at end of file +- [SSHFS](SSHFS.md) +- [XFS](XFS.md) \ No newline at end of file diff --git a/technology/linux/filesystems/XFS.md b/technology/linux/filesystems/XFS.md new file mode 100644 index 0000000..95adaf6 --- /dev/null +++ b/technology/linux/filesystems/XFS.md @@ -0,0 +1,29 @@ +--- +obj: filesystem +wiki: https://en.wikipedia.org/wiki/XFS +--- + +# XFS +XFS is a high-performance, scalable file system designed for Unix-like operating systems. It was originally developed by Silicon Graphics, Inc. (SGI) and later open-sourced. XFS is known for its robustness, advanced features, and suitability for large-scale storage environments. + +## File System Creation and Management + +Creating an XFS file system can be done using the mkfs.xfs command: +```shell +mkfs.xfs /dev/sdX +``` + +To mount an XFS file system, use the mount command: +```shell +mount -t xfs /dev/sdX /mnt/point +``` + +Grow the filesystem: +```shell +xfs_growfs /mnt +``` + +Get information on filesystem: +```shell +xfs_info /mnt +```