Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Tester
  4. Frigate Adapter für ioBroker

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.8k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.2k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    3.2k

Frigate Adapter für ioBroker

Geplant Angeheftet Gesperrt Verschoben Tester
370 Beiträge 45 Kommentatoren 103.1k Aufrufe 44 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • crunchipC crunchip

    @wal sagte in Test Frigate Adapter 0.2.5:

    Installiere nochmal über Github

    • hab ich jetzt auch mal
    • Links haben noch den //, funktionieren aber

    zum besagten Fehler, der blieb bzw war einmalig beim Neustart des Adapters.

    • ich hatte zwischenzeitlich in der Gui sämtliche toogle mal de/aktiviert und bin auch mal vor jede cam gelaufen, dadurch tauchten auch sämtliche Datenpunkte nun auf.

    • Ein anschließender Neustart des Adapters verursachte dann keinen Fehler mehr.

    • hab den Adapter gestoppt
    • im Objektbaum mal alle Datenpunkte gelöscht und Adapter neu gestartet
    • nur frigate.0.stats wurde angelegt, der Rest blieb aus
    • Bewegung vor der cam, erschien frigate.0.Buero.motion aber sonst wird nichts angelegt auch nach längerem warten
    • Neustart des mqtt Adapters und zack, sind alle Datenpunkte unter frigate.0 vorhanden
    • Neustart des frigate Adapters kein Fehler mehr

    Schlussfolgerung
    Timing / mqtt Adapter Problem(falsche Einstellung)?

    WalW Offline
    WalW Offline
    Wal
    Developer
    schrieb am zuletzt editiert von
    #85

    @crunchip ,
    habe eine Lösung gefunden.
    Ich fange den Fehler ab und bringe im Log eine Meldung den MQTT Broker neu zu starten.
    Kannst du das mal testen ?
    Einmal Github bitte.

    Gruß
    Walter

    DoorIO-Adapter
    wioBrowser-Adapter und wioBrowser

    crunchipC 1 Antwort Letzte Antwort
    1
    • WalW Wal

      @crunchip sagte in Test Frigate Adapter 0.2.5:

      Timing / mqtt Adapter Problem(falsche Einstellung)?

      Ja habe ich auch so jetzt festgestellt. Werden die Datenpunkte im MQTT Adapter schon erstellt ohne das der Frigate Adapter läuft, gibt es danach ein Problem.

      Ich muss beim erstellen oder starten der Frigate Instanz erst alle Datenpunkte aus dem MQTT Adapter auslesen, damit die Objekte synchron sind oder ich muss einen eigenen MQTT Server einbauen was aber wieder einen neuen Port bedeutet. Mal sehen wie ich das mache.

      crunchipC Abwesend
      crunchipC Abwesend
      crunchip
      Forum Testing Most Active
      schrieb am zuletzt editiert von crunchip
      #86

      @wal sagte in Test Frigate Adapter 0.2.5:

      Werden die Datenpunkte im MQTT Adapter schon erstellt ohne das der Frigate Adapter läuft

      ja und die waren ja bei meinem Test nach wie vor vorhanden im mqtt Adapter

      @wal sagte in Test Frigate Adapter 0.2.5:

      Ich fange den Fehler ab und bringe im Log eine Meldung den MQTT Broker neu zu starten.

      kann ich machen, also

      • frigate Adapter stoppen, Objekte löschen, von git installieren und danach starten?
      • oder soll ich mqtt auch noch mal löschen?

      umgestiegen von Proxmox auf Unraid

      WalW 1 Antwort Letzte Antwort
      1
      • crunchipC crunchip

        @wal sagte in Test Frigate Adapter 0.2.5:

        Werden die Datenpunkte im MQTT Adapter schon erstellt ohne das der Frigate Adapter läuft

        ja und die waren ja bei meinem Test nach wie vor vorhanden im mqtt Adapter

        @wal sagte in Test Frigate Adapter 0.2.5:

        Ich fange den Fehler ab und bringe im Log eine Meldung den MQTT Broker neu zu starten.

        kann ich machen, also

        • frigate Adapter stoppen, Objekte löschen, von git installieren und danach starten?
        • oder soll ich mqtt auch noch mal löschen?
        WalW Offline
        WalW Offline
        Wal
        Developer
        schrieb am zuletzt editiert von
        #87

        @crunchip ,
        nein MQTT nicht löschen.

        Gruß
        Walter

        DoorIO-Adapter
        wioBrowser-Adapter und wioBrowser

        crunchipC 1 Antwort Letzte Antwort
        0
        • WalW Wal

          @crunchip ,
          nein MQTT nicht löschen.

          crunchipC Abwesend
          crunchipC Abwesend
          crunchip
          Forum Testing Most Active
          schrieb am zuletzt editiert von
          #88

          @wal ok, sieht so aus

          figate.0
          2023-11-28 15:17:58.660	info	restart MQTT Broker please !!!
          
          frigate.0
          2023-11-28 15:17:53.487	info	restart MQTT Broker please !!!
          
          frigate.0
          2023-11-28 15:17:48.275	info	restart MQTT Broker please !!!
          
          frigate.0
          2023-11-28 15:17:40.447	info	restart MQTT Broker please !!!
          
          frigate.0
          2023-11-28 15:17:35.479	info	restart MQTT Broker please !!!
          
          frigate.0
          2023-11-28 15:17:30.442	info	restart MQTT Broker please !!!
          
          frigate.0
          2023-11-28 15:17:25.468	info	restart MQTT Broker please !!!
          
          frigate.0
          2023-11-28 15:17:20.139	info	restart MQTT Broker please !!!
          
          frigate.0
          2023-11-28 15:17:13.054	info	restart MQTT Broker please !!!
          
          frigate.0
          2023-11-28 15:17:10.229	info	restart MQTT Broker please !!!
          
          frigate.0
          2023-11-28 15:16:09.913	info	restart MQTT Broker please !!!
          
          frigate.0
          2023-11-28 15:15:39.643	info	MQTT Frigate URL: http://10.1.1.219:5000/
          
          frigate.0
          2023-11-28 15:15:39.641	info	MQTT Frigate Object: mqtt.0.frigate
          
          frigate.0
          2023-11-28 15:15:39.602	info	starting. Version 0.2.6 (non-npm: Bettman66/ioBroker.frigate#72d8fc0bd18a7463eab0c312d5778b477c3e7436) in /opt/iobroker/node_modules/iobroker.frigate, node: v18.18.2, js-controller: 5.0.16
          host.IoBroker
          2023-11-28 15:15:34.277	info	instance system.adapter.frigate.0 started with pid 606808
          host.IoBroker
          2023-11-28 15:15:33.513	info	"system.adapter.frigate.0" enabled
          

          mqtt neu gestartet

          host.IoBroker
          2023-11-28 15:20:30.179	info	instance system.adapter.mqtt.0 started with pid 608938
          host.IoBroker
          2023-11-28 15:20:27.345	info	instance system.adapter.mqtt.0 terminated with code 11 (ADAPTER_REQUESTED_TERMINATION)
          host.IoBroker
          2023-11-28 15:20:26.883	info	stopInstance system.adapter.mqtt.0 send kill signal
          host.IoBroker
          2023-11-28 15:20:26.506	info	stopInstance system.adapter.mqtt.0 (force=false, process=true)
          
          frigate.0
          2023-11-28 15:20:13.051	info	restart MQTT Broker please !!!
          
          frigate.0
          2023-11-28 15:19:12.601	info	restart MQTT Broker please !!!
          
          frigate.0
          2023-11-28 15:19:02.459	info	restart MQTT Broker please !!!
          
          frigate.0
          2023-11-28 15:18:42.688	info	restart MQTT Broker please !!!
          

          umgestiegen von Proxmox auf Unraid

          M 1 Antwort Letzte Antwort
          1
          • crunchipC crunchip

            @wal ok, sieht so aus

            figate.0
            2023-11-28 15:17:58.660	info	restart MQTT Broker please !!!
            
            frigate.0
            2023-11-28 15:17:53.487	info	restart MQTT Broker please !!!
            
            frigate.0
            2023-11-28 15:17:48.275	info	restart MQTT Broker please !!!
            
            frigate.0
            2023-11-28 15:17:40.447	info	restart MQTT Broker please !!!
            
            frigate.0
            2023-11-28 15:17:35.479	info	restart MQTT Broker please !!!
            
            frigate.0
            2023-11-28 15:17:30.442	info	restart MQTT Broker please !!!
            
            frigate.0
            2023-11-28 15:17:25.468	info	restart MQTT Broker please !!!
            
            frigate.0
            2023-11-28 15:17:20.139	info	restart MQTT Broker please !!!
            
            frigate.0
            2023-11-28 15:17:13.054	info	restart MQTT Broker please !!!
            
            frigate.0
            2023-11-28 15:17:10.229	info	restart MQTT Broker please !!!
            
            frigate.0
            2023-11-28 15:16:09.913	info	restart MQTT Broker please !!!
            
            frigate.0
            2023-11-28 15:15:39.643	info	MQTT Frigate URL: http://10.1.1.219:5000/
            
            frigate.0
            2023-11-28 15:15:39.641	info	MQTT Frigate Object: mqtt.0.frigate
            
            frigate.0
            2023-11-28 15:15:39.602	info	starting. Version 0.2.6 (non-npm: Bettman66/ioBroker.frigate#72d8fc0bd18a7463eab0c312d5778b477c3e7436) in /opt/iobroker/node_modules/iobroker.frigate, node: v18.18.2, js-controller: 5.0.16
            host.IoBroker
            2023-11-28 15:15:34.277	info	instance system.adapter.frigate.0 started with pid 606808
            host.IoBroker
            2023-11-28 15:15:33.513	info	"system.adapter.frigate.0" enabled
            

            mqtt neu gestartet

            host.IoBroker
            2023-11-28 15:20:30.179	info	instance system.adapter.mqtt.0 started with pid 608938
            host.IoBroker
            2023-11-28 15:20:27.345	info	instance system.adapter.mqtt.0 terminated with code 11 (ADAPTER_REQUESTED_TERMINATION)
            host.IoBroker
            2023-11-28 15:20:26.883	info	stopInstance system.adapter.mqtt.0 send kill signal
            host.IoBroker
            2023-11-28 15:20:26.506	info	stopInstance system.adapter.mqtt.0 (force=false, process=true)
            
            frigate.0
            2023-11-28 15:20:13.051	info	restart MQTT Broker please !!!
            
            frigate.0
            2023-11-28 15:19:12.601	info	restart MQTT Broker please !!!
            
            frigate.0
            2023-11-28 15:19:02.459	info	restart MQTT Broker please !!!
            
            frigate.0
            2023-11-28 15:18:42.688	info	restart MQTT Broker please !!!
            
            M Offline
            M Offline
            MrHenker27
            schrieb am zuletzt editiert von
            #89

            moin.

            wie kann ich mit Blockly den letzten Snapshot in in Telegramm senden? Hat da jemand mal ein Beispiel.

            Bei den Objekten ist ja im mqtt was zu finden. ( mqtt.0.frigate.Kamera_hinten.person.snapshot )
            Die Kamera variiert ja wie auch das Objekt ( Person, Bird, Cat ) .....

            Marco

            crunchipC WalW 2 Antworten Letzte Antwort
            0
            • M MrHenker27

              moin.

              wie kann ich mit Blockly den letzten Snapshot in in Telegramm senden? Hat da jemand mal ein Beispiel.

              Bei den Objekten ist ja im mqtt was zu finden. ( mqtt.0.frigate.Kamera_hinten.person.snapshot )
              Die Kamera variiert ja wie auch das Objekt ( Person, Bird, Cat ) .....

              Marco

              crunchipC Abwesend
              crunchipC Abwesend
              crunchip
              Forum Testing Most Active
              schrieb am zuletzt editiert von crunchip
              #90

              @mrhenker27 weiter oben ist ein Beispiel
              https://forum.iobroker.net/post/1065896
              oder direkt von der cam bei Ereignis
              e1c9a95d-1d2e-4723-89a1-31b0e3c5ef14-image.png

              umgestiegen von Proxmox auf Unraid

              1 Antwort Letzte Antwort
              0
              • M MrHenker27

                moin.

                wie kann ich mit Blockly den letzten Snapshot in in Telegramm senden? Hat da jemand mal ein Beispiel.

                Bei den Objekten ist ja im mqtt was zu finden. ( mqtt.0.frigate.Kamera_hinten.person.snapshot )
                Die Kamera variiert ja wie auch das Objekt ( Person, Bird, Cat ) .....

                Marco

                WalW Offline
                WalW Offline
                Wal
                Developer
                schrieb am zuletzt editiert von Wal
                #91

                @mrhenker27 ,
                hier hatte ich ein Javascript gepostet.
                Und hier der Link für die Frigate Snapshot Api.

                Gruß
                Walter

                DoorIO-Adapter
                wioBrowser-Adapter und wioBrowser

                M 1 Antwort Letzte Antwort
                0
                • WalW Wal

                  @mrhenker27 ,
                  hier hatte ich ein Javascript gepostet.
                  Und hier der Link für die Frigate Snapshot Api.

                  M Offline
                  M Offline
                  MrHenker27
                  schrieb am zuletzt editiert von
                  #92

                  @wal

                  über die API bin ich schon "gestolpert"

                  Über den Objektbaum habe ich schon mal die ID bekommen und kann dann das Bild laden.

                  http:// <IP> :5000//api/events/ <iventID> /snapshot.jpg

                  http:// <IP> :5000/api/Kamera_hinten/bird/snapshot.jpg

                  Mal sehen was ich daraus morgen basteln kann. Dachte ich könnte das Objekt selber gleich senden, was in der DB abgelegt wird, aber schein echt nur über den Weg des Zwischenspeicherns zu gehen. Mit Javascript bin ich nicht so gut befreundet g

                  M 1 Antwort Letzte Antwort
                  0
                  • M MrHenker27

                    @wal

                    über die API bin ich schon "gestolpert"

                    Über den Objektbaum habe ich schon mal die ID bekommen und kann dann das Bild laden.

                    http:// <IP> :5000//api/events/ <iventID> /snapshot.jpg

                    http:// <IP> :5000/api/Kamera_hinten/bird/snapshot.jpg

                    Mal sehen was ich daraus morgen basteln kann. Dachte ich könnte das Objekt selber gleich senden, was in der DB abgelegt wird, aber schein echt nur über den Weg des Zwischenspeicherns zu gehen. Mit Javascript bin ich nicht so gut befreundet g

                    M Offline
                    M Offline
                    MrHenker27
                    schrieb am zuletzt editiert von
                    #93

                    okay ich bin heute zu .....

                    in "mqtt.0.frigate.events" steht zwar die ID aber nicht mal die schaff ich grade zu exportieren in Blockly

                    M WalW 2 Antworten Letzte Antwort
                    0
                    • M MrHenker27

                      okay ich bin heute zu .....

                      in "mqtt.0.frigate.events" steht zwar die ID aber nicht mal die schaff ich grade zu exportieren in Blockly

                      M Offline
                      M Offline
                      martinschm
                      schrieb am zuletzt editiert von
                      #94

                      @mrhenker27

                      kommt vor, manchmal hat man so Tage.

                      Einfach diesen Block nehmen und dann dort einbauen wo du ihn brauchst.
                      148034ab-f4b9-4ecb-8175-034f934d3fe3-image.png

                      Kannst dort ein Objekt selektieren und dir den Wert ausgeben lassen und dann zB in einen Text einfügen.

                      1 Antwort Letzte Antwort
                      0
                      • M MrHenker27

                        okay ich bin heute zu .....

                        in "mqtt.0.frigate.events" steht zwar die ID aber nicht mal die schaff ich grade zu exportieren in Blockly

                        WalW Offline
                        WalW Offline
                        Wal
                        Developer
                        schrieb am zuletzt editiert von
                        #95

                        @mrhenker27 ,
                        ich habe auf Github ein Objekt "lastidurl" hinzugefügt, dort erscheint immer die Url vom letzten Event.
                        Evtl. hilft es dir.

                        Gruß
                        Walter

                        DoorIO-Adapter
                        wioBrowser-Adapter und wioBrowser

                        M 1 Antwort Letzte Antwort
                        0
                        • WalW Wal

                          @mrhenker27 ,
                          ich habe auf Github ein Objekt "lastidurl" hinzugefügt, dort erscheint immer die Url vom letzten Event.
                          Evtl. hilft es dir.

                          M Offline
                          M Offline
                          MrHenker27
                          schrieb am zuletzt editiert von
                          #96

                          @wal

                          cool. Danke, schau ich mir an. Aber das sollte den ganzen Quatsch den ich da gebastelt habe überflüssig machen.

                          Jetzt habe ich es grade SO gelöst:

                          fe9b7f74-404d-471d-aa42-16d7074f96dd-image.png

                          Das Problem ist das mein Proxmox Rechner im Garten steht samt Kameras und ich mal eben nicht so schnell den Trigger testen kann ^^

                          der fehlende Text im Erstelle text ist: wget -O /opt/iobroker/tmp.jpg "http://192.168.177.240:5000/api/events/

                          1 Antwort Letzte Antwort
                          0
                          • WalW Wal

                            @crunchip ,
                            habe eine Lösung gefunden.
                            Ich fange den Fehler ab und bringe im Log eine Meldung den MQTT Broker neu zu starten.
                            Kannst du das mal testen ?
                            Einmal Github bitte.

                            crunchipC Abwesend
                            crunchipC Abwesend
                            crunchip
                            Forum Testing Most Active
                            schrieb am zuletzt editiert von
                            #97

                            @wal mal nur bedingt mit dem Adapter zu tun.

                            Ich hab frigate auf unraid laufen, nun ist mir aufgefallen, wenn nachts das backup läuft und der Container währenddessen gestoppt wird, werden die Datenpunkte(speziell zum triggern einer Bewegung) anschiessend nicht mehr aktualisiert.
                            Ist mir erst aufgefallen nachdem kein Bild gesendet wurde, als die Post da war.

                            Ich muss dann mqtt und den Adapter neu starten, dann funktioniert es wieder, bis zum nachsten backup.

                            Variante 1, ich lass beide Instanzen nach dem backup automatisch neu starten
                            Variante 2, den container nicht zu stoppen während des backups.

                            Vllt hast du diesbezüglich ja eine Idee

                            Ps: iobroker läuft noch als VM auf nem anderen Rechner(Proxmox)

                            umgestiegen von Proxmox auf Unraid

                            WalW 1 Antwort Letzte Antwort
                            0
                            • crunchipC crunchip

                              @wal mal nur bedingt mit dem Adapter zu tun.

                              Ich hab frigate auf unraid laufen, nun ist mir aufgefallen, wenn nachts das backup läuft und der Container währenddessen gestoppt wird, werden die Datenpunkte(speziell zum triggern einer Bewegung) anschiessend nicht mehr aktualisiert.
                              Ist mir erst aufgefallen nachdem kein Bild gesendet wurde, als die Post da war.

                              Ich muss dann mqtt und den Adapter neu starten, dann funktioniert es wieder, bis zum nachsten backup.

                              Variante 1, ich lass beide Instanzen nach dem backup automatisch neu starten
                              Variante 2, den container nicht zu stoppen während des backups.

                              Vllt hast du diesbezüglich ja eine Idee

                              Ps: iobroker läuft noch als VM auf nem anderen Rechner(Proxmox)

                              WalW Offline
                              WalW Offline
                              Wal
                              Developer
                              schrieb am zuletzt editiert von
                              #98

                              @crunchip ,
                              ich mache das ja unter Proxmox auch alle 2 Tage, da läuft es danach aber wieder.
                              Machst du es wie ich mit einem Mosquitto Server und dem mqtt client Adapter ?

                              Gruß
                              Walter

                              DoorIO-Adapter
                              wioBrowser-Adapter und wioBrowser

                              crunchipC 1 Antwort Letzte Antwort
                              0
                              • WalW Wal

                                @crunchip ,
                                ich mache das ja unter Proxmox auch alle 2 Tage, da läuft es danach aber wieder.
                                Machst du es wie ich mit einem Mosquitto Server und dem mqtt client Adapter ?

                                crunchipC Abwesend
                                crunchipC Abwesend
                                crunchip
                                Forum Testing Most Active
                                schrieb am zuletzt editiert von
                                #99

                                @wal ja hab nen mqtt container auf unraid und client im iobroker laufen.

                                Muss ich mich mal demnächst näher damit beschäftigen warum nicht mehr aktualisiert wird.

                                Aktuell ist zuhause und Umgebung allerdings totaler Stromausfall, das scheint was größeres zu sein.

                                umgestiegen von Proxmox auf Unraid

                                1 Antwort Letzte Antwort
                                0
                                • D Offline
                                  D Offline
                                  dragst3r
                                  schrieb am zuletzt editiert von dragst3r
                                  #100

                                  Ich habe derzeit das Problem, dass immer wieder die Webclips oder Snapshots URLs kein Event (noevent) haben und somit verschiedene Fehler in Skripten/Adapter erzeugen. Das liegt mMn daran, das Snapshots oder Webclips pauschal im Objekt aktualisiert werden ohne eine Validierung, ob was existiert.

                                  Laut JSON von Frigate gibt es ja die Werte:
                                  "has_clip": true,
                                  "has_snapshot": true

                                  EDIT: Ich glaube die Logik war schon enthalten, funktioniert aber nicht "mehr"?
                                  const bsnap = await this.getStateAsync(beforecamera + '.snapshots.state');
                                  const bclip = await this.getStateAsync(beforecamera + '.recordings.state');

                                  Wäre es daher nicht sinnvoll, beim schreiben des jeweiligen Objektes von Clip/Snap dies vorher abzufragen?

                                  VG
                                  dragst3r

                                  EDIT2: Ich habe mich mal versucht in github direkt was zu ändern. Keine Ahnung ob das so richtig war.

                                  WalW 1 Antwort Letzte Antwort
                                  0
                                  • D dragst3r

                                    Ich habe derzeit das Problem, dass immer wieder die Webclips oder Snapshots URLs kein Event (noevent) haben und somit verschiedene Fehler in Skripten/Adapter erzeugen. Das liegt mMn daran, das Snapshots oder Webclips pauschal im Objekt aktualisiert werden ohne eine Validierung, ob was existiert.

                                    Laut JSON von Frigate gibt es ja die Werte:
                                    "has_clip": true,
                                    "has_snapshot": true

                                    EDIT: Ich glaube die Logik war schon enthalten, funktioniert aber nicht "mehr"?
                                    const bsnap = await this.getStateAsync(beforecamera + '.snapshots.state');
                                    const bclip = await this.getStateAsync(beforecamera + '.recordings.state');

                                    Wäre es daher nicht sinnvoll, beim schreiben des jeweiligen Objektes von Clip/Snap dies vorher abzufragen?

                                    VG
                                    dragst3r

                                    EDIT2: Ich habe mich mal versucht in github direkt was zu ändern. Keine Ahnung ob das so richtig war.

                                    WalW Offline
                                    WalW Offline
                                    Wal
                                    Developer
                                    schrieb am zuletzt editiert von
                                    #101

                                    @dragst3r ,
                                    schau ich mir mal zeitnah an.

                                    Gruß
                                    Walter

                                    DoorIO-Adapter
                                    wioBrowser-Adapter und wioBrowser

                                    D 1 Antwort Letzte Antwort
                                    0
                                    • WalW Wal

                                      @dragst3r ,
                                      schau ich mir mal zeitnah an.

                                      D Offline
                                      D Offline
                                      dragst3r
                                      schrieb am zuletzt editiert von
                                      #102

                                      @wal ,
                                      falls meine Änderungen in Github nicht abgeschickt worden sind, reicht schon folgendes, markiert mit // NEU bzw. anders

                                       async onEventChange(obj) {
                                              const extractedJSON = JSON.parse(obj.val);
                                              const beforecamera = extractedJSON.before.camera;
                                              const before = extractedJSON.before; // NEU 
                                              const beforelabel = extractedJSON.before.label;
                                              const afterid = extractedJSON.after.id;
                                              const topscore = extractedJSON.after.top_score;
                                              const eventtype = extractedJSON.type;
                                              const id1 = beforecamera + '.event';
                                              const id2 = beforecamera + '.objects.' + beforelabel;
                                              const websnap = weburl + '/api/events/' + afterid + '/snapshot.jpg';
                                              const webclip = weburl + '/api/events/' + afterid + '/clip.mp4';
                                      
                                      
                                              const bsnap = before.has_snapshot; // NEU bzw. anders
                                              const bclip = before.has_clip; // NEU bzw. anders
                                              if ((bsnap == null) || (bclip == null)) {
                                                  this.log.info('restart MQTT Broker please !!!');
                                                  return;
                                              }
                                              this.log.debug(`Snap: ${bsnap}`);
                                              this.log.debug(`Clip: ${bclip}`);
                                              this.log.debug(`changed: ${obj.val}`);
                                              try {
                                                  if (eventtype == 'new') {
                                                      //------------------------------
                                                      //      Bewegung erkannt
                                                      //------------------------------
                                                      this.setState('event', { val: true, ack: true });
                                                      //------------------------------
                                                      //       Kamera erkannt
                                                      //------------------------------
                                                      await this.setObjectNotExistsAsync(id1, {
                                                          type: 'state',
                                                          common: {
                                                              name: 'Camera detected',
                                                              type: 'boolean',
                                                              role: 'indicator',
                                                              read: true,
                                                              write: false,
                                                              def: false
                                                          },
                                                          native: {},
                                                      });
                                                      this.setState(id1, { val: true, ack: true });
                                                      //------------------------------
                                                      //       Objekt erkannt
                                                      //------------------------------
                                                      await this.setObjectNotExistsAsync(id2 + '.event', {
                                                          type: 'state',
                                                          common: {
                                                              name: beforelabel + ' detected',
                                                              type: 'boolean',
                                                              role: 'indicator',
                                                              read: true,
                                                              write: false,
                                                              def: false
                                                          },
                                                          native: {},
                                                      });
                                                      this.setState(id2 + '.event', { val: true, ack: true });
                                                  } else if (eventtype == 'end') {
                                                      //------------------------------
                                                      //         Event ID
                                                      //------------------------------
                                                      await this.setObjectNotExistsAsync(id2 + '.id', {
                                                          type: 'state',
                                                          common: {
                                                              name: 'Event ID',
                                                              type: 'string',
                                                              role: 'value',
                                                              read: true,
                                                              write: false,
                                                              def: 'none'
                                                          },
                                                          native: {},
                                                      });
                                                      this.setState(id2 + '.id', { val: afterid, ack: true });
                                                      //------------------------------
                                                      //         Cam + Event ID
                                                      //------------------------------
                                                      await this.setObjectNotExistsAsync(id2 + '.camid', {
                                                          type: 'state',
                                                          common: {
                                                              name: 'Cam ID',
                                                              type: 'string',
                                                              role: 'value',
                                                              read: true,
                                                              write: false,
                                                              def: 'none'
                                                          },
                                                          native: {},
                                                      });
                                                      this.setState(id2 + '.camid', { val: beforecamera + '-' + afterid, ack: true });
                                                      this.setState('lastcamid', { val: beforecamera + '-' + afterid, ack: true });
                                                      this.setState('lastidurl', { val: websnap, ack: true });
                                                      //------------------------------
                                                      //           WebURL
                                                      //------------------------------
                                                      const anz = this.config.webnum;
                                                      if (bsnap == true) { // NEU bzw. anders
                                                          for (let i = 0; i < anz; i++)
                                                              await this.setObjectNotExistsAsync(id2 + '.web.snap.snap_' + i.toString(), {
                                                                  type: 'state',
                                                                  common: {
                                                                      name: 'Snapshot WebUrl ' + i.toString(),
                                                                      type: 'string',
                                                                      role: 'value',
                                                                      read: true,
                                                                      write: false,
                                                                      def: ''
                                                                  },
                                                                  native: {},
                                                              });
                                      
                                                          for (let i = anz - 1; i > -1; i--) {
                                                              if (i == 0) {
                                                                  this.setState(id2 + '.web.snap.snap_' + i.toString(), { val: websnap, ack: true });
                                                              } else {
                                                                  const str = await this.getStateAsync(id2 + '.web.snap.snap_' + (i - 1).toString());
                                                                  if (str != null)
                                                                      this.setState(id2 + '.web.snap.snap_' + i.toString(), { val: str.val, ack: true });
                                                              }
                                                          }
                                                      }
                                                      if (bclip == true) { // NEU bzw. anders
                                                          for (let i = 0; i < anz; i++)
                                                              await this.setObjectNotExistsAsync(id2 + '.web.clip.clip_' + i.toString(), {
                                                                  type: 'state',
                                                                  common: {
                                                                      name: 'Clip WebUrl ' + i.toString(),
                                                                      type: 'string',
                                                                      role: 'value',
                                                                      read: true,
                                                                      write: false,
                                                                      def: ''
                                                                  },
                                                                  native: {},
                                                              });
                                      
                                                          for (let i = anz - 1; i > -1; i--) {
                                                              if (i == 0) {
                                                                  this.setState(id2 + '.web.clip.clip_' + i.toString(), { val: webclip, ack: true });
                                                              } else {
                                                                  const str = await this.getStateAsync(id2 + '.web.clip.clip_' + (i - 1).toString());
                                                                  if (str != null)
                                                                      this.setState(id2 + '.web.clip.clip_' + i.toString(), { val: str.val, ack: true });
                                                              }
                                                          }
                                                      }
                                                      //------------------------------
                                                      //       Erkennungsrate
                                                      //------------------------------
                                                      await this.setObjectNotExistsAsync(id2 + '.score', {
                                                          type: 'state',
                                                          common: {
                                                              type: 'number',
                                                              read: true,
                                                              write: false,
                                                              name: 'detection rate',
                                                              role: 'value.score',
                                                              unit: '%',
                                                              def: 0
                                                          },
                                                          native: {},
                                                      });
                                                      this.setState(id2 + '.score', { val: Math.round(topscore * 100), ack: true });
                                                      //------------------------------
                                                      //      Reset Event States
                                                      //------------------------------
                                                      this.setState('event', { val: false, ack: true });
                                                      this.setState(id1, { val: false, ack: true });
                                                      this.setState(id2 + '.event', { val: false, ack: true });
                                                  }
                                              } catch (error) {
                                                  this.log.error(error);
                                              }
                                          }
                                      
                                      1 Antwort Letzte Antwort
                                      1
                                      • WalW Offline
                                        WalW Offline
                                        Wal
                                        Developer
                                        schrieb am zuletzt editiert von
                                        #103

                                        Version 2.8 mit den Änderungen von @dragst3r erstellt.

                                        Gruß
                                        Walter

                                        DoorIO-Adapter
                                        wioBrowser-Adapter und wioBrowser

                                        D 1 Antwort Letzte Antwort
                                        0
                                        • WalW Wal

                                          Version 2.8 mit den Änderungen von @dragst3r erstellt.

                                          D Offline
                                          D Offline
                                          dragst3r
                                          schrieb am zuletzt editiert von
                                          #104

                                          @wal danke, bei Github heiße ich allerdings anders :-) und zwar Obsthaendler falls es wichtig ist.

                                          U 1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          895

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe