A simple app to expose all events generated by an Amcrest device to MQTT using the
python-amcrest
library.
It supports the following environment variables:
AMCREST_HOST
(required)AMCREST_PORT
(optional, default = 80)AMCREST_USERNAME
(optional, default = admin)AMCREST_PASSWORD
(required)MQTT_USERNAME
(required, unless using TLS client authentication)MQTT_PASSWORD
(optional, default = empty password)MQTT_HOST
(optional, default = 'localhost')MQTT_QOS
(optional, default = 0)MQTT_PORT
(optional, default = 1883)MQTT_TLS_ENABLED
(optional, default = false) - set totrue
to enable TLS server authenticationMQTT_TLS_INSECURE
(optional, default = false) - disables TLS certificate verification - use with caution! Consider usingMQTT_TLS_CA_CERT
instead.MQTT_TLS_CA_CERT
(required if using TLS, unlessMQTT_TLS_INSECURE
is set) - path to the trusted CA certificate fileMQTT_TLS_CERT
(required if using TLS client authentication) - path to the client's certificate fileMQTT_TLS_KEY
(required if using TLS client authentication) - path to the client's private key fileHOME_ASSISTANT
(optional, default = false)HOME_ASSISTANT_PREFIX
(optional, default = 'homeassistant')STORAGE_POLL_INTERVAL
(optional, default = 3600) - how often to fetch storage data (in seconds) (set to 0 to disable functionality)DEVICE_NAME
(optional) - override the default device name used in the Amcrest app
It exposes events to the following topics:
amcrest2mqtt/[SERIAL_NUMBER]/event
- all eventsamcrest2mqtt/[SERIAL_NUMBER]/doorbell
- doorbell status (if AD110 or AD410)amcrest2mqtt/[SERIAL_NUMBER]/human
- human detection (if AD410)amcrest2mqtt/[SERIAL_NUMBER]/motion
- motion events (if supported)amcrest2mqtt/[SERIAL_NUMBER]/config
- device configuration information
The app supports events for any Amcrest device supported by python-amcrest
.
The app has built-in support for Home Assistant discovery. Set the HOME_ASSISTANT
environment variable to true
to enable support.
If you are using a different MQTT prefix to the default, you will need to set the HOME_ASSISTANT_PREFIX
environment variable.
The easiest way to run the app is via Docker Compose, e.g.
version: "3"
services:
amcrest2mqtt:
container_name: amcrest2mqtt
image: ghcr.io/danclough/amcrest2mqtt:latest
restart: unless-stopped
environment:
AMCREST_HOST: 192.168.0.1
AMCREST_PASSWORD: password
MQTT_HOST: 192.168.0.2
MQTT_USERNAME: admin
MQTT_PASSWORD: password
HOME_ASSISTANT: "true"
The app will not support multiple devices. You can run multiple instances of the app if you need to expose events for multiple devices.
Docker is the only supported way of deploying the application. The app should run directly via Python but this is not supported.