Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [Gelöst] Unifi Voucher

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    [Gelöst] Unifi Voucher

    This topic has been deleted. Only users with topic management privileges can see it.
    • draexler
      draexler @liv-in-sky last edited by draexler

      @liv-in-sky Wegen Chat...Komme ich gerne darauf zurück, bin nur die ganze Zeit sehr sporadisch vor dem Bildschirm.

      Ich bin jetzt auf jeden Fall einen Schritt weiter.
      Aber... Lasse ich ein einfaches Debug Log laufen sehe ich in dem Logs wunderbar das die Voucherdaten geliefert werden.
      Bildschirmfoto 2022-08-13 um 15.06.48.png
      Bildschirmfoto 2022-08-13 um 15.08.36.png
      Wobei ich mich frage sollte dann eigentlich dann nicht mehr die "0" geliefert werden solange ein Voucher existiert?

      Wenn ich jetzt aber diesen Wert mit diesen Blockly weiterverarbeiten will:
      Bildschirmfoto 2022-08-13 um 15.12.32.png
      wird in den „Rohdaten“ Datenpunkt immer nur die "0" geschrieben (sollte es tatsächlich die 0 sein, schreibt es wie gewünscht "NULL"

      Bildschirmfoto 2022-08-13 um 15.09.34.png

      liv-in-sky 1 Reply Last reply Reply Quote 0
      • liv-in-sky
        liv-in-sky @draexler last edited by

        @draexler weiß nicht, ob ich das alles richtig verstehe

        entweder stimmt die falls abfrage nicht und es kommt immer "0" zurück

        falls wert von UNIFI.Voucherueberwachung = 0 kannste mal auf = "0" - also einen string vergleichen, nicht eine zahl - evtl ist da was falsch

        draexler 1 Reply Last reply Reply Quote 1
        • draexler
          draexler @liv-in-sky last edited by

          @liv-in-sky sorry wenn es kompliziert ist.

          Also ich will das in den „Rohdaten“ Datenpunkt der Return Wert deines „Abfrage“
          scripts eingetragen wird.
          Aber mein Blockly trägt immer „0“ ein. Außer der Return Wert deines „Abfrage“
          Scripts ist „0“ dann schreibt er „NULL“ gemäß des Blocklys.

          Ich hoffe das war verständlicher 😊

          liv-in-sky 1 Reply Last reply Reply Quote 0
          • liv-in-sky
            liv-in-sky @draexler last edited by

            @draexler ich glaube, das habe ich soweit verstanden - daher die falls abfrage ändern. die function gibt immer einen string zurück, du fragst aber eine zahl in der 2ten if abfrage ab- daher meine idee, dass mal zu ändern

            draexler 1 Reply Last reply Reply Quote 1
            • draexler
              draexler @liv-in-sky last edited by

              @liv-in-sky Sicher das immer ein String zurückgeliefert wird?
              Ich habe den Datenpunkt mal auf Zahl geändert und habe nun das im Log:

              State value to set for "0_userdata.0.VIS_Datenpunkte.UNIFI.Voucherueberwachung" has to be type "string" but received type "number"
              
              liv-in-sky 1 Reply Last reply Reply Quote 0
              • liv-in-sky
                liv-in-sky @draexler last edited by

                @draexler ok - das sollte dann schon stimmen - habe ich mich geirrt

                draexler 1 Reply Last reply Reply Quote 1
                • draexler
                  draexler @liv-in-sky last edited by draexler

                  @liv-in-sky Habe jetzt mal wieder ein bisschen getestet. Aber keine Chance. Er schreibt mir immer wieder nur die "0" als Return Wert.

                  Ich habe jetzt mal unter dem Blockly ein Debug Output eingebaut:
                  Bildschirmfoto 2022-08-14 um 00.47.00.png

                  Man sieht also das das wenn der Return Wert der "Abfrage" ungleich "0" er die korrekte if Abfrage nimmt. Er schreibt aber trotzdem nur eine "0" ins Log.

                  Bildschirmfoto 2022-08-14 um 00.52.01.png

                  Lasse ich wie schon mal geschrieben vollkommen losgelöst einen Debug Output Trigger lassen schreibt er den gewünschten Wert
                  Bildschirmfoto 2022-08-14 um 00.58.15.png Bildschirmfoto 2022-08-14 um 00.57.22.png

                  Ich bin ratlos....

                  Hier nochmal das Abfrage Skript:

                    const dpPrefix = "0_userdata.0.VIS_Datenpunkte.";
                    let arrTrigger=[];
                    let count=0
                  
                   let alterWert=getState(dpPrefix+"UNIFI.Voucherueberwachung").val
                    $('unifi.0.default.vouchers.*.create_time').each(function(id, i) {
                        if(!id.includes("voucher_.create")){  
                          count++  
                  
                        let erstellt=getState(id).val
                       arrTrigger.push([new Date(erstellt).getTime(),id,getState(id.replace("create_time","code")).val])
                  
                    }
                          });
                      
                          setState(dpPrefix+"UNIFI.Voucherueberwachung",count)
                  
                  
                  arrTrigger.sort(function (alpha, beta) {
                               
                                return  beta[0]- alpha[0];
                               });
                               
                      if  (alterWert<count) {return arrTrigger[0][1]+","+arrTrigger[0][2]; } else { return "0";} 
                      alterWert=count  
                  

                  Vielleicht ist hier ja doch ein Fehler drin 😞

                  liv-in-sky 1 Reply Last reply Reply Quote 0
                  • liv-in-sky
                    liv-in-sky @draexler last edited by liv-in-sky

                    @draexler
                    du rufst die function öfter mal in einem if block auf - versuche mal eine neue variable zu erstellen und rufe dort die function auf - im if-block nutzt du dann die neue variable, anstatt immer wieder die function aufzurufen.

                    die function setzt bei einmaligen durchlaufen einen wert und merkt sich den für den nächstan aufruf - das könnte evtl das seltsame verhalten zeigen

                    hier ein beispiel:
                    Image 018.png

                    draexler 1 Reply Last reply Reply Quote 1
                    • draexler
                      draexler @liv-in-sky last edited by

                      @liv-in-sky Das war es! Super Danke dir 🙂

                      Jetzt bastel ich mal weiter.

                      liv-in-sky 1 Reply Last reply Reply Quote 0
                      • liv-in-sky
                        liv-in-sky @draexler last edited by

                        @draexler dann noch viel spaß beim "coden"

                        1 Reply Last reply Reply Quote 1
                        • First post
                          Last post

                        Support us

                        ioBroker
                        Community Adapters
                        Donate

                        941
                        Online

                        31.9k
                        Users

                        80.1k
                        Topics

                        1.3m
                        Posts

                        2
                        15
                        463
                        Loading More Posts
                        • Oldest to Newest
                        • Newest to Oldest
                        • Most Votes
                        Reply
                        • Reply as topic
                        Log in to reply
                        Community
                        Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                        The ioBroker Community 2014-2023
                        logo