1
0
Fork 0
Original URL (with bug tracking etc.): https://sr.ht/~michalr/hswro-alarm-bot/
Go to file
Michał Rudowicz 499fa82d96 Collect improvements 2025-01-07 00:10:21 +01:00
.build.yml xz -> zstd 2024-04-06 12:13:12 +02:00
.gitignore Mock time functions 2024-02-11 11:51:41 +01:00
.pre-commit-config.yaml Bump go-satel; remove throttling of messages 2024-03-05 22:30:48 +01:00
COPYING Initial commit 2024-02-08 19:23:46 +01:00
Dockerfile Add missing newline 2025-01-03 22:01:13 +01:00
README.md Omit telegram if no bot api key is provided 2025-01-03 21:47:07 +01:00
config.go Get Telegram Bot API from config instead of env 2025-01-03 20:33:36 +01:00
config_test.go Get Telegram Bot API from config instead of env 2025-01-03 20:33:36 +01:00
data_store.go Retrieve partition names from Satel 2024-03-04 22:01:35 +01:00
debug_utils.go Avoid possible race condition with waitgroups 2025-01-02 13:40:25 +01:00
filters.go Avoid possible race condition with waitgroups 2025-01-02 13:40:25 +01:00
filters_sync.go Collect improvements 2025-01-07 00:10:21 +01:00
filters_test.go Collect improvements 2025-01-07 00:10:21 +01:00
go.mod Bump go-satel (polling for alarms) 2024-03-06 19:26:05 +01:00
go.sum Bump go-satel (polling for alarms) 2024-03-06 19:26:05 +01:00
main.go Omit telegram if no bot api key is provided 2025-01-03 21:47:07 +01:00
main_test.go Get persistence file path from $STATE_DIRECTORY 2024-03-03 13:54:42 +01:00
message_contents.go (hopefully) fix not all chatIds being used 2024-03-10 21:15:51 +01:00
satel_utils.go Remove reconnection attempts, return error unless ctrl+c was sent 2024-03-30 07:21:37 +01:00
satel_utils_test.go Possibility to filter by ChangeType 2024-02-18 18:44:08 +01:00
sender_sync.go SyncFilter is now generic 2025-01-06 23:29:54 +01:00
sender_sync_test.go SyncFilter is now generic 2025-01-06 23:29:54 +01:00
sender_worker.go HTTP Request timeout to avoid issues when services are down 2025-01-03 23:39:32 +01:00
telegram_utils.go Omit telegram if no bot api key is provided 2025-01-03 21:47:07 +01:00
telegram_utils_test.go Sync senders 2025-01-06 21:38:43 +01:00
templates.go Matterbridge sender 2025-01-02 13:42:53 +01:00
templates_test.go Sync senders 2025-01-06 21:38:43 +01:00
test_utils.go Sync senders 2025-01-06 21:38:43 +01:00

README.md

Hackerspace Wroclaw Alarm Bot

builds.sr.ht status

Warning: this is a proof of concept, don't rely on it

It was very basically tested, and while it seems to work, approach it without any expectations. In other words - treat it as a toy, not as a tool that will save your life or valuables, because it probably won't.

Running

$ ./alarm-bot

Remember that hswro-alarm-bot.yml should be present in the current directory.

Configuration via YAML file

Configuration should be stored in hswro-alarm-bot.yml in current directory.

satel-addr: "192.168.13.37"
tg-chat-ids:
 - 1234
 - 5678
 - 9876
allowed-types:
 - "zone-isolate"
 - "zone-alarm"
allowed-indexes:
 - 5678
 - 1337
pool-interval: 5m
telegram-api-key: "telegram api key"
arm-callback-urls:
 - "http://192.168.1.10/hello"
 - "http://example.com/api"
disarm-callback-urls:
 - "http://192.168.1.10/bye"
 - "http://example.com/api2"
alarm-callback-urls:
 - "http://192.168.1.10/ohno"
 - "http://example.com/api3"
matterbridge:
 - uri: "http://localhost:4242/api/message"
   token: "test_token_1"
   gateway: "test_gateway_1"
   username: "test_username_1"
  • pool-interval sets how often will the Satel device be asked for changes
  • satel-addr sets the IP address of the Satel device
  • tg-chat-ids sets which telegram groups will receive notifications about alarm state changes
  • telegram-api-key sets the Bot API key for Telegram that was obtained from BotFather

Matterbridge integration

As Telegram is kinda questionable it's beneficial to get the notifications somewhere else as well. This bot can utilize Matterbridge's API to send notifications to many different chat platforms. Check the Matterbridge API documentation to learn how to configure your existing MAtterbridge installation.

Tip: You can still have independent Telegram and Matterbridge notifications - simply set up an additional gateway in Matterbridge that pushes the messages to your non-telegram chat groups but omits the Telegram group to avoid duplicated messages. Those other chat groups can be the same as those where your regular messages are bridged - Matterbridge will handle that just fine without the need for duplicated bots etc.

To configure that set the matterbridge part of the config file with the following parameters:

  • uri - URI to your Matterbridge's API
  • token - Token that you've set up for yout Matterbridge API. Situation where this token is not configured is not taken into account.
  • gateway - Set it to the same value that is set in the name parameter to your [[gateway]] in matterbridge.toml
  • username - The username from which the alarm bot messages will appear to API.

Notification via HTTP callbacks

Set the values in following parts of the config file:

  • arm-callback-urls - for an URL that will be POST when partition 0 is armed
  • disarm-callback-urls - for an URL that will be POST when partition 0 is unarmed
  • alarm-callback-urls - for an URL that will be POST when any partition alarm is activated

Filtering events by change type

It's possible to filter events by change type. Use the allowed-types part of the config file to do that. If that parameter is not provided, then all change types are allowed, otherwise only the provided ones will be used for notifications.

Supported types are:

  • zone-violation
  • zone-tamper
  • zone-alarm
  • zone-tamper-alarm
  • zone-alarm-memory
  • zone-tamper-alarm-memory
  • zone-bypass
  • zone-no-violation-trouble
  • zone-long-violation-trouble
  • armed-partition-suppressed
  • armed-partition
  • partition-armed-mode-2
  • partition-armed-mode-3
  • partition-with-1st-code-enter
  • partition-entry-time
  • partition-exit-time-over-10s
  • partition-exit-time-under-10s
  • partition-temporary-blocked
  • partition-blocked-guard-round
  • partition-alarm
  • partition-fire-alarm
  • partition-alarm-memory
  • partition-fire-alarm-memory
  • output
  • doors-opened
  • doors-opened-long
  • status-bit
  • trouble-part-1
  • trouble-part-2
  • trouble-part-3
  • trouble-part-4
  • trouble-part-5
  • trouble-memory-part-1
  • trouble-memory-part-2
  • trouble-memory-part-3
  • trouble-memory-part-4
  • trouble-memory-part-5
  • partition-with-violated-zones
  • zone-isolate

Filtering events by index (which meaning depends on the change type)

Use the allowed-indexes part of config file to set the list of allowed indexes. If that parameter is not provided, then all indexes are allowed; otherwise the notification is sent only for provided indexes.

example systemd unit

[Unit]
Description=Satel Alarm Telegram Status Notifier
Requires=network.target
After=network.target

[Service]
Type=simple
ExecStart=/path/to/alarm_bot
DynamicUser=True
RuntimeDirectory=hswro-alarm-bot
StateDirectory=hswro-alarm-bot
RestartSec=30
Restart=on-failure

CPUAccounting=true
CPUQuota=5%
MemoryAccounting=true
MemoryHigh=25M
MemoryMax=50M

[Install]
WantedBy=multi-user.target