Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. [Vorlage] Alias per Skript erzeugen

    NEWS

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    [Vorlage] Alias per Skript erzeugen

    This topic has been deleted. Only users with topic management privileges can see it.
    • paul53
      paul53 @Segway last edited by

      @Segway sagte:

      Datenpunkt true / false --> type = string

      Du meinst: "true" / "false"; type: "string" ?

      @Segway sagte in [Vorlage] Alias per Skript erzeugen:

      Alias erzeugen der bei true dann 1 liefert und bei false 0

      Weshalb binäre Werte ? In ioBroker / Javascript sollte man man mit booleschen Werten arbeiten.

      Segway 1 Reply Last reply Reply Quote 0
      • Segway
        Segway @paul53 last edited by Segway

        @paul53

        War nur eine schreibweise um mein "Problem" zu schildern.

        Warum ich 0 und 1 brauche ? Nunja, wie in meinem anderen aktuellen Thread zu erkennen, kann ich in Grafana leider den Zustand nicht mit true / false abbilden sondern brauche eine 0 und 1 (STAT-Panel in Grafana - anders gehts da nicht)

        Edit:
        // Folgende kommentieren, wenn keine Änderung der Eigenschaft erforderlich

        nameAlias = 'VM Influx';
        desc = 'per Script erstellt';
        typeAlias = 'number'; // oder 'number'
        read = "!val"; // Erkennung "Aus" --> false erfolgt automatisch

        paul53 1 Reply Last reply Reply Quote 0
        • paul53
          paul53 @Segway last edited by

          @Segway sagte:

          read = "!val";

          Das erzeugt einen booleschen Wert und invertiert gleichzeitig. Richtig:

          read = "val == 'true' ? 1 : 0";
          
          Segway 1 Reply Last reply Reply Quote 0
          • Segway
            Segway @paul53 last edited by

            @paul53 sagte in [Vorlage] Alias per Skript erzeugen:

            Das erzeugt einen booleschen Wert und invertiert gleichzeitig. Richtig:

            read = "val == 'true' ? 1 : 0";
            

            Ja das habe ich auch schon probiert ABER trotzdem wird in dem Aliaswert dann FALSE reingeschrieben warum auch immer:
            4d7e90db-2543-43e1-b887-901145693449-grafik.png

            {
              "type": "state",
              "common": {
                "name": "VM Influx",
                "desc": "per Script erstellt",
                "type": "boolean",
                "read": true,
                "write": false,
                "role": "value",
                "custom": {
                  "influxdb.0": {
                    "enabled": true,
                    "changesOnly": true,
                    "debounce": "",
                    "maxLength": 10,
                    "retention": 0,
                    "changesRelogInterval": "",
                    "changesMinDelta": "",
                    "storageType": "Boolean",
                    "aliasId": ""
                  },
                  "linkeddevices.0": {
                    "enabled": true,
                    "number_unit": "",
                    "linkedId": "InfluxDB_.is_online",
                    "name": "",
                    "role": "",
                    "mergeSettingsOnRestart": false,
                    "expertSettings": false,
                    "number_convertTo": "",
                    "number_maxDecimal": "",
                    "number_min": "",
                    "number_max": "",
                    "number_calculation": "",
                    "number_calculation_readOnly": "",
                    "number_to_boolean_condition": "",
                    "number_to_boolean_value_true": "",
                    "number_to_boolean_value_false": "",
                    "number_to_string_condition": "",
                    "number_to_duration_convert_seconds": "",
                    "number_to_duration_format": "",
                    "number_to_datetime_convert_seconds": "",
                    "number_to_datetime_format": "",
                    "number_to_multi_condition": "",
                    "boolean_convertTo": "",
                    "boolean_to_string_value_true": "",
                    "boolean_to_string_value_false": "",
                    "string_convertTo": "",
                    "string_prefix": "",
                    "string_suffix": "",
                    "string_to_boolean_value_true": "",
                    "string_to_boolean_value_false": "",
                    "string_to_number_unit": "",
                    "string_to_number_maxDecimal": "",
                    "string_to_number_calculation": "",
                    "string_to_number_calculation_readOnly": "",
                    "string_to_duration_format": "",
                    "string_to_datetime_parser": "",
                    "string_to_datetime_format": ""
                  }
                },
                "alias": {
                  "id": "linux-control.0.VM_Influx.info.is_online",
                  "read": "val == 'true' ? 1 : 0"
                }
              },
              "native": {},
              "from": "system.adapter.javascript.0",
              "user": "system.user.admin",
              "ts": 1608034784675,
              "_id": "alias.0.linux-control.0.VM_Influx.info.is_online_InfluxDB",
              "acl": {
                "object": 1636,
                "state": 1636,
                "owner": "system.user.admin",
                "ownerGroup": "system.group.administrator"
              }
            }
            
            paul53 1 Reply Last reply Reply Quote 0
            • paul53
              paul53 @Segway last edited by paul53

              @Segway sagte:

              trotzdem wird in dem Aliaswert dann FALSE reingeschrieben

              Ich lese

                  "type": "boolean",
              

              "_id": "alias.0.linux-control.0.VM_Influx.info.is_online_InfluxDB",

              ist wirklich vom Typ "string" ? Kann ich mir nicht vorstellen. Falls Typ "boolean", dann

              read = "val ? 1 : 0"
              

              EDIT:

              log('typ: ' + typeof getState("linux-control.0.Ubuntu_18.info.is_online").val);
              

              liefert bei mir 'boolean'.

              Segway 1 Reply Last reply Reply Quote 0
              • Segway
                Segway @paul53 last edited by Segway

                @paul53

                Tja ich sollte nicht zig Dinge auf einmal ändern. Es stand mitllerweile wieder auf boolean. Habe jetzt auf number umgestellt und es klappt. Es landet auch eine 0 im Datenpunkt !
                Allerdings landet bei true eine 0 im Punkt; das müsste ja eine 1 sein oder ?

                Edit:
                Also doch auf boolean stellen ?

                paul53 1 Reply Last reply Reply Quote 0
                • paul53
                  paul53 @Segway last edited by

                  @Segway sagte:

                  bei true eine 0 im Punkt

                  Siehe meinen letzten Beitrag:

                  read = "val ? 1 : 0"
                  
                  Segway 1 Reply Last reply Reply Quote 0
                  • Segway
                    Segway @paul53 last edited by Segway

                    @paul53 sagte in [Vorlage] Alias per Skript erzeugen:

                    @Segway sagte:

                    bei true eine 0 im Punkt

                    Siehe meinen letzten Beitrag:

                    read = "val ? 1 : 0"
                    

                    Mhhh, nun hab ich es auf:

                    typeAlias = 'boolean'; // oder 'number'
                    read = "val ? 1 : 0"; // Erkennung "Aus" --> false erfolgt automatisch
                    

                    geändert und es kommt wieder nur TRUE rein 😞 anstatt 1
                    355089de-daa1-4908-a629-847f8fa36f0e-grafik.png

                    paul53 1 Reply Last reply Reply Quote 0
                    • paul53
                      paul53 @Segway last edited by

                      @Segway sagte:

                      typeAlias = 'boolean'; // oder 'number'

                      Das ist falsch !! Lesen !!!

                      Segway 1 Reply Last reply Reply Quote 0
                      • Segway
                        Segway @paul53 last edited by

                        @paul53

                        Ja das weiss ich. Ich habs nun nochmal komplett neu gemacht, allerdings wird mir in der Übersicht angezeigt "1" aber in der datenbank landet true ?????

                        iobroker Übersicht:
                        7675d5cf-b07b-4e7e-ae2c-d2feee255e7c-grafik.png

                        iobroker InfluxDB:
                        1613e66d-3e3a-4d01-b07b-303380faf739-grafik.png

                        raw-Format:

                        {
                          "type": "state",
                          "common": {
                            "name": "VM Influx",
                            "desc": "per Script erstellt",
                            "type": "number",
                            "read": true,
                            "write": false,
                            "role": "value",
                            "custom": {
                              "influxdb.0": {
                                "enabled": true,
                                "changesOnly": true,
                                "debounce": "",
                                "maxLength": 10,
                                "retention": 0,
                                "changesRelogInterval": "",
                                "changesMinDelta": "",
                                "storageType": "Boolean",
                                "aliasId": ""
                              },
                              "linkeddevices.0": {
                                "enabled": true,
                                "number_unit": "",
                                "linkedId": "InfluxDB_.is_online",
                                "name": "",
                                "role": "",
                                "mergeSettingsOnRestart": false,
                                "expertSettings": false,
                                "number_convertTo": "",
                                "number_maxDecimal": "",
                                "number_min": "",
                                "number_max": "",
                                "number_calculation": "",
                                "number_calculation_readOnly": "",
                                "number_to_boolean_condition": "",
                                "number_to_boolean_value_true": "",
                                "number_to_boolean_value_false": "",
                                "number_to_string_condition": "",
                                "number_to_duration_convert_seconds": "",
                                "number_to_duration_format": "",
                                "number_to_datetime_convert_seconds": "",
                                "number_to_datetime_format": "",
                                "number_to_multi_condition": "",
                                "boolean_convertTo": "",
                                "boolean_to_string_value_true": "",
                                "boolean_to_string_value_false": "",
                                "string_convertTo": "",
                                "string_prefix": "",
                                "string_suffix": "",
                                "string_to_boolean_value_true": "",
                                "string_to_boolean_value_false": "",
                                "string_to_number_unit": "",
                                "string_to_number_maxDecimal": "",
                                "string_to_number_calculation": "",
                                "string_to_number_calculation_readOnly": "",
                                "string_to_duration_format": "",
                                "string_to_datetime_parser": "",
                                "string_to_datetime_format": ""
                              }
                            },
                            "alias": {
                              "id": "linux-control.0.VM_Influx.info.is_online",
                              "read": "val ? 1 : 0"
                            }
                          },
                          "native": {},
                          "from": "system.adapter.javascript.0",
                          "user": "system.user.admin",
                          "ts": 1608037099330,
                          "_id": "alias.0.linux-control.0.VM_Influx.info.is_online_InfluxDB",
                          "acl": {
                            "object": 1636,
                            "state": 1636,
                            "owner": "system.user.admin",
                            "ownerGroup": "system.group.administrator"
                          }
                        }
                        
                        paul53 2 Replies Last reply Reply Quote 0
                        • paul53
                          paul53 @Segway last edited by

                          @Segway sagte:

                          aber in der datenbank landet true ?????

                                  "storageType": "Boolean",
                          
                          1 Reply Last reply Reply Quote 0
                          • paul53
                            paul53 @Segway last edited by

                            @Segway sagte:

                            Datenpunkt true / false --> type = string

                            type = "string" ist falsch. Habe PR auf Github erstellt.

                            Segway 1 Reply Last reply Reply Quote 0
                            • Segway
                              Segway @paul53 last edited by

                              @paul53 sagte in [Vorlage] Alias per Skript erzeugen:

                              @Segway sagte:

                              Datenpunkt true / false --> type = string

                              type = "string" ist falsch. Habe PR auf Github erstellt.

                              Du überforderst mich gerade.
                              Anscheinend liegt hier ein Fehler vor ? Ich habe diesen noch nicht erkannt 😞

                              paul53 1 Reply Last reply Reply Quote 0
                              • paul53
                                paul53 @Segway last edited by paul53

                                @Segway sagte in:

                                Anscheinend liegt hier ein Fehler vor ?

                                type = "string" ist zwar falsch, hat aber auf die Reaktion des Alias keinen Einfluss, wenn man es weiß. Das Problem ist eher, dass Anwender (wie Du) glauben, was sie an der Stelle lesen.

                                Das Problem mit der DB ist eher der "storageType".

                                Segway 2 Replies Last reply Reply Quote 0
                                • Segway
                                  Segway @paul53 last edited by

                                  @paul53 sagte in [Vorlage] Alias per Skript erzeugen:

                                  Das Problem mit der DB ist eher der "storageType".

                                  Ja das hatte ich auch gelesen und habe es einfach per Hand geändert unter RAW aber dann schreibt die Influx nicht mehr da sie den Datentyp nicht kennt 😞
                                  Also warte ich mal 😞

                                  crunchip 1 Reply Last reply Reply Quote 0
                                  • Segway
                                    Segway @paul53 last edited by

                                    @paul53
                                    Kann ich das irgendwie auch manuell lösen, dass die 0 und 1 in den Wert geschrieben wird?

                                    1 Reply Last reply Reply Quote 0
                                    • crunchip
                                      crunchip Forum Testing Most Active @Segway last edited by crunchip

                                      @Segway nur so nebenbei, wenn du schon einen Datenpunkt in die Influx DB schreibst, auf (auto/boolean) gestellt hattest und änderst es nachträglich auf (number) musst du diesen erst aus der Influx löschen, sofern der DP die gleiche Bezeichnung hat, sonst funktioniert Influx/Grafana nicht mehr und dir wird "no data" angezeigt.

                                      PS: mit nem blockly wärst schneller und einfacher gewesen😜

                                      hab oben dein RAW nochmal angesehen,
                                      ist das nicht doppelt gemoppelt, alias und linkeddevices für den DP zu verwenden oder hab ich nen Denkfehler??

                                      Segway 1 Reply Last reply Reply Quote 0
                                      • Segway
                                        Segway @crunchip last edited by

                                        @crunchip sagte in [Vorlage] Alias per Skript erzeugen:

                                        @Segway nur so nebenbei, wenn du schon einen Datenpunkt in die Influx DB schreibst, auf (auto/boolean) gestellt hattest und änderst es nachträglich auf (number) musst du diesen erst aus der Influx löschen, sofern der DP die gleiche Bezeichnung hat, sonst funktioniert Influx/Grafana nicht mehr und dir wird "no data" angezeigt.

                                        Ja da hast du vollkommen Recht und genau das ist ja mein problem.
                                        Ich habe das Skript genutzt und umgestellt (wie oben gepostet) und durch die Hilfe von @paul53 scheint es so, dass ich alles nach number deklariert habe aber das Skript anscheinend den "storgaeType: Boolean" trotzdem setzt und NICHT auf number !
                                        Wenn ich das richtig verstanden habe, gibt es da einen Fehler und er hat das schon als PR auf Github gepostet.

                                        Somit kann ich es nicht durch das Skript richtig anlegen - ist jedenfalls meine Schlussfolgerung daraus.

                                        Daher die Frage ob ich da manuell irgendwie Hand anlegen kann.

                                        paul53 1 Reply Last reply Reply Quote 0
                                        • paul53
                                          paul53 @Segway last edited by

                                          @Segway sagte:

                                          das Skript anscheinend den "storgaeType: Boolean" trotzdem setzt und NICHT auf number !

                                          Das macht nicht das Skript, sondern muss eine Einstellung für die DB sein.

                                          @Segway sagte in [Vorlage] Alias per Skript erzeugen:

                                          hat das schon als PR auf Github gepostet.

                                          Der PR hat nichts mit Influx zu tun, sondern betrifft iobroker.linux-control.

                                          Segway 1 Reply Last reply Reply Quote 0
                                          • Segway
                                            Segway @paul53 last edited by Segway

                                            @paul53 sagte in [Vorlage] Alias per Skript erzeugen:

                                            @Segway sagte:

                                            das Skript anscheinend den "storgaeType: Boolean" trotzdem setzt und NICHT auf number !

                                            Das macht nicht das Skript, sondern muss eine Einstellung für die DB sein.

                                            @Segway sagte in [Vorlage] Alias per Skript erzeugen:

                                            hat das schon als PR auf Github gepostet.

                                            Der PR hat nichts mit Influx zu tun, sondern betrifft iobroker.linux-control.

                                            Ja dann weiss ich es auch nicht mehr wo hier das problem liegt. Ich blicke als Laie nunmal da nicht durch.
                                            Fakt ist, ich habe das Skript genutzt und es entsprechend angepasst und es funktioniert auch, dass der Wert in iobroker mit 0 und 1 landet. In Influx landet aber nunmal true / false.
                                            Ich kann nicht mehr erkennen wo nun das Problem liegt.

                                            Zu deiner Aussage
                                            @paul53 sagte in [Vorlage] Alias per Skript erzeugen:

                                            Das macht nicht das Skript, sondern muss eine Einstellung für die DB sein.

                                            soll mir das jetzt sagen, dass ich nur Boolean Werte in die Influx schreiben kann ?

                                            Ich weiss es einfach nicht und bisher, so leid es mir tut, habe ich noch nirgends eine Lösung gelesen --> mag sein dass sie irgendwo steht und auf meine Dummheit zurückzuführen ist, dass ich Sie nicht erkannt habe.
                                            Nicht falsch verstehen aber so kommt es für mich als Laie halt rüber.

                                            paul53 crunchip 2 Replies Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            918
                                            Online

                                            31.6k
                                            Users

                                            79.5k
                                            Topics

                                            1.3m
                                            Posts

                                            38
                                            314
                                            43656
                                            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