fritz_guardian/smarthome/11630_0107632/state
1. Werte aus dem Payload auswählen
Klicke einzelne Felder an, die du als Extractor übernehmen möchtest. Mehrfachauswahl möglich. Schon konfigurierte Pfade sind grün markiert.
| $.timestamp | numeric | 1779372413 | |
| $.ain | text | 11630 0107632 | |
| $.name | text | Kompressor | |
| $.product | text | FRITZ!Smart Energy 200 | |
| $.type | text | device | |
| $.present | bool | true | |
| $.tx_busy | bool | false | |
| $.fwversion | text | 04.27 | |
| $.has.temperature | bool | true | |
| $.has.humidity | bool | false | |
| $.has.switch | bool | true | |
| $.has.powermeter | bool | true | |
| $.has.thermostat | bool | false | |
| $.has.alert | bool | false | |
| $.switch.state | bool | false | |
| $.switch.state_raw | text | 0 | |
| $.switch.mode | text | auto | |
| $.switch.lock | bool | false | |
| $.switch.device_lock | bool | false | |
| $.powermeter.voltage_v | numeric | 231.283 | |
| $.powermeter.power_w | numeric | 0.0 | |
| $.powermeter.energy_wh | numeric | 24394 | |
| $.powermeter.energy_kwh | numeric | 24.394 |
2. Konfiguration
Letzter Payload
{
"timestamp": 1779372413,
"ain": "11630 0107632",
"name": "Kompressor",
"product": "FRITZ!Smart Energy 200",
"type": "device",
"present": true,
"tx_busy": false,
"fwversion": "04.27",
"has": {
"temperature": true,
"humidity": false,
"switch": true,
"powermeter": true,
"thermostat": false,
"alert": false
},
"switch": {
"state": false,
"state_raw": "0",
"mode": "auto",
"lock": false,
"device_lock": false
},
"powermeter": {
"voltage_v": 231.283,
"power_w": 0.0,
"energy_wh": 24394,
"energy_kwh": 24.394
}
}
Test-Ergebnis
Ähnliche Topics
3. Daten-Browser
| Sub-Key | Art | Einheit | Faktor | Werte (Roh) | 15-Min | Erste | Letzte | |
|---|---|---|---|---|---|---|---|---|
| numeric | ||||||||
| text | – | – |
| Zeit | Wert |
|---|---|
Keine Daten im gewählten Zeitraum.
Letzte Roh-Nachrichten
Direkter Blick in raw_cache für dieses Topic. Klick auf eine
Zeile öffnet den vollen Payload im Viewer.
| Zeit | QoS | Status | Payload |
|---|---|---|---|
4. Wert-Labels
Optional: ordne gespeicherten Zahlen lesbare Texte zu (z.B. 161 → "Bereit").
Die Labels werden in der Daten-Tabelle & Charts angezeigt — die Speicherung selbst bleibt
rein numerisch.
| Wert | Label | |
|---|---|---|
Extractor-Schema & Tricks
Pfad-Syntax
$ · $.foo.bar · $.arr[0] · $.arr[*] (nur in iter)
value_map — Text in 0/1 (oder beliebig) umwandeln
Für Statuswerte wie "online"/"offline" oder true/false:
[
{
"path": "$.presence_state",
"sub_key": "",
"kind": "numeric",
"factor": 1,
"on_change": true,
"value_map": { "online": 1, "offline": 0 }
}
]
Lookup case-insensitive. Für Boolean-Payloads kannst du auch {"true":1,"false":0} nutzen
(direkte true/false-Werte werden ohnehin automatisch zu 1/0 gemappt).
Mehrere Topics → ein Kurzname (logisches Mergen)
Zwei oder mehr physische MQTT-Topics dürfen denselben Kurznamen haben.
Die Werte landen in values_numeric/values_text mit jeweils eigener
topic_id, aber die spätere Data-API kann sie zu einer Zeitserie vereinen
(SELECT … WHERE topic_id IN (SELECT id FROM topics WHERE short_name=…)).
Beispiel: fritz_guardian/device/<MAC>/online und .../offline beide auf
Kurzname baer_iphone_presence mit obigem value_map → eine durchgehende 0/1-Linie.
Pro-Extractor Storage-Override
[
{ "path": "$.power", "sub_key": "power",
"kind": "numeric", "factor": 100,
"storage_mode": "15min", "aggregation": "mean" },
{ "path": "$.energy_total", "sub_key": "energy_total",
"kind": "numeric", "factor": 1,
"storage_mode": "all" }
]
Power als Mittelwert pro 15-Min-Bucket, Energie als jeder geänderte Zählerstand.
Iteration über Listen
[
{ "iter": "$.devices[*]", "iter_key": "$.mac",
"path": "$.presence_state", "sub_key": "{iter_key}.status",
"kind": "numeric", "value_map":{"online":1,"offline":0},
"on_change": true }
]
Für jeden Eintrag in devices[] wird ein Sub-Key wie
C6:99:0D:F0:6F:C6.status angelegt.