Iter 30. Ships the three ADR-122 §2.6 operator-ready Home Assistant
automation blueprints. Each blueprint binds to one BFLD MQTT entity
(presence / motion / identity_risk) and lets an HA operator import
+ configure without writing YAML by hand.
Added (under v2/crates/cog-ha-matter/blueprints/bfld/):
- presence-lighting.yaml
binary_sensor.<node>_bfld_presence ⇒ light.turn_on / turn_off
with a configurable hold_seconds delay before the off action
(ADR-122 §2.6 requirement: "configurable hold time")
- motion-hvac.yaml
sensor.<node>_bfld_motion ⇒ climate.set_temperature
Operator picks motion_threshold (default 0.3, per ADR §2.6),
delta_temperature_c (°C adjustment), and quiet_seconds debounce
- identity-risk-anomaly.yaml
sensor.<node>_bfld_identity_risk ⇒ notify.<target>
Two trigger paths:
- Absolute spike (raw score >= spike_threshold, default 0.8)
- Rolling 7-day z-score deviation (default 3 sigma)
Requires a Statistics helper entity for the baseline; documented
in the inline description and the blueprints README.
- README.md
Lists the three blueprints + privacy caveat for identity_risk
(only present at PrivacyClass::Anonymous; class 3 deployments
will fail validation by design)
Added (in v2/crates/wifi-densepose-bfld/tests/ha_blueprints.rs):
- 7 named tests using include_str! to embed each YAML at build time
and validate structure without adding a serde_yaml dep:
presence_lighting_blueprint_is_structurally_valid
motion_hvac_blueprint_is_structurally_valid
identity_risk_blueprint_is_structurally_valid
blueprints_carry_source_url_pointing_at_canonical_path
(catches path drift when files move)
presence_blueprint_uses_mqtt_integration_filter
motion_blueprint_uses_mqtt_integration_filter
identity_risk_blueprint_carries_privacy_class_caveat_in_description
(operators running class 3 should know not to install)
- Helper assert_required_blueprint_fields(yaml, name_substring, label)
enforces blueprint.{name,domain,input,trigger,action,mode} per HA spec
ACs progressed:
- ADR-122 §2.6 — all three blueprints shipped with the documented
configurable inputs (hold_seconds for #1, motion_threshold +
delta_temperature_c for #2, z_score_threshold + statistics_entity
for #3). Operator installs via HA UI; no YAML editing required.
- ADR-118 §1.5 privacy_mode visibility — identity-risk blueprint
documents the class-2-only availability so operators understand
why the blueprint fails on class-3 deployments.
Test config:
- cargo test --no-default-features → 72 passed
- cargo test → 210 passed (203 + 7)
Out of scope (next iter target):
- GitHub Actions workflow with mosquitto Docker so iters 24 + 29
e2e tests actually run in CI with BFLD_MQTT_BROKER set.
- cog-ha-matter cargo crate-internal test that loads each blueprint
via serde_yaml + validates against an HA blueprint schema (instead
of the string-only checks here). Optional; current coverage is
sufficient to catch drift in the YAML files themselves.
Co-Authored-By: claude-flow <ruv@ruv.net>
|
||
|---|---|---|
| .. | ||
| README.md | ||
| identity-risk-anomaly.yaml | ||
| motion-hvac.yaml | ||
| presence-lighting.yaml | ||
README.md
BFLD HA Blueprints
Operator-ready Home Assistant automation blueprints for the BFLD entities
published by wifi-densepose-bfld. Sourced from ADR-122 §2.6.
Installing
Copy each .yaml file into your HA blueprints/automation/ directory (or
import via the HA UI: Settings → Automations & Scenes → Blueprints → Import).
Available blueprints
| File | Purpose | BFLD entity consumed |
|---|---|---|
presence-lighting.yaml |
Turn a light on/off with BFLD occupancy | binary_sensor.<node>_bfld_presence |
motion-hvac.yaml |
Adjust HVAC setpoint when motion crosses a threshold | sensor.<node>_bfld_motion |
identity-risk-anomaly.yaml |
Notify operator on identity-risk z-score spike | sensor.<node>_bfld_identity_risk |
Privacy notes
identity-risk-anomaly.yamlrequiressensor.<node>_bfld_identity_riskwhich is only present atprivacy_class = Anonymous(per ADR-122 §2.1). Atprivacy_class = Restricted(e.g., care-home deployments) the entity is not advertised to HA at all, and this blueprint will fail validation — by design.- The
statistics_entityinput foridentity-risk-anomaly.yamlrequires the operator to first create an HA Statistics helper for the BFLD identity-risk sensor with a 7-day window. The blueprint readsmean+standard_deviationattributes.
Source-of-truth blueprint structure tests
v2/crates/wifi-densepose-bfld/tests/ha_blueprints.rs validates each YAML at build time via include_str! and asserts the presence of the required HA-blueprint fields (blueprint.name, blueprint.domain, input block, trigger, action, mode).