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. Alias Umwandlung bei JSON mit "null" bereitet Probleme

NEWS

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    9
    1
    101

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.4k

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

Alias Umwandlung bei JSON mit "null" bereitet Probleme

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
javascriptblockly
19 Beiträge 5 Kommentatoren 1.5k Aufrufe 3 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.
  • H Heinz53

    Mein ursprüngliches Problem ist mittlerweile behoben. Der Zugriff auf den ioBroker war nach Start der Admin Instanz über SSH wieder möglich.

    iobroker start admin
    

    Als Ursache für meine Probleme vermute ich den "Schlafmodus" meiner Zigbee Button beim Versuch des öffnens eines "schlafenden" alias Datenpunktes in den Objekten.
    Dies führte bei mir reproduzierbar zu Problemen der Admin Instanz.
    Nach dem Setzen des Retain bei den Problematischen Geräten traten keine Abbrüche mehr auf.

    "retain": true
    

    @FredF und @paul53 : Ich habe noch Probleme meine Zigbee Steckdose (mit JSON) zu schalten.
    Bei der Anbindung eines direkten Datenpunktes funktioniert es:

      "common": {
        "name": "Test_1",
        "desc": "Manuell erzeugt",
        "role": "state",
        "type": "boolean",
        "read": true,
        "write": true,
        "def": false,
        "alias": {
          "id": "0_userdata.0.Test.TestOnOff",
          "read": "val == 'on' ? true : false",
          "write": "val ? 'on' : 'off'"
        }
      },
    

    Bei der Steckdose habe ich noch Probleme. Ich erhalte die Fehlermeldung:
    Invalid write function for "alias.0.Steckdose.Strom28.state": "val ? JSON.stringify{'state' : 'on'} : JSON.stringify{'state' : 'off'}" => Unexpected token '{'

    Ich habe schon viele Varianten erfolglos durchprobiert.

      "common": {
        "name": "state",
        "desc": "Manuell erzeugt",
        "role": "state",
        "type": "boolean",
        "read": true,
        "write": true,
        "def": "",
        "alias": {
          "id": {
            "read": "mqtt.0.zigbee2mqtt.Strom28",
            "write": "mqtt.0.zigbee2mqtt.Strom28.set"
          },
          "read": "JSON.parse(val).state == 'on' ? true : false",
          "write": "val ? JSON.stringify{'state' : 'on'} : JSON.stringify{'state' : 'off'}"
        }
      },
    

    Wie geht es richtig?

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

    @heinz53 sagte: Wie geht es richtig?

    Es fehlenden die runden Klammern.

          "read": "JSON.parse(val).state == 'on'",
          "write": "JSON.stringify({state: val ? 'on' : 'off'})"
    

    Die Rolle sollte "switch" sein. Außerdem bietet sich an, einen eindeutigen, verständlichen Namen zu vergeben.

    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

    1 Antwort Letzte Antwort
    0
    • H Offline
      H Offline
      Heinz53
      schrieb am zuletzt editiert von
      #9

      @paul53 said in Alias Umwandlung bei JSON mit "null" bereitet Probleme:

      JSON.stringify({state: val ? 'on' : 'off'})

      @paul53 Nun erhalte ich folgende Fehlermeldung:
      Object alias.0.Steckdose.Strom28.state is invalid: Default value has to be type "boolean" but received type "string" This will throw an error up from js-controller version 7.0.0!

      Wenn die Steckdose ausgeschaltet ist wird sie über den alias eingeschaltet.
      Das Ausschalten über den alias ist nicht möglich.

        "common": {
          "name": "Steckdose_Strom28",
          "desc": "Manuell erzeugt",
          "role": "switch",
          "type": "boolean",
          "read": true,
          "write": true,
          "def": "",
          "alias": {
            "id": {
              "read": "mqtt.0.zigbee2mqtt.Strom28",
              "write": "mqtt.0.zigbee2mqtt.Strom28.set"
            },
            "read": "JSON.parse(val).state == 'on' ? true : false ",
            "write": "JSON.stringify({state: val ? 'on' : 'off'})"
          }
        },
      

      Was kann ich machen?

      paul53P 1 Antwort Letzte Antwort
      0
      • H Heinz53

        @paul53 said in Alias Umwandlung bei JSON mit "null" bereitet Probleme:

        JSON.stringify({state: val ? 'on' : 'off'})

        @paul53 Nun erhalte ich folgende Fehlermeldung:
        Object alias.0.Steckdose.Strom28.state is invalid: Default value has to be type "boolean" but received type "string" This will throw an error up from js-controller version 7.0.0!

        Wenn die Steckdose ausgeschaltet ist wird sie über den alias eingeschaltet.
        Das Ausschalten über den alias ist nicht möglich.

          "common": {
            "name": "Steckdose_Strom28",
            "desc": "Manuell erzeugt",
            "role": "switch",
            "type": "boolean",
            "read": true,
            "write": true,
            "def": "",
            "alias": {
              "id": {
                "read": "mqtt.0.zigbee2mqtt.Strom28",
                "write": "mqtt.0.zigbee2mqtt.Strom28.set"
              },
              "read": "JSON.parse(val).state == 'on' ? true : false ",
              "write": "JSON.stringify({state: val ? 'on' : 'off'})"
            }
          },
        

        Was kann ich machen?

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

        @heinz53 sagte: Was kann ich machen?

        Ändere "def":

            "def": false,
        

        @heinz53 sagte in Alias Umwandlung bei JSON mit "null" bereitet Probleme:

        Das Ausschalten über den alias ist nicht möglich.

        ?? Wie sieht der Wert von "mqtt.0.zigbee2mqtt.Strom28" bei ausgeschalteter Steckdose aus?

        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

        1 Antwort Letzte Antwort
        0
        • H Offline
          H Offline
          Heinz53
          schrieb am zuletzt editiert von
          #11

          Die mqtt Daten sind:

            "common": {
              "name": "Steckdose_Strom28",
              "desc": "Manuell erzeugt",
              "role": "switch",
              "type": "boolean",
              "read": true,
              "write": true,
              "def": false,
              "alias": {
                "id": {
                  "read": "mqtt.0.zigbee2mqtt.Strom28",
                  "write": "mqtt.0.zigbee2mqtt.Strom28.set"
                },
                "read": "JSON.parse(val).state == 'on'",
                "write": "JSON.stringify({state: val ? 'on' : 'off'})"
              }
            },
          

          Nach der Änderung von "def" erhalte ich keine Fehlermeldung mehr im log.
          Das Ausschalten ist weiterhin nicht möglich.

            "common": {
              "name": "Steckdose_Strom28",
              "desc": "Manuell erzeugt",
              "role": "switch",
              "type": "boolean",
              "read": true,
              "write": true,
              "def": false,
              "alias": {
                "id": {
                  "read": "mqtt.0.zigbee2mqtt.Strom28",
                  "write": "mqtt.0.zigbee2mqtt.Strom28.set"
                },
                "read": "JSON.parse(val).state == 'on'",
                "write": "JSON.stringify({state: val ? 'on' : 'off'})"
              }
            },
          
          1 Antwort Letzte Antwort
          0
          • H Offline
            H Offline
            Heinz53
            schrieb am zuletzt editiert von
            #12

            die mqtt Daten:
            {
            "child_lock": "UNLOCK",
            "countdown": 0,
            "current": 0,
            "energy": 0.03,
            "indicator_mode": "off/on",
            "last_seen": "2025-01-08T20:10:18+01:00",
            "linkquality": 138,
            "power": 0,
            "power_outage_memory": "restore",
            "state": "OFF",
            "update": {
            "installed_version": 80,
            "latest_version": 80,
            "state": "idle"
            },
            "update_available": false,
            "voltage": 225
            }

            paul53P 1 Antwort Letzte Antwort
            0
            • H Heinz53

              die mqtt Daten:
              {
              "child_lock": "UNLOCK",
              "countdown": 0,
              "current": 0,
              "energy": 0.03,
              "indicator_mode": "off/on",
              "last_seen": "2025-01-08T20:10:18+01:00",
              "linkquality": 138,
              "power": 0,
              "power_outage_memory": "restore",
              "state": "OFF",
              "update": {
              "installed_version": 80,
              "latest_version": 80,
              "state": "idle"
              },
              "update_available": false,
              "voltage": 225
              }

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

              @heinz53 sagte: "state": "OFF",

              ... groß geschrieben! Auch "ON"?

              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

              1 Antwort Letzte Antwort
              0
              • H Offline
                H Offline
                Heinz53
                schrieb am zuletzt editiert von
                #14

                Danke! Das war's. Nun funktioniert es.

                  "common": {
                    "name": "Steckdose_Strom28",
                    "desc": "Manuell erzeugt",
                    "role": "switch",
                    "type": "boolean",
                    "read": true,
                    "write": true,
                    "def": false,
                    "alias": {
                      "id": {
                        "read": "mqtt.0.zigbee2mqtt.Strom28",
                        "write": "mqtt.0.zigbee2mqtt.Strom28.set"
                      },
                      "read": "JSON.parse(val).state == 'ON'",
                      "write": "JSON.stringify({state: val ? 'ON' : 'OFF'})"
                    }
                  },
                

                Es funktionieren beim direkten Schalten beide Schreibweisen (Groß oder Kleinschrift)

                ... und wieder was gelernt ...
                Danke für die Unterstützung!

                C 1 Antwort Letzte Antwort
                0
                • H Heinz53

                  Danke! Das war's. Nun funktioniert es.

                    "common": {
                      "name": "Steckdose_Strom28",
                      "desc": "Manuell erzeugt",
                      "role": "switch",
                      "type": "boolean",
                      "read": true,
                      "write": true,
                      "def": false,
                      "alias": {
                        "id": {
                          "read": "mqtt.0.zigbee2mqtt.Strom28",
                          "write": "mqtt.0.zigbee2mqtt.Strom28.set"
                        },
                        "read": "JSON.parse(val).state == 'ON'",
                        "write": "JSON.stringify({state: val ? 'ON' : 'OFF'})"
                      }
                    },
                  

                  Es funktionieren beim direkten Schalten beide Schreibweisen (Groß oder Kleinschrift)

                  ... und wieder was gelernt ...
                  Danke für die Unterstützung!

                  C Offline
                  C Offline
                  c1olli
                  schrieb am zuletzt editiert von
                  #15

                  Ich habe ein wenigstens der Überschrift nach ähnliches Problem.

                  Ich bekomme die Daten aus der Victron VRM als json ins MQTT geliefert.
                  Diese wandele ich mit:

                  Math.round(JSON.parse(val).value * 10) / 10
                  

                  im Alias zu Werten um und das funktioniert auch recht gut.

                  Aber wenn die PV nichts mehr einspeist meldet der Datenpunkt :

                  {"value":null}
                  

                  Damit kommt dann der alias nicht klar und meldet folgenden Fehler:

                  Invalid read function for "alias.0.Vic-Erz": "Math.round(JSON.parse(val).value * 10) / 10" => Cannot read properties of null (reading 'value')
                  

                  Weil Null kein Wert ist.

                  So sieht der Datenpunkt dann aus:

                  {
                    "common": {
                      "name": "PV-Pow-Ges",
                      "desc": "Manuell erzeugt",
                      "role": "value",
                      "type": "number",
                      "read": true,
                      "write": true,
                      "def": 0,
                      "alias": {
                        "read": "Math.round(JSON.parse(val).value * 100) / 100",
                        "id": "mqtt.0.N.48e7da85dd79.pvinverter.22.Ac.Power"
                      },
                      "unit": "W"
                    },
                    "type": "state",
                    "native": {},
                    "_id": "alias.0.PV-Pow-Ges",
                    "acl": {
                      "object": 1636,
                      "state": 1636,
                      "owner": "system.user.admin",
                      "ownerGroup": "system.group.administrator"
                    },
                    "from": "system.adapter.admin.0",
                    "user": "system.user.admin",
                    "ts": 1736334728344
                  }
                  

                  Wie kann ich nun die Fehlermeldung verhindern?

                  Gruß
                  Olli

                  paul53P 1 Antwort Letzte Antwort
                  0
                  • mickymM Offline
                    mickymM Offline
                    mickym
                    Most Active
                    schrieb am zuletzt editiert von
                    #16

                    @c1olli sagte in Alias Umwandlung bei JSON mit "null" bereitet Probleme:

                    Math.round(JSON.parse(val).value * 10) / 10

                    Probier halt das Gleiche was vorgeschlagen wurde:

                    val ? Math.round(JSON.parse(val).value * 10) / 10 : val
                    

                    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
                    • C c1olli

                      Ich habe ein wenigstens der Überschrift nach ähnliches Problem.

                      Ich bekomme die Daten aus der Victron VRM als json ins MQTT geliefert.
                      Diese wandele ich mit:

                      Math.round(JSON.parse(val).value * 10) / 10
                      

                      im Alias zu Werten um und das funktioniert auch recht gut.

                      Aber wenn die PV nichts mehr einspeist meldet der Datenpunkt :

                      {"value":null}
                      

                      Damit kommt dann der alias nicht klar und meldet folgenden Fehler:

                      Invalid read function for "alias.0.Vic-Erz": "Math.round(JSON.parse(val).value * 10) / 10" => Cannot read properties of null (reading 'value')
                      

                      Weil Null kein Wert ist.

                      So sieht der Datenpunkt dann aus:

                      {
                        "common": {
                          "name": "PV-Pow-Ges",
                          "desc": "Manuell erzeugt",
                          "role": "value",
                          "type": "number",
                          "read": true,
                          "write": true,
                          "def": 0,
                          "alias": {
                            "read": "Math.round(JSON.parse(val).value * 100) / 100",
                            "id": "mqtt.0.N.48e7da85dd79.pvinverter.22.Ac.Power"
                          },
                          "unit": "W"
                        },
                        "type": "state",
                        "native": {},
                        "_id": "alias.0.PV-Pow-Ges",
                        "acl": {
                          "object": 1636,
                          "state": 1636,
                          "owner": "system.user.admin",
                          "ownerGroup": "system.group.administrator"
                        },
                        "from": "system.adapter.admin.0",
                        "user": "system.user.admin",
                        "ts": 1736334728344
                      }
                      

                      Wie kann ich nun die Fehlermeldung verhindern?

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

                      @c1olli sagte: {"value":null}

                      "JSON.parse(val).value ? Math.round(JSON.parse(val).value * 100) / 100 : 0",
                      

                      Das JSON wird noch so erzeugt? Es ist nicht der gesamte Wert null?

                      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

                      C 2 Antworten Letzte Antwort
                      0
                      • paul53P paul53

                        @c1olli sagte: {"value":null}

                        "JSON.parse(val).value ? Math.round(JSON.parse(val).value * 100) / 100 : 0",
                        

                        Das JSON wird noch so erzeugt? Es ist nicht der gesamte Wert null?

                        C Offline
                        C Offline
                        c1olli
                        schrieb am zuletzt editiert von c1olli
                        #18

                        @paul53
                        ich habe die Variante von @mickym und auch die von Dir probiert (2 verschiedene Werte) und beides funktioniert erst einmal.
                        Ob das mit Null funktioniert weiß ich nicht, da die PV erst heute abend auf "null" stellt.

                        Ich versuche mal beides zu simulieren.

                        Edit:
                        In der Simulation hat beides funktioniert. Ich warte also mal ab was passiert.

                        Gruß
                        Olli

                        1 Antwort Letzte Antwort
                        0
                        • paul53P paul53

                          @c1olli sagte: {"value":null}

                          "JSON.parse(val).value ? Math.round(JSON.parse(val).value * 100) / 100 : 0",
                          

                          Das JSON wird noch so erzeugt? Es ist nicht der gesamte Wert null?

                          C Offline
                          C Offline
                          c1olli
                          schrieb am zuletzt editiert von
                          #19

                          @paul53
                          @mickym

                          Ich hab die Varianten jetzt laufen lassen und die Variante von @mickym funktioniert.
                          Bei der anderen Variante kommt dann wieder "null" und die Fehlermeldung,

                          Danke für die Hilfe.

                          Gruß
                          Olli

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


                          Support us

                          ioBroker
                          Community Adapters
                          Donate

                          841

                          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