No description
Find a file
2026-03-23 23:21:14 -07:00
pi feat: add basic rss feat support 2026-03-23 13:56:00 -07:00
remote fix: make the badge look like badge 2026-03-23 23:21:14 -07:00
scripts fix: active poll instead of wait for interupt 2026-03-23 13:22:55 -07:00
secrets feat: add zulip integration 2026-03-23 22:18:29 -07:00
.envrc feat!: make declarative version 2026-03-22 17:40:48 -07:00
.gitignore feat!: make declarative version 2026-03-22 17:40:48 -07:00
Cargo.lock feat: add zulip integration 2026-03-23 22:18:29 -07:00
Cargo.toml feat: add zulip integration 2026-03-23 22:18:29 -07:00
flake.lock feat!: make declarative version 2026-03-22 17:40:48 -07:00
flake.nix feat: add zulip integration 2026-03-23 22:18:29 -07:00
README.md feat: add the badge to the readme 2026-03-23 23:20:49 -07:00
rustfmt.toml feat: add basic rss feat support 2026-03-23 13:56:00 -07:00

Noisebell

Space status

Monitors the door at Noisebridge and tells you whether it's open or closed.

A Raspberry Pi reads a magnetic sensor on the door and pushes state changes to a cache server. The cache keeps the latest state and fans updates out to chat integrations such as Discord and Zulip.

Pi (door sensor) ──webhook──> Cache ──webhook──> Discord / Zulip
                                |
                     polls Pi <-+

Layout

Directory What it is
pi/ Raspberry Pi OS base with laptop-built Noisebell deploy
remote/ Server-side services (cache, RSS, Discord, Zulip)
secrets/ Shared agenix-encrypted secrets and recipient rules

Each directory has its own README with setup and configuration details.

For hosted deployment, another repo such as ../extremist-software imports noisebell.nixosModules.default. That host repo provides deployment-specific values like domains, ports, and the Pi address, while the Noisebell module itself points agenix at the encrypted files in secrets/ and consumes the decrypted runtime files on the target machine.