Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. JavaScript zum Auslesen der Tibber API?

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    JavaScript zum Auslesen der Tibber API?

    This topic has been deleted. Only users with topic management privileges can see it.
    • mickym
      mickym Most Active last edited by mickym

      Tja vielleicht ist NodeRed doch nicht so kompliziert. 😉 und scheint zu funktionieren. 😉

      S 1 Reply Last reply Reply Quote 1
      • OliverIO
        OliverIO @skorpil last edited by

        @skorpil

        Also ich sag mal Puh.
        Im Endeffekt müssen wir dir hier alles vorgeben.
        Wenn xxxx der Token ist, dann frage ich mich wie der da hin kommt.
        Gemäß dem Skriptausschnitt von oben:

        const options = {
            url: `https://api.tibber.com/v1/home/${HOME_ID}`,
            headers: {
                Authorization: `Bearer ${API_TOKEN}`
            }
        };
        

        Sollte an der Stelle eigentlich die Home_ID sein.
        Die Fehlermeldung interpretiere ich so, das er (wenn es der Token ist) kein home mit der ID findet
        Bitte setze dich selber über die Doku (hier request Bibliothek) mit den Funktionen auseinander, sonst wird es echt schwierig.
        https://github.com/request/request#readme
        Ganz nebenbei, mein erstes Beispiel verwendete die neuere Axios-Bibliothek,
        aber request ist auch OK, daher an dem deprecated nicht stören.

        S 1 Reply Last reply Reply Quote 0
        • S
          skorpil @OliverIO last edited by

          @oliverio Sorry, es war die Home ID. Du hast recht

          OliverIO 1 Reply Last reply Reply Quote 0
          • OliverIO
            OliverIO @skorpil last edited by

            @skorpil
            dann ist sie falsch oder du bist nicht authentifiziert

            S 1 Reply Last reply Reply Quote 0
            • S
              skorpil @mickym last edited by

              @mickym da dürftest Du recht haben. Ich hatte gehofft, es gäbe auch einen direkten Weg. Ich werde das morgen in Angriff nehmen.

              mickym 1 Reply Last reply Reply Quote 0
              • S
                skorpil @OliverIO last edited by

                @oliverio ich glaubte, sie sei richtig. Heute Abend kann ich das nicht mehr prüfen. Ich gebe morgen Feedback. Danke dennoch schon Mal

                OliverIO 1 Reply Last reply Reply Quote 0
                • OliverIO
                  OliverIO @skorpil last edited by

                  @skorpil
                  probiere erst mal den weg über node red.
                  wenn der funktioniert und alle parameter richtig sind, dann kann man nochmal schauen, wie man das auf javascript überträgt

                  S 1 Reply Last reply Reply Quote 0
                  • S
                    skorpil @OliverIO last edited by

                    @oliverio das mache ich! Gerade habe ich nochmal die homeID und den Token hier

                    https://developer.tibber.com/explorer
                    

                    überprüft! Sie sind beide richtig. Ergo stimmt irgendwas am Aufruf nicht. Aber nach meiner Prüfung über NodeRed wissen wir morgen mehr. Danke nochmals

                    1 Reply Last reply Reply Quote 0
                    • mickym
                      mickym Most Active @skorpil last edited by mickym

                      @skorpil sagte in JavaScript zum Auslesen der Tibber API?:

                      @mickym da dürftest Du recht haben. Ich hatte gehofft, es gäbe auch einen direkten Weg. Ich werde das morgen in Angriff nehmen.

                      Was ist denn an NodeRed bitte indirekt. NodeRed ist unter dem iobroker (bis auf ein paar Kleinigkeiten) den anderen Logikmaschinen wie Javascript oder Blockly gleichwertig. Gerade wenn es im iobroker keinen passenden Adapter gibt, hat man mit den NodeRed Nodes die Möglichkeit den iobroker zu erweitern (zudem die NodeRed Community einiges größer ist). Die Kommunikation ist also genauso direkt - kein bisschen indirekter oder weniger performant. Für mich sieht das immer wieder so aus, als ob man sich mit Händen und Füssen wehrt sich mit diesem tollen Tool zu beschäftigen und lieber Javascript codiert, was übrigens mit NodeRed auch geht.

                      S 1 Reply Last reply Reply Quote 1
                      • S
                        skorpil @mickym last edited by

                        @mickym alles gut! Ich habe mich damit nur noch nie beschäftigt. Ich wollte halt nicht noch ein weiteres System lernen, wo ich JavaScript noch nicht einmal beherrsche. Daher schien es mir ein Umweg zu sein. Ich lasse mich ja gerne eines Besseren belehren. Und morgen starte ich dann also mit NodeRed.

                        1 Reply Last reply Reply Quote 0
                        • S
                          skorpil last edited by

                          mit node red hat es geklappt. Tolle Anleitung. Auch wenn ich keine Ahnung habe, was ich da genau gemacht habe, es funktioniert.

                          mickym 1 Reply Last reply Reply Quote 0
                          • mickym
                            mickym Most Active @skorpil last edited by

                            @skorpil sagte in JavaScript zum Auslesen der Tibber API?:

                            Auch wenn ich keine Ahnung habe, was ich da genau gemacht habe, es funktioniert.

                            Vielleicht wäre das ja mal ein Grund sich mit diesem tollen Tool näher zu beschäftigen. 😉

                            O 1 Reply Last reply Reply Quote 0
                            • O
                              ostseeskipper @mickym last edited by

                              Hinweis
                              Unter Github gibts eine funktionierende JS Version um die Tibber API auszulesen. Lediglich der Public Token muss aktualisiert werden
                              zum Script

                              paul53 1 Reply Last reply Reply Quote 2
                              • paul53
                                paul53 @ostseeskipper last edited by paul53

                                @ostseeskipper sagte: funktionierende JS Version um die Tibber API auszulesen.

                                Habe ein paar Anpassungen und Korrekturen vorgenommen:

                                // Get Tibber Data  (Awattar alternative)
                                const url = 'https://api.tibber.com/v1-beta/gql';
                                const token = "Bearer 5K4MVS-OjfWhK_4yrjOlFe1F6kJXPVf7eQYggo8ebAE"; // Anpassen!
                                const path = '0_userdata.0.Tibber.Preise.'; // Anpassen!
                                
                                function requestData() {
                                    const options = {
                                        uri: url,
                                        method: 'POST',
                                        body: '{"query": "{ viewer { homes { currentSubscription{ priceInfo{ today{ total startsAt } tomorrow{ total startsAt } } } } } }" }',
                                        headers: {
                                            'Authorization': token,
                                            'Content-Type': 'application/json'
                                        }
                                    }
                                 
                                    request(options, (error, response, body) => {
                                        if(error) return log(error, 'warn');
                                 
                                        if(response.statusCode == 200) {
                                            let array = JSON.parse(body).data.viewer.homes[0].currentSubscription.priceInfo.today
                                                array = array.concat(JSON.parse(body).data.viewer.homes[0].currentSubscription.priceInfo.tomorrow)
                                            var jetzt = new Date(),
                                                midn = new Date(
                                                    jetzt.getFullYear(),
                                                    jetzt.getMonth(),
                                                    jetzt.getDate(),
                                                    0,0,0),
                                                diffhr = Math.floor((jetzt.getTime() - midn.getTime())/3600000);
                                            for(let i = diffhr; i < array.length; i++) {
                                                let a = i - diffhr
                                                let stateBaseName = path + a + ".";
                                                let start = new Date(Date.parse(array[i].startsAt));
                                                let option = { hour12: false, hour: '2-digit', minute:'2-digit'};
                                                let startTime = start.toLocaleTimeString('de-DE', option);
                                                let startDate = start.toLocaleDateString('de-DE');
                                                 
                                                let end = new Date(Date.parse(array[i].startsAt)).getTime()+3600000
                                                let endTime = new Date(end).toLocaleTimeString('de-DE', option);
                                                let price = 100 * array[i].total;
                                                //console.log(startTime + ',' + startDate + ',' + startTime + ',' + endTime + ',' + price )
                                                
                                                if(existsState(stateBaseName + "startTime")) setState(stateBaseName + "startTime", startTime, true);
                                                else createState(stateBaseName + "startTime", startTime, {
                                                    read: true,
                                                    write: false,
                                                    name: "Gultigkeitsbeginn (Uhrzeit)",
                                                    type: "string",
                                                    def: ''
                                                });
                                
                                                if(existsState(stateBaseName + "startDate")) setState(stateBaseName + "startDate", startDate, true);
                                                else createState(stateBaseName + "startDate", startDate, {
                                                    read: true,
                                                    write: false,
                                                    name: "Gultigkeitsbeginn (Datum)",
                                                    type: "string",
                                                    def: ''
                                                });
                                
                                                if(existsState(stateBaseName + "endTime")) setState(stateBaseName + "endTime", endTime, true);
                                                else createState(stateBaseName + "endTime", endTime, {
                                                    read: true,
                                                    write: false,
                                                    name: "Gultigkeitsende (Uhrzeit)",
                                                    type: "string",
                                                    def: ''
                                                });
                                
                                                if(existsState(stateBaseName + "price")) setState(stateBaseName + "price", price, true);
                                                else createState(stateBaseName + "price", price, {
                                                    read: true,
                                                    write: false,
                                                    name: "Preis",
                                                    type: "number",
                                                    unit: 'ct/kWh',
                                                    def: 0
                                                });
                                            };
                                        };
                                    });
                                }
                                
                                requestData();
                                schedule("0 * * * *", requestData);
                                
                                crunchip O 2 Replies Last reply Reply Quote 2
                                • crunchip
                                  crunchip Forum Testing Most Active @paul53 last edited by

                                  @paul53 Daten kommen an

                                  1 Reply Last reply Reply Quote 1
                                  • O
                                    ostseeskipper @paul53 last edited by

                                    @paul53
                                    Das Script ist war ne gute Basis und dafür das es aus 2020 ist ne gute Arbeit.

                                    Mir gefiel einiges nicht daran und bin noch am probieren und testen.
                                    Unter anderen, das Datenpunkt anlegen ohne if(exitsState) was du nun schon geändert hast.

                                    Habe auch lange gerätselt wozu das hier ist.

                                                var jetzt = new Date(),
                                    
                                                    midn = new Date(
                                    
                                                        jetzt.getFullYear(),
                                    
                                                        jetzt.getMonth(),
                                    
                                                        jetzt.getDate(),
                                    
                                                        0,0,0),
                                    
                                                    diffhr = Math.floor((jetzt.getTime() - midn.getTime())/3600000);
                                    
                                                for(let i = diffhr; i < array.length; i++) {
                                    
                                                    let a = i - diffhr
                                    
                                    

                                    und es dann rausgeschmissen weil ich da die Datenpunkte mit Stunden kleiner 10 mit führender Null haben wollte wegen der Sortierung.
                                    Ich mach da mal weiter und poste meinen aktuellen Stand wenn er läuft.

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

                                      @ostseeskipper sagte: rausgeschmissen weil ich da die Datenpunkte mit Stunden kleiner 10 mit führender Null haben wollte

                                      Der Bestandteil a der Datenpunkt-ID ist nicht die Uhrzeit, sondern der Stunden-Abstand zur aktuellen Uhrzeit. Deshalb fängt die Schleife auch mit der aktuellen Uhrzeit an, da Daten aus der Vergangenheit nicht interessieren.
                                      Beispiel mit Abfrage um 19:00 Uhr:

                                      Tibber_DP.JPG

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

                                        @paul53
                                        weiss nicht warum ich stündlich in der Schleife oben aktuell haben möchte.
                                        Da kann man auch stündlich über "current" abrufen
                                        d192be90-24d2-4a65-8e91-8663b16a7b95-grafik.png

                                        Aber egal das kann sich ja jeder so bauen wie er mag.

                                        @paul53 Schön das du hier bist 🙂
                                        Wegen einem RexEx komme ich sicherlich demnächst noch mal auf dich zu.

                                        O 1 Reply Last reply Reply Quote 1
                                        • O
                                          ostseeskipper @ostseeskipper last edited by ostseeskipper

                                          @paul53 und alle Tibber'ianer die danach suchten

                                          Da ich ab Mai auch zu Tibber wechsle möchte ich mir die Preise visualisieren und natürlich im nächsten Step auch nach rechnen(folgt später).
                                          Zudem ist es mein erstes Projekt bei dem ich den Umgang mit JSON 👻 lernen konnte.

                                          Abruf erfolgt über die Tibber API mit einem Token. Den kann man sich hier holen.
                                          Mit einem persönlichen Token bekommt man nach bestätigter Anmeldung auch seine eigenen echten Preise.
                                          (so hab ich das zumindest verstanden und sehe ich mit meinem privaten Token)

                                          Mir war wichtig das die Datenpunkte der Stundenfolge nach beginnend mit 0 in der richtigen Reihenfolge stehen, daher werden die Datenpunkte 0-9 mit einer führenden Null angelegt.

                                          Abgerufen wird 14:01 und 15:01 weil ab da neue Daten für den Folgetag zur Verfügung stehen sollen.
                                          Zu 00:01 wird noch mal aufgerufen werden weil da dann der Tagessprung ist.
                                          Hier muss ich noch schauen ob sich die Werte für Stunde 24-47 von selbst löschen wenn diese nach Mitternacht nicht mehr über die API kommen.

                                          /* 
                                          MIT License - see LICENSE.md 
                                          Copyright (c) [2020] [Matthias Boettger <mboe78@gmail.com>]
                                          Basic unter https://github.com/Maverick78de/SMA_forecast_charging/blob/master/get_tibber_data_1.0.1.js
                                          Modifiziert ostseeskipper
                                          */
                                          
                                          const token = "5K4MVS-OjfWhK_4yrjOlFe1F6kJXPVf7eQYggo8ebAE" //PublicToken
                                          // Get Tibber Data  
                                          const url = 'https://api.tibber.com/v1-beta/gql'
                                          const baseName = '0_userdata.0.StromKosten.TibberTest.';              // Legt die Datenpunkte für Stunden unter diesen Javascript-Objektordner an
                                          let myDebugLevel = 'info';  // LogLevel
                                          
                                          function requestData() {
                                           
                                              const options = {
                                                  uri: url,
                                                  method: 'POST',
                                                  body: '{"query": "{ viewer { homes { currentSubscription{ priceInfo{ today{ total energy tax startsAt } tomorrow{ total energy tax startsAt } } } } } }" }',
                                                  headers: {
                                                      'Authorization': token,
                                                  'Content-Type': 'application/json'
                                                  }
                                              }
                                              
                                              request(options, (error, response, body) => {
                                                  
                                                  if(error) return console.log(error);
                                           
                                                  if(response.statusCode == 200) {
                                                      let array = JSON.parse(body).data.viewer.homes[0].currentSubscription.priceInfo.today
                                                          array = array.concat(JSON.parse(body).data.viewer.homes[0].currentSubscription.priceInfo.tomorrow)
                                          
                                              for(var i = 0; i < 48; i++) {        // 48 Datenpunkte
                                          
                                          
                                                  
                                                          let lfd_Std = i + '.';
                                                  
                                                          if(i < 10) lfd_Std = '0' + lfd_Std; // voranstehende 0
                                                  
                                          
                                                          let price = Number(array[i].total)*100;
                                                          
                                                          let energy = Number(array[i].energy) *100;                
                                                          
                                                          let tax = Number(array[i].tax) *100;                
                                          
                                                          let start = String(new Date(Date.parse(array[i].startsAt)));
                                          
                                          
                                                          if(existsState(baseName + lfd_Std + "startTime")) setState(baseName + lfd_Std + "startTime", start, true);
                                                          else createState(baseName + lfd_Std + "startTime", start, {
                                          
                                                              read: true,
                                                              write: false,
                                                              name: "Gultigkeitsbeginn",
                                                              type: "string",
                                                              def: ''
                                          
                                                          });
                                          
                                                          if(existsState(baseName + lfd_Std + "Total_Preis")) setState(baseName + lfd_Std + "Total_Preis", price, true);
                                                          else createState(baseName + lfd_Std + "Total_Preis", price, {
                                          
                                                              read: true,
                                                              write: false,
                                                              name: "Total_Preis",
                                                              type: "number",
                                                              unit: "ct/kWh",
                                                              def: 0
                                          
                                                          });
                                          
                                                          if(existsState(baseName + lfd_Std + "Tax")) setState(baseName + lfd_Std + "Tax", tax, true);
                                                          else createState(baseName + lfd_Std + "Tax", tax, {
                                          
                                                              read: true,
                                                              write: false,
                                                              name: "Tax (Abgaben)",
                                                              type: "number",
                                                              unit: "ct/kWh",
                                                              def: 0
                                          
                                                          });
                                          
                                                          if(existsState(baseName + lfd_Std + "EPEX_Preis")) setState(baseName + lfd_Std + "EPEX_Preis", energy, true);
                                                          else createState(baseName + lfd_Std + "EPEX_Preis", energy, {
                                          
                                                              read: true,
                                                              write: false,
                                                              name: "EPEX_Preis",
                                                              type: "number",
                                                              unit: "ct/kWh",
                                                              def: 0
                                          
                                                          });
                                          /*      
                                           console.log('energy :'+ energy );  
                                           console.log('Variable :' + [i] );  
                                           console.log('Start :' + startTime );  
                                          */
                                                      };
                                                  };
                                              });
                                          }
                                          requestData(); // 1x Abruf bei Scriptstart
                                          
                                          
                                          schedule('1 0,14,15 * * *', function () { // 00:01 14:01 und 15:01 holen
                                          
                                              requestData();
                                          });
                                          

                                          EDIT: Vorschlag paul53 übernommen

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

                                            @ostseeskipper
                                            Zeilen 36, 37 würde ich so programmieren:

                                                    let lfd_Std = i + '.';
                                                    if(i < 10) lfd_Std = '0' + lfd_Std; // voranstehende 0
                                            

                                            Wenn man multipliziert, muss man nicht per Number() wandeln. Es erfolgt eine implizite Typwandlung.
                                            Richtige Schreibweise der Maßeinheit: "ct/kWh"

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            846
                                            Online

                                            31.8k
                                            Users

                                            80.0k
                                            Topics

                                            1.3m
                                            Posts

                                            10
                                            51
                                            5075
                                            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