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. Skripten / Logik
  4. source does not exist for "read" function

NEWS

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    22
    1
    1.2k

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

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    14
    1
    2.5k

source does not exist for "read" function

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
52 Beiträge 4 Kommentatoren 3.8k Aufrufe 2 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.
  • mickymM mickym

    @thomas-braun In Mosquitto ist alles gut - der macht keine Konvertierung, sondern das ist ein Objekt. Dann ist es auch richtig, dass unter 0_userdata.0...Datenpunkt ein String ist, da das dann ein JSON ist. Das extrahieren der Zahl machst Du dann im Alias - aber ich würde es halt nicht im Adapter machen, sondern direkt im Alias.

    Das heißt in deinem 0_userdata.0 Datenpunkt sollte eigentlich ein JSON String stehen. Poste den mal, dann können wir uns überlegen wie die Readfunktion im Alias auszusehen hat.

    Normalerweise extrahiert man die Eigenschaft mit

    (JSON.parse(val).Eigenschaft) * 100
    
    Thomas BraunT Online
    Thomas BraunT Online
    Thomas Braun
    Most Active
    schrieb am zuletzt editiert von
    #9

    @mickym

    0_userdata.0.solix.solarbank_info.total_battery_power

    Objekt schaut wohl so aus:

    {
      "common": {
        "name": "total_battery_power",
        "type": "string",
        "role": "value",
        "read": true,
        "write": true
      },
      "native": {},
      "type": "state",
      "from": "system.adapter.javascript.0",
      "user": "system.user.admin",
      "ts": 1738344042869,
      "_id": "0_userdata.0.solix.solarbank_info.total_battery_power",
      "acl": {
        "object": 1636,
        "state": 1636,
        "owner": "system.user.admin",
        "ownerGroup": "system.group.administrator"
      }
    }
    

    Linux-Werkzeugkasten:
    https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
    NodeJS Fixer Skript:
    https://forum.iobroker.net/topic/68035/iob-node-fix-skript
    iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

    mickymM 1 Antwort Letzte Antwort
    0
    • Thomas BraunT Thomas Braun

      @mickym

      0_userdata.0.solix.solarbank_info.total_battery_power

      Objekt schaut wohl so aus:

      {
        "common": {
          "name": "total_battery_power",
          "type": "string",
          "role": "value",
          "read": true,
          "write": true
        },
        "native": {},
        "type": "state",
        "from": "system.adapter.javascript.0",
        "user": "system.user.admin",
        "ts": 1738344042869,
        "_id": "0_userdata.0.solix.solarbank_info.total_battery_power",
        "acl": {
          "object": 1636,
          "state": 1636,
          "owner": "system.user.admin",
          "ownerGroup": "system.group.administrator"
        }
      }
      
      mickymM Offline
      mickymM Offline
      mickym
      Most Active
      schrieb am zuletzt editiert von mickym
      #10

      @thomas-braun Nein das ist der Pfad oder die ID des Objektes. Geh mal bitte unter objekte und auf den Datenpunkt
      solix.solarbank_info.total_battery_power unter 0_userdata.0 und dann kopiere mal den JSON String der als Wert in dem Datenpunkt steht hier rein.

      69f2aac4-7b00-4231-b9b4-648e5b13ce6a-image.png

      Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

      Thomas BraunT 1 Antwort Letzte Antwort
      0
      • mickymM mickym

        @thomas-braun Nein das ist der Pfad oder die ID des Objektes. Geh mal bitte unter objekte und auf den Datenpunkt
        solix.solarbank_info.total_battery_power unter 0_userdata.0 und dann kopiere mal den JSON String der als Wert in dem Datenpunkt steht hier rein.

        69f2aac4-7b00-4231-b9b4-648e5b13ce6a-image.png

        Thomas BraunT Online
        Thomas BraunT Online
        Thomas Braun
        Most Active
        schrieb am zuletzt editiert von Thomas Braun
        #11

        @mickym

        Keine Ahnung was du brauchst...

        0_userdata.0.solix.solarbank_info.total_battery_power
        
        total_battery_power
        

        Da steht sonst unter value nur noch

        0.61

        drin. Und den will ich ja mit 100 multiplizieren. Das JSON wird davor noch per skript in Einzelerte zerlegt. Fällt mir gerade ein... g

        Linux-Werkzeugkasten:
        https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
        NodeJS Fixer Skript:
        https://forum.iobroker.net/topic/68035/iob-node-fix-skript
        iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

        mickymM 1 Antwort Letzte Antwort
        0
        • Thomas BraunT Thomas Braun

          @mickym

          Keine Ahnung was du brauchst...

          0_userdata.0.solix.solarbank_info.total_battery_power
          
          total_battery_power
          

          Da steht sonst unter value nur noch

          0.61

          drin. Und den will ich ja mit 100 multiplizieren. Das JSON wird davor noch per skript in Einzelerte zerlegt. Fällt mir gerade ein... g

          mickymM Offline
          mickymM Offline
          mickym
          Most Active
          schrieb am zuletzt editiert von mickym
          #12

          @thomas-braun

          Da steht sonst nur noch

          0.61

          Ah OK dann ist das aber kein JSON mehr sondern wirklich ein numerischer Wert. Dann stell doch einfach mal den Datenpunkt auf Typ Zahl um.
          Also Bleistift rechts und dann Typ ändern.

          7e59f085-599a-4ee0-bb41-e9754774ac17-image.png

          Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

          Thomas BraunT 1 Antwort Letzte Antwort
          0
          • mickymM mickym

            @thomas-braun

            Da steht sonst nur noch

            0.61

            Ah OK dann ist das aber kein JSON mehr sondern wirklich ein numerischer Wert. Dann stell doch einfach mal den Datenpunkt auf Typ Zahl um.
            Also Bleistift rechts und dann Typ ändern.

            7e59f085-599a-4ee0-bb41-e9754774ac17-image.png

            Thomas BraunT Online
            Thomas BraunT Online
            Thomas Braun
            Most Active
            schrieb am zuletzt editiert von
            #13

            @mickym sagte in source does not exist for "read" function:

            Ah OK dann ist das aber kein JSON mehr sondern wirklich ein numerischer Wert.

            Das JSON wird zuvor schon in Einzelwerte zerlegt.

            Dann stell doch einfach mal den Datenpunkt auf Typ Zahl um.

            Das funktioniert genau einmal. Die nächste Übermittlung des Wertes ist wieder ein String.

            Linux-Werkzeugkasten:
            https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
            NodeJS Fixer Skript:
            https://forum.iobroker.net/topic/68035/iob-node-fix-skript
            iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

            mickymM 1 Antwort Letzte Antwort
            0
            • Thomas BraunT Thomas Braun

              @mickym sagte in source does not exist for "read" function:

              Ah OK dann ist das aber kein JSON mehr sondern wirklich ein numerischer Wert.

              Das JSON wird zuvor schon in Einzelwerte zerlegt.

              Dann stell doch einfach mal den Datenpunkt auf Typ Zahl um.

              Das funktioniert genau einmal. Die nächste Übermittlung des Wertes ist wieder ein String.

              mickymM Offline
              mickymM Offline
              mickym
              Most Active
              schrieb am zuletzt editiert von
              #14

              @thomas-braun OK dann fallen mit noch 2 Möglichkeiten ein.

              1. Du stellst den Datentyp auf "Mixed" - würde ich präferieren
              2. Du konvertierst halt dann in der Aliasfunktion noch
              Number(val) * 100
              

              Ich schau mal ob man dem mqtt-Client noch was einstellen kann.

              Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

              Thomas BraunT 1 Antwort Letzte Antwort
              0
              • mickymM mickym

                @thomas-braun OK dann fallen mit noch 2 Möglichkeiten ein.

                1. Du stellst den Datentyp auf "Mixed" - würde ich präferieren
                2. Du konvertierst halt dann in der Aliasfunktion noch
                Number(val) * 100
                

                Ich schau mal ob man dem mqtt-Client noch was einstellen kann.

                Thomas BraunT Online
                Thomas BraunT Online
                Thomas Braun
                Most Active
                schrieb am zuletzt editiert von
                #15

                @mickym

                Ich glaube, jetzt geht es...
                Hab noch 'irgendwo irgendwas' umgestellt, jetzt erscheint auch im echarts der richtige Prozentwert.
                Mal schauen ob es einen Neustart auch übersteht...

                Linux-Werkzeugkasten:
                https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
                NodeJS Fixer Skript:
                https://forum.iobroker.net/topic/68035/iob-node-fix-skript
                iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

                mickymM 1 Antwort Letzte Antwort
                0
                • Thomas BraunT Thomas Braun

                  @mickym

                  Ich glaube, jetzt geht es...
                  Hab noch 'irgendwo irgendwas' umgestellt, jetzt erscheint auch im echarts der richtige Prozentwert.
                  Mal schauen ob es einen Neustart auch übersteht...

                  mickymM Offline
                  mickymM Offline
                  mickym
                  Most Active
                  schrieb am zuletzt editiert von
                  #16

                  @thomas-braun Welche Methode hast Du verwendet?

                  Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                  Thomas BraunT 1 Antwort Letzte Antwort
                  0
                  • Thomas BraunT Thomas Braun

                    @mickym

                    Das ist ja genau die Frage. Wo in der Kette konvertiere ich den String am besten in ein Zahlenformat. 7
                    Die Batterie schickt ein json an mosquitto, der mqtt-client holt das dann in den ioBroker rein, das ganze wird in userdata.0 geschoben und dann mit dem Alias-Adapter verwurstet.

                    Wo setze ich da an?

                    paul53P Offline
                    paul53P Offline
                    paul53
                    schrieb am zuletzt editiert von
                    #17

                    @thomas-braun sagte: Wo in der Kette konvertiere ich den String am besten in ein Zahlenformat

                    Die Multiplikation mit 100 im Alias konvertiert implizit den String in eine Zahl.
                    Die Meldung "does not exist" sieht eher danach aus, als dass es den DP "0_userdata.0.solix.solarbank_info.total_battery_power" nicht (mehr) gibt.

                    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                    Thomas BraunT HomoranH 2 Antworten Letzte Antwort
                    0
                    • mickymM mickym

                      @thomas-braun Welche Methode hast Du verwendet?

                      Thomas BraunT Online
                      Thomas BraunT Online
                      Thomas Braun
                      Most Active
                      schrieb am zuletzt editiert von
                      #18

                      @mickym

                      Ich kann es wirklich nicht sagen.
                      Planloses herumgeklicke von mir in der Admin-GUI.

                      Linux-Werkzeugkasten:
                      https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
                      NodeJS Fixer Skript:
                      https://forum.iobroker.net/topic/68035/iob-node-fix-skript
                      iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

                      mickymM 1 Antwort Letzte Antwort
                      0
                      • paul53P paul53

                        @thomas-braun sagte: Wo in der Kette konvertiere ich den String am besten in ein Zahlenformat

                        Die Multiplikation mit 100 im Alias konvertiert implizit den String in eine Zahl.
                        Die Meldung "does not exist" sieht eher danach aus, als dass es den DP "0_userdata.0.solix.solarbank_info.total_battery_power" nicht (mehr) gibt.

                        Thomas BraunT Online
                        Thomas BraunT Online
                        Thomas Braun
                        Most Active
                        schrieb am zuletzt editiert von
                        #19

                        @paul53 sagte in source does not exist for "read" function:

                        Die Meldung "does not exist" sieht eher danach aus, als dass es den DP "0_userdata.0.solix.solarbank_info.total_battery_power" nicht (mehr) gibt.

                        Doch, den gibt und gab es.

                        Linux-Werkzeugkasten:
                        https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
                        NodeJS Fixer Skript:
                        https://forum.iobroker.net/topic/68035/iob-node-fix-skript
                        iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

                        1 Antwort Letzte Antwort
                        0
                        • Thomas BraunT Thomas Braun

                          @mickym

                          Ich kann es wirklich nicht sagen.
                          Planloses herumgeklicke von mir in der Admin-GUI.

                          mickymM Offline
                          mickymM Offline
                          mickym
                          Most Active
                          schrieb am zuletzt editiert von
                          #20

                          @thomas-braun sagte in source does not exist for "read" function:

                          Planloses herumgeklicke von mir in der Admin-GUI.

                          :grinning: :joy: :rolling_on_the_floor_laughing:

                          Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                          1 Antwort Letzte Antwort
                          0
                          • paul53P paul53

                            @thomas-braun sagte: Wo in der Kette konvertiere ich den String am besten in ein Zahlenformat

                            Die Multiplikation mit 100 im Alias konvertiert implizit den String in eine Zahl.
                            Die Meldung "does not exist" sieht eher danach aus, als dass es den DP "0_userdata.0.solix.solarbank_info.total_battery_power" nicht (mehr) gibt.

                            HomoranH Nicht stören
                            HomoranH Nicht stören
                            Homoran
                            Global Moderator Administrators
                            schrieb am zuletzt editiert von Homoran
                            #21

                            @paul53 sagte in source does not exist for "read" function:

                            nicht (mehr) gibt.

                            das hatte ich etwas differenzierter interpretiert, da die Meldung noch mit 'for read' weiterging.
                            Dachte daher dass der read=false sei, was er nicht ist.

                            Möglich aber, dass es nur um den in der Lesekonvertierung angegebenen DP geht

                            kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                            Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                            der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                            Thomas BraunT 1 Antwort Letzte Antwort
                            0
                            • HomoranH Homoran

                              @paul53 sagte in source does not exist for "read" function:

                              nicht (mehr) gibt.

                              das hatte ich etwas differenzierter interpretiert, da die Meldung noch mit 'for read' weiterging.
                              Dachte daher dass der read=false sei, was er nicht ist.

                              Möglich aber, dass es nur um den in der Lesekonvertierung angegebenen DP geht

                              Thomas BraunT Online
                              Thomas BraunT Online
                              Thomas Braun
                              Most Active
                              schrieb am zuletzt editiert von
                              #22

                              Leider nix. Mein Log wird immer noch geflutet:

                              2025-02-01 15:44:53.948  - warn: javascript.0 (888) You are assigning a string to the state "0_userdata.0.solix.solarbank_info.total_battery_power" which expects a number. Please fix your code to use a number or change the state type to string. This warning might become an error in future versions.
                              2025-02-01 15:44:53.949  - warn: javascript.0 (888)     at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:2090:20)
                              2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at createObjectsRecursively (script.js.solix2mqtt:74:11)
                              2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at createObjectsRecursively (script.js.solix2mqtt:38:9)
                              2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at Object.<anonymous> (script.js.solix2mqtt:84:4)
                              2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1452:38)
                              2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:645:29)
                              2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.ts:11048:62)
                              2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at processImmediate (node:internal/timers:483:21)
                              2025-02-01 15:44:54.003  - info: javascript.0 (888) State value to set for "0_userdata.0.solix.solarbank_info.total_battery_power" has to be type "number" but received type "string" 
                              2025-02-01 15:44:54.066  - error: history.0 (857) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "val*100"
                              2025-02-01 15:44:54.066  - error: javascript.0 (888) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "val*100"
                              2025-02-01 15:45:53.952  - warn: javascript.0 (888) You are assigning a string to the state "0_userdata.0.solix.solarbank_info.total_battery_power" which expects a number. Please fix your code to use a number or change the state type to string. This warning might become an error in future versions.
                              2025-02-01 15:45:53.954  - warn: javascript.0 (888)     at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:2090:20)
                              2025-02-01 15:45:53.954  - warn: javascript.0 (888)     at createObjectsRecursively (script.js.solix2mqtt:74:11)
                              2025-02-01 15:45:53.954  - warn: javascript.0 (888)     at createObjectsRecursively (script.js.solix2mqtt:38:9)
                              2025-02-01 15:45:53.954  - warn: javascript.0 (888)     at Object.<anonymous> (script.js.solix2mqtt:84:4)
                              2025-02-01 15:45:53.955  - warn: javascript.0 (888)     at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1452:38)
                              2025-02-01 15:45:53.955  - warn: javascript.0 (888)     at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:645:29)
                              2025-02-01 15:45:53.955  - warn: javascript.0 (888)     at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.ts:11048:62)
                              2025-02-01 15:45:53.955  - warn: javascript.0 (888)     at processImmediate (node:internal/timers:483:21)
                              2025-02-01 15:45:54.007  - info: javascript.0 (888) State value to set for "0_userdata.0.solix.solarbank_info.total_battery_power" has to be type "number" but received type "string" 
                              2025-02-01 15:45:54.074  - error: history.0 (857) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "val*100"
                              2025-02-01 15:45:54.074  - error: javascript.0 (888) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "val*100"
                              
                              

                              Linux-Werkzeugkasten:
                              https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
                              NodeJS Fixer Skript:
                              https://forum.iobroker.net/topic/68035/iob-node-fix-skript
                              iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

                              mickymM HomoranH 2 Antworten Letzte Antwort
                              0
                              • Thomas BraunT Thomas Braun

                                Leider nix. Mein Log wird immer noch geflutet:

                                2025-02-01 15:44:53.948  - warn: javascript.0 (888) You are assigning a string to the state "0_userdata.0.solix.solarbank_info.total_battery_power" which expects a number. Please fix your code to use a number or change the state type to string. This warning might become an error in future versions.
                                2025-02-01 15:44:53.949  - warn: javascript.0 (888)     at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:2090:20)
                                2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at createObjectsRecursively (script.js.solix2mqtt:74:11)
                                2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at createObjectsRecursively (script.js.solix2mqtt:38:9)
                                2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at Object.<anonymous> (script.js.solix2mqtt:84:4)
                                2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1452:38)
                                2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:645:29)
                                2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.ts:11048:62)
                                2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at processImmediate (node:internal/timers:483:21)
                                2025-02-01 15:44:54.003  - info: javascript.0 (888) State value to set for "0_userdata.0.solix.solarbank_info.total_battery_power" has to be type "number" but received type "string" 
                                2025-02-01 15:44:54.066  - error: history.0 (857) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "val*100"
                                2025-02-01 15:44:54.066  - error: javascript.0 (888) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "val*100"
                                2025-02-01 15:45:53.952  - warn: javascript.0 (888) You are assigning a string to the state "0_userdata.0.solix.solarbank_info.total_battery_power" which expects a number. Please fix your code to use a number or change the state type to string. This warning might become an error in future versions.
                                2025-02-01 15:45:53.954  - warn: javascript.0 (888)     at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:2090:20)
                                2025-02-01 15:45:53.954  - warn: javascript.0 (888)     at createObjectsRecursively (script.js.solix2mqtt:74:11)
                                2025-02-01 15:45:53.954  - warn: javascript.0 (888)     at createObjectsRecursively (script.js.solix2mqtt:38:9)
                                2025-02-01 15:45:53.954  - warn: javascript.0 (888)     at Object.<anonymous> (script.js.solix2mqtt:84:4)
                                2025-02-01 15:45:53.955  - warn: javascript.0 (888)     at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1452:38)
                                2025-02-01 15:45:53.955  - warn: javascript.0 (888)     at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:645:29)
                                2025-02-01 15:45:53.955  - warn: javascript.0 (888)     at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.ts:11048:62)
                                2025-02-01 15:45:53.955  - warn: javascript.0 (888)     at processImmediate (node:internal/timers:483:21)
                                2025-02-01 15:45:54.007  - info: javascript.0 (888) State value to set for "0_userdata.0.solix.solarbank_info.total_battery_power" has to be type "number" but received type "string" 
                                2025-02-01 15:45:54.074  - error: history.0 (857) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "val*100"
                                2025-02-01 15:45:54.074  - error: javascript.0 (888) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "val*100"
                                
                                
                                mickymM Offline
                                mickymM Offline
                                mickym
                                Most Active
                                schrieb am zuletzt editiert von
                                #23

                                @thomas-braun na wenn du aber auf mixed umstellst, dann sollte der Fehler nicht mehr kommen

                                Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                1 Antwort Letzte Antwort
                                0
                                • Thomas BraunT Thomas Braun

                                  Leider nix. Mein Log wird immer noch geflutet:

                                  2025-02-01 15:44:53.948  - warn: javascript.0 (888) You are assigning a string to the state "0_userdata.0.solix.solarbank_info.total_battery_power" which expects a number. Please fix your code to use a number or change the state type to string. This warning might become an error in future versions.
                                  2025-02-01 15:44:53.949  - warn: javascript.0 (888)     at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:2090:20)
                                  2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at createObjectsRecursively (script.js.solix2mqtt:74:11)
                                  2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at createObjectsRecursively (script.js.solix2mqtt:38:9)
                                  2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at Object.<anonymous> (script.js.solix2mqtt:84:4)
                                  2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1452:38)
                                  2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:645:29)
                                  2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.ts:11048:62)
                                  2025-02-01 15:44:53.950  - warn: javascript.0 (888)     at processImmediate (node:internal/timers:483:21)
                                  2025-02-01 15:44:54.003  - info: javascript.0 (888) State value to set for "0_userdata.0.solix.solarbank_info.total_battery_power" has to be type "number" but received type "string" 
                                  2025-02-01 15:44:54.066  - error: history.0 (857) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "val*100"
                                  2025-02-01 15:44:54.066  - error: javascript.0 (888) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "val*100"
                                  2025-02-01 15:45:53.952  - warn: javascript.0 (888) You are assigning a string to the state "0_userdata.0.solix.solarbank_info.total_battery_power" which expects a number. Please fix your code to use a number or change the state type to string. This warning might become an error in future versions.
                                  2025-02-01 15:45:53.954  - warn: javascript.0 (888)     at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:2090:20)
                                  2025-02-01 15:45:53.954  - warn: javascript.0 (888)     at createObjectsRecursively (script.js.solix2mqtt:74:11)
                                  2025-02-01 15:45:53.954  - warn: javascript.0 (888)     at createObjectsRecursively (script.js.solix2mqtt:38:9)
                                  2025-02-01 15:45:53.954  - warn: javascript.0 (888)     at Object.<anonymous> (script.js.solix2mqtt:84:4)
                                  2025-02-01 15:45:53.955  - warn: javascript.0 (888)     at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1452:38)
                                  2025-02-01 15:45:53.955  - warn: javascript.0 (888)     at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:645:29)
                                  2025-02-01 15:45:53.955  - warn: javascript.0 (888)     at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.ts:11048:62)
                                  2025-02-01 15:45:53.955  - warn: javascript.0 (888)     at processImmediate (node:internal/timers:483:21)
                                  2025-02-01 15:45:54.007  - info: javascript.0 (888) State value to set for "0_userdata.0.solix.solarbank_info.total_battery_power" has to be type "number" but received type "string" 
                                  2025-02-01 15:45:54.074  - error: history.0 (857) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "val*100"
                                  2025-02-01 15:45:54.074  - error: javascript.0 (888) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "val*100"
                                  
                                  
                                  HomoranH Nicht stören
                                  HomoranH Nicht stören
                                  Homoran
                                  Global Moderator Administrators
                                  schrieb am zuletzt editiert von Homoran
                                  #24

                                  @thomas-braun sagte in source does not exist for "read" function:

                                  You are assigning a string to the state "0_userdata.0.solix.solarbank_info.total_battery_power" which expects a number

                                  woher bekommt der DP seinen Wert

                                  wie sehen denn die beiden angemeckerten alias-Konfigurationen aus?

                                  kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                                  Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                  der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                                  Thomas BraunT 1 Antwort Letzte Antwort
                                  0
                                  • HomoranH Homoran

                                    @thomas-braun sagte in source does not exist for "read" function:

                                    You are assigning a string to the state "0_userdata.0.solix.solarbank_info.total_battery_power" which expects a number

                                    woher bekommt der DP seinen Wert

                                    wie sehen denn die beiden angemeckerten alias-Konfigurationen aus?

                                    Thomas BraunT Online
                                    Thomas BraunT Online
                                    Thomas Braun
                                    Most Active
                                    schrieb am zuletzt editiert von
                                    #25

                                    @homoran sagte in source does not exist for "read" function:

                                    woher bekommt der DP seinen Wert

                                    Aus einem JSON, das zuvor aber noch über ein enstprechendes Skript läuft und dann dort in Einzelwerte zerlegt wird.

                                    Linux-Werkzeugkasten:
                                    https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
                                    NodeJS Fixer Skript:
                                    https://forum.iobroker.net/topic/68035/iob-node-fix-skript
                                    iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

                                    HomoranH mickymM 2 Antworten Letzte Antwort
                                    0
                                    • Thomas BraunT Thomas Braun

                                      @homoran sagte in source does not exist for "read" function:

                                      woher bekommt der DP seinen Wert

                                      Aus einem JSON, das zuvor aber noch über ein enstprechendes Skript läuft und dann dort in Einzelwerte zerlegt wird.

                                      HomoranH Nicht stören
                                      HomoranH Nicht stören
                                      Homoran
                                      Global Moderator Administrators
                                      schrieb am zuletzt editiert von
                                      #26

                                      @thomas-braun sagte in source does not exist for "read" function:

                                      ein enstprechendes Skript läuft und dann dort in Einzelwerte zerlegt wird.

                                      zei gen!

                                      kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                                      Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                      der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                                      Thomas BraunT 1 Antwort Letzte Antwort
                                      0
                                      • Thomas BraunT Thomas Braun

                                        @homoran sagte in source does not exist for "read" function:

                                        woher bekommt der DP seinen Wert

                                        Aus einem JSON, das zuvor aber noch über ein enstprechendes Skript läuft und dann dort in Einzelwerte zerlegt wird.

                                        mickymM Offline
                                        mickymM Offline
                                        mickym
                                        Most Active
                                        schrieb am zuletzt editiert von mickym
                                        #27

                                        @thomas-braun sagte in source does not exist for "read" function:

                                        @homoran sagte in source does not exist for "read" function:

                                        woher bekommt der DP seinen Wert

                                        Aus einem JSON, das zuvor aber noch über ein enstprechendes Skript läuft und dann dort in Einzelwerte zerlegt wird.

                                        Na dann ist es doch das Skript - und wenn Du schon mit Alias arbeitest, dann würde ich es auch nicht über Einzelwerte vorher zerlegen, sondern direkt im Alias auseinandernehmen.
                                        Von einem Skript hast Du vorher ja gar nichts gesagt.
                                        Ausser Du nimmst meinen NodeRed Flow - der zerlegt auch in die richtigen Datentypen. ;)

                                        Aber Spaß beiseite - ich würde nichts auseinander nehmen sondern das Objekt speichern und im Alias auseinandernehmen.

                                        Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                        1 Antwort Letzte Antwort
                                        0
                                        • HomoranH Homoran

                                          @thomas-braun sagte in source does not exist for "read" function:

                                          ein enstprechendes Skript läuft und dann dort in Einzelwerte zerlegt wird.

                                          zei gen!

                                          Thomas BraunT Online
                                          Thomas BraunT Online
                                          Thomas Braun
                                          Most Active
                                          schrieb am zuletzt editiert von
                                          #28

                                          Das 'Konvertier'-Skript:

                                          // where the mqtt messages arrive
                                          
                                          const mqttDatenpunktObjectId = 'mqtt.0.solix.site.Stromstausee.scenInfo';
                                          
                                          // where the states should appear
                                          
                                          const userDataFolder = '0_userdata.0.solix';
                                          
                                           
                                          
                                          // ############## end user config
                                          
                                           
                                          
                                          // receive
                                          
                                          on(mqttDatenpunktObjectId, (obj) => {
                                            // log(JSON.stringify(obj.state.val))
                                            const jsonString = obj.state.val;
                                          
                                            const jsonData = JSON.parse(jsonString);
                                          
                                           
                                          
                                            function createObjectsRecursively(parent, data) {
                                          
                                              for (const key in data) {
                                          
                                                const obj = data[key];
                                          
                                                const stateName = `${parent}.${key}`;
                                          
                                               
                                          
                                                if (typeof obj === 'object') {
                                          
                                                  createObjectsRecursively(stateName, obj);
                                          
                                                } else {
                                          
                                                 let value = obj;  
                                          
                                           
                                          
                                                  // Check if the state already exists. If it does, just update the value.
                                          
                                                  // If it does not exist create the states.
                                          
                                                  if (!existsState(stateName)) {
                                          
                                                    // If the state does not exist, create it and set the value
                                          
                                                    createState(stateName, value, {
                                          
                                                      name: key,
                                          
                                                      type: typeof value,
                                          
                                                      role: "value",
                                          
                                                      read: true,
                                          
                                                      write: true
                                          
                                                    });
                                          
                                                    log(`Created state ${stateName}`);
                                          
                                                    
                                          
                                                  } else {
                                                    // log(stateName + ': ' + value)
                                                    setState(stateName, value, true);
                                          
                                                  }
                                          
                                                }
                                          
                                              }
                                          
                                            }
                                          
                                             createObjectsRecursively(userDataFolder, jsonData);
                                          
                                          });
                                          

                                          Linux-Werkzeugkasten:
                                          https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
                                          NodeJS Fixer Skript:
                                          https://forum.iobroker.net/topic/68035/iob-node-fix-skript
                                          iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

                                          mickymM 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

                                          673

                                          Online

                                          32.5k

                                          Benutzer

                                          81.7k

                                          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