fritz_guardian/device/C6990DF06FC6/online
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.
| $.mac | text | C6:99:0D:F0:6F:C6 | |
| $.ip | text | 192.168.178.150 | |
| $.name | text | iPhone | |
| $.interface | text | unknown | |
| $.interface_group | text | other | |
| $.active | numeric | 1 | |
| $.lease_seconds | numeric | 1123198 | |
| $.address_source | text | DHCP | |
| $.first_seen | numeric | 1777574165 | |
| $.last_seen | numeric | 1779469239 | |
| $.last_status_change | numeric | 1779469239 | |
| $.monitor_enabled | numeric | 1 | |
| $.notify_online | numeric | 1 | |
| $.notify_offline | numeric | 1 | |
| $.online_timeout | numeric | 0 | |
| $.offline_timeout | numeric | 120 | |
| $.last_online_action | numeric | 1779457641 | |
| $.last_offline_action | numeric | 1779468484 | |
| $.custom_name | text | baer-iphone | |
| $.note | text | ||
| $.details.FritzBoxActive | text | 0 | |
| $.details.ActiveSource | text | generic | |
| $.details.PresenceSource | text | arp | |
| $.details.ProbeEnabled | text | 1 | |
| $.details.ProbeMethod | text | arp | |
| $.details.ProbeOk | text | 1 | |
| $.details.ProbeMs | text | 579 | |
| $.details.ProbeResults[0].ok | bool | false | |
| $.details.ProbeResults[0].method | text | neigh-before | |
| $.details.ProbeResults[0].ms | numeric | 8 | |
| $.details.ProbeResults[0].mac | text | C6:99:0D:F0:6F:C6 | |
| $.details.ProbeResults[0].state | text | STALE | |
| $.details.ProbeResults[0].raw | text | 192.168.178.150 dev enP4p65s0 lladdr c6:99:0d:f0:6f:c6 STALE | |
| $.details.ProbeResults[1].ok | bool | true | |
| $.details.ProbeResults[1].ms | numeric | 579 | |
| $.details.ProbeResults[1].method | text | arp | |
| $.details.ProbeResults[1].mac | text | ||
| $.details.ProbeResults[2].ok | bool | true | |
| $.details.ProbeResults[2].ms | numeric | 67 | |
| $.details.ProbeResults[2].method | text | ping | |
| $.details.ProbeResults[…] | array | (4 Elemente) | |
| $.online_urls[0] | text | http://192.168.179.54/rpc/Switch.Set?id=0&on=true | |
| $.online_urls[1] | text | http://192.168.179.58/rpc/Switch.Set?id=0&on=true | |
| $.offline_urls[0] | text | http://192.168.179.54/rpc/Switch.Set?id=0&on=false | |
| $.offline_urls[1] | text | http://192.168.179.58/rpc/Switch.Set?id=0&on=false | |
| $.presence_state | text | online | |
| $.presence_label | text | online | |
| $.seconds_since_change | numeric | 16 | |
| $.offline_due_in | numeric | 0 | |
| $.display_name | text | baer-iphone | |
| $.fritz_name | text | iPhone |
2. Konfiguration
Letzter Payload
{
"mac": "C6:99:0D:F0:6F:C6",
"ip": "192.168.178.150",
"name": "iPhone",
"interface": "unknown",
"interface_group": "other",
"active": 1,
"lease_seconds": 1123198,
"address_source": "DHCP",
"first_seen": 1777574165,
"last_seen": 1779469239,
"last_status_change": 1779469239,
"monitor_enabled": 1,
"notify_online": 1,
"notify_offline": 1,
"online_timeout": 0,
"offline_timeout": 120,
"last_online_action": 1779457641,
"last_offline_action": 1779468484,
"custom_name": "baer-iphone",
"note": "",
"details": {
"FritzBoxActive": "0",
"ActiveSource": "generic",
"PresenceSource": "arp",
"ProbeEnabled": "1",
"ProbeMethod": "arp",
"ProbeOk": "1",
"ProbeMs": "579",
"ProbeResults": [
{
"ok": false,
"method": "neigh-before",
"ms": 8,
"mac": "C6:99:0D:F0:6F:C6",
"state": "STALE",
"raw": "192.168.178.150 dev enP4p65s0 lladdr c6:99:0d:f0:6f:c6 STALE"
},
{
"ok": true,
"ms": 579,
"method": "arp",
"mac": ""
},
{
"ok": true,
"ms": 67,
"method": "ping"
},
{
"ok": true,
"method": "neigh-after",
"ms": 11,
"mac": "C6:99:0D:F0:6F:C6",
"state": "REACHABLE",
"raw": "192.168.178.150 dev enP4p65s0 lladdr c6:99:0d:f0:6f:c6 REACHABLE"
}
]
},
"online_urls": [
"http://192.168.179.54/rpc/Switch.Set?id=0&on=true",
"http://192.168.179.58/rpc/Switch.Set?id=0&on=true"
],
"offline_urls": [
"http://192.168.179.54/rpc/Switch.Set?id=0&on=false",
"http://192.168.179.58/rpc/Switch.Set?id=0&on=false"
],
"presence_state": "online",
"presence_label": "online",
"seconds_since_change": 16,
"offline_due_in": 0,
"display_name": "baer-iphone",
"fritz_name": "iPhone"
}
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.