NEWS
Helium API per GET abrufen (incl. User-Agent)
-
@unbekannt
Probiere es erst Mal.mit meiner LösungDie fehlerm Ladung ist eigentlich selbst erklärend.
Die Funktion mit diesem Namen wurde nie definiert
Die Folgezeilen sind der stacktrace für diesen Fehler -
Wenn ich dein zuletzt gepostetes Skript nutze (plus ergänzend der Timeout), sprich Sktipt2 in meinem letzten Post, dann bekomme ich eine analoge Fehlermeldung:
17.8.2022, 15:17:02.151 [info ]: javascript.0 (1151) Stop script script.js.Allgemein.Crypto.Helium.test 17.8.2022, 15:17:02.255 [info ]: javascript.0 (1151) Start javascript script.js.Allgemein.Crypto.Helium.test 17.8.2022, 15:17:02.291 [info ]: javascript.0 (1151) script.js.Allgemein.Crypto.Helium.test: registered 0 subscriptions and 1 schedule 17.8.2022, 15:17:02.293 [error]: javascript.0 (1151) script.js.Allgemein.Crypto.Helium.test: ReferenceError: writeValueOverview is not defined 17.8.2022, 15:17:02.293 [error]: javascript.0 (1151) at script.js.Allgemein.Crypto.Helium.test:75:1 17.8.2022, 15:17:02.293 [error]: javascript.0 (1151) at script.js.Allgemein.Crypto.Helium.test:79:3 17.8.2022, 15:17:03.451 [info ]: javascript.0 (1151) script.js.Allgemein.Crypto.Helium.test: {'total':0.3685975,'sum':36859750,'stddev':0.0094209479866946,'min':0,'median':0.01122825,'max':0,'avg':0.012710258620689655} 17.8.2022, 15:17:04.390 [info ]: javascript.0 (1151) script.js.Allgemein.Crypto.Helium.test: {'total':0.06173936,'sum':6173936,'stddev':0.018747958871,'min':0,'median':0.01570541,'max':0,'avg':0.020579786666666666} 17.8.2022, 15:17:05.389 [info ]: javascript.0 (1151) script.js.Allgemein.Crypto.Helium.test: {'total':0.3685975,'sum':36859750,'stddev':0.0094209479866946,'min':0,'median':0.01122825,'max':0,'avg':0.012710258620689655} 17.8.2022, 15:17:06.625 [info ]: javascript.0 (1151) script.js.Allgemein.Crypto.Helium.test: {'total':0.3685975,'sum':36859750,'stddev':0.0094209479866946,'min':0,'median':0.01122825,'max':0,'avg':0.012710258620689655}
Mir ist bewusst, dass writeValueOverview nicht definiert ist, ich weiß nur nicht wie ich das mache. Thema fehlendes Basiswissen zum Thema Javascript. Bisher habe ich meine Skripte immer irgendwie zusammenkopiert nach dem try&error Prinzip.
Da in dem Skript vom Prinzip 4 mal der gleiche Code genutzt wird, verstehe ich nicht, warum der Fehler nur bei einer Funktion vorhanden ist und nicht bei allen vieren. Vor allem, weil das Skript ja erfolgreich die Daten holt. Muss ich am Anfang im Skript einfach eine Definition festlegen? Wenn ja, wie mache ich das?
-
@unbekannt
Jetzt wird es durcheinander. Poste bitte die aktuelle Skriptversion zu der das debig Log passt dazu.
Zu diesem Log kann ich jetzt kein Skriptbeispiel mehr findenDa wo du die Funktionen in settimeout callbacks gepackt hast, sind eigentlich immer anonyme Funktionen. Den Namen den du da vergibst gilt nur innerhalb des settimeout Aufrufs
Daher ist der Name unnötig
Und der Aufruf weiter unten schlägt fehlDas mit settimeout zu machen ist nicht richtig auch wenn es wohl das Problem löst. Irgendwann passt das Zeitverhalten nicht mehr und dann klappt es wieder nicht.
https://developer.mozilla.org/de/docs/Web/JavaScript/Reference/Functions
Was funktionierte bei meinem Beispiel konkret nicht?
-
@oliverio
Ich versuche es mal. Also hier dein Skript mit diesen Anpassungen:- Miner ID ergänzt/ausgetauscht
- Zeile 6 &12 dp2 entfernt (benötige ich nicht)
- Zeile 9 (url) zu (v_url) geändert (sonst bekomme ich den Fehler, das url nicht definiert ist)
- Zeile 21 & 29 data.total ergänzt statt Fragezeichen
- Zeile 30 gelöscht
- Zeile 42 zum Testen auf jede Minute geändert
Hier das Skript:
Ich habe das Skript mal laufen gelassen und festgestellt, das Resultat nach jedem Abruf unterschiedlich ist. Mal bekomme ich einen Fehler, mal mehrere und manchmal keine.
Hier die Ausgabe:Fehler Nr.1
Fehler Nr.2
hier mal kein Fehler
Fehler Nr.3
Wie du siehst geht es manchmal gut, manchmal aber auch nicht. Wie würdest du das lösen?
-
@unbekannt
Schau ich mir Anfang der nö hatten Woche im Detail an. Bin Grad ni ht an einem RechnerDer Fehler 429 kann 2 Möglichkeiten haben.
Einmal too many requests. Anbieter versuchen die Häufigkeit der Anfragen in einem bestimmten Zeitabschnitt zu limitieren. Das muss man beachten. Hab aber auf die schnelle keine Regel gefunden
Allerdings hab ich gefunden das man einen User-Agent String mit angeben muss da ansonsten genau mit 429 abgebrochen wird. Evtl findest du dazu Details. Wenn du im Internet suchst dann findest Angaben bspw zu Chrome oder Firefox. Welcher ist relativ egal -
@oliverio
Ja, dass der Fehler wegen zu vieler Anfragen kommt, hatte ich auch recherchiert, daher wollte ich ja den Timeout setzen. Aber du meintest ja, dass es so wie ich es gemacht habe nicht optimal ist.Ich habe jetzt einen anderen Ansatz gewählt und einfach mal ganz pragmatisch den cronjob angepasst, damit läuft das Skript auf jeden Fall fehlerfrei.
Ich danke dir auf jeden Fall für deinen Input, ich habe eine Menge gelernt
Für die, die es interessiert, hier das funktionierende Skript. Ihr müsst nur "dp1" und die Miner-ID anpassen:
-
@unbekannt
das hatte hier ich als andere alternative auch geschrieben
die skript detail sachen kann ich fühestens erst ab montag wieder schauen
-
ich habe den folgenden Code ausprobiert. Das schedule habe ich aus testzwecken entfernt.
Er hat einwandfrei funktioniert.
Gab es jetzt noch ein Problem.
Den Useragent hast ja auch ergänzt.
Hab daher nun kein 429 mehr erhalten. -
@oliverio Hi
ich beschäftige mich auch gerade mit dem auslesen von der API
aber im moment blicke ich garnichts.
Ich habe Iobroker und Grafana am laufen.
Und möchte auch die Daten aus der Helium Api auslesen.
Es hapert aber schon an diesem Axis. Muss man das im Iobroker einrichten oder wie benutze ich dieses Script.
Sorry für diese doofe Frage. -
axios ist eine zusätzliche bibliothek, mit der man http-abfragen machen kann.
also genau die art von abfragen, die der browser im hintergrund macht.axios wird auch von iobroker intern verwendet, aber um sicher zu gehen,
sollte man ihn in den einstellungen des javascript-adapters im feld "zusätzliche npm module" eintragen. also einfach "axios" eintragen.
danach kann im javascript diese bibiothek mitvar axios = require("axios");
verwendet werden.
welche befehle und parameter zur verfügung stehen, kann man in der doku nachlesen
https://axios-http.com/docs/api_intro -
@oliverio sagte in Helium API per GET abrufen (incl. User-Agent):
ich habe den folgenden Code ausprobiert. Das schedule habe ich aus testzwecken entfernt.
Er hat einwandfrei funktioniert.
Gab es jetzt noch ein Problem.
Den Useragent hast ja auch ergänzt.
Hab daher nun kein 429 mehr erhalten.kurzes Update:
Ich habe den Code (mit schedule) nun seit einigen Tagen fehlerfrei laufen.Danke nochmal für deine Hilfestellungen.
-
@unbekannt said in Helium API per GET abrufen (incl. User-Agent):
@oliverio sagte in Helium API per GET abrufen (incl. User-Agent):
ich habe den folgenden Code ausprobiert. Das schedule habe ich aus testzwecken entfernt.
Er hat einwandfrei funktioniert.
Gab es jetzt noch ein Problem.
Den Useragent hast ja auch ergänzt.
Hab daher nun kein 429 mehr erhalten.kurzes Update:
Ich habe den Code (mit schedule) nun seit einigen Tagen fehlerfrei laufen.Danke nochmal für deine Hilfestellungen.
Hi wo hast du das Schedule eingetragen?
-
@manni4545
in diesem post kannst du nachschauen
https://forum.iobroker.net/topic/50188/helium-api-per-get-abrufen-incl-user-agent/25?_=1661253687023wobei man auch alle Funktionsaufrufe in ein schedule reinschreiben kann.
bei mir gab es keine fehlermeldung mehr, auch wenn ich das skript mehrmals hintereinander laufen lassen habe -
Hat jemand zufällig schon eine Lösung für die neue API erarbeitet?