NEWS
"On" Subscripton: Funktionsaufruf mit Parameter
-
@vippis du verwendest var um deine variablen zu deklarieren, damit sind sie global. Das kann zu unerwarteten Fehlern führen weil damit schon vorhandene variablen überschrieben werden.
Verwende statt dessen let und const. -
Zunächst mal vorweg: JS ist nicht unbedingt meine Kernkompetenz
Aber mir fallen da ein paar Dinge auf:
@vippis sagte in "On" Subscripton: Funktionsaufruf mit Parameter:
der aufzurufenden Funktion einen Parameter übergeben
Das machst Du aber nicht.
Du rufts - wie eigentlich üblich - eine anonyme Funktion auf. Ohne Parameter - das könnte man nämlich auch so formatieren:on ({id: ventile[5].on, change: 'ne'}, function() { Einschalten(ventile[5]); });
Deine Formatierung ist lediglich "mimified".
Wie gesagt: Nicht meine Kernkompetenz, aber ich würde da ein Semikolon ans Ende der Zeile setzen.Auch den Vergleich würde ich anders formulieren:
if (ein) { ... } else { ... }
Und hinter
console.log("Schalte Ventil "+ventil.name+" ein.")
und
var s = min * 60
und einigen anderen Zeilen fehlt ein Semikolon,
-
@vippis sagte in "On" Subscripton: Funktionsaufruf mit Parameter:
Wo ist mein Fehler?
Sleep liefert ein Promise zurück: https://github.com/ioBroker/ioBroker.javascript/blob/master/docs/en/javascript.md#wait
Damit wartet Dein Script an der Stelle nie, sondern die Schleife läuft mit voller Rechenleistung. Ansonsten könntest Du das Script deutlich vereinfachen (es fehlt zwar die Hälfte vom Script, aber hier ein Beispiel):
const ventile = { '0_userdata.0.Garten.Rasensprenger_Ein': { name: 'Rasensprenger', nr: 1, left: '0_userdata.0.Garten.Rasensprenger_Restzeit', }, '0_userdata.0.Garten.Hecke+Steinbeet_Ein': { name: 'Hecke+Steinbeet', nr: 2, left: '0_userdata.0.Garten.Hecke+Steinbeet_Restzeit', }, '0_userdata.0.Garten.Vorgaten+Kübel_Ein': { name: 'Vorgarten+Kübel', nr: 3, left: '0_userdata.0.Garten.Vorgarten+Kübel_Restzeit', }, '0_userdata.0.Garten.Hochbeete_Ein': { name: 'Hochbeete', nr: 4, left: '0_userdata.0.Garten.Hochbeete_Restzeit', }, '0_userdata.0.Garten.Oli-Seite_Ein': { name: 'Oli-Seite', nr: 5, left: '0_userdata.0.Garten.Oli-Seite_Restzeit', }, '0_userdata.0.Garten.Dachterrasse_Ein': { name: 'Dachterrasse', nr: 6, left: '0_userdata.0.Garten.Dachterrasse_Restzeit', }, }; on ({ id: Object.keys(ventile), change: 'ne' }, async (obj) => { const ventil = ventile[obj.id]; const isOn = obj.state.val; const durationStateId = `${root}${ventil.nr}.duration_value`; console.log(`Schalte Ventil ${ventil.name} ein.`); const min = parseInt(getState('0_userdata.0.Garten.Einschalten_min').val); const s = min * 60; if (isOn) { const duration_value = getState(durationStateId).val; let i = 1; while (duration_value == null || duration_value == "null") { log(`Starte Bewässerung ${ventil.name}. ${i}-ter Versuch...`); setState(durationStateId, String(s), true); await sleep(10000); i += 1; } } else { setState(durationStateId, 'STOP_UNTIL_NEXT_TASK', true); log(`Stoppe Bewässerung ${ventil.name}`); } });
(so richtig verstehe ich die Logik dahinter noch nicht. Nur im Forum programmiert - daher kein Anspruch auf Vollständigkeit)
-
Vielen Dank für Euren Input, werde es umsetzen.
Zurzeit macht der smartgarden Adapter aber Ärger und daher kann ich die Verbesserungen nicht überprüfen. Ich bekomme jetzt error 429 Rückmeldungen von der API, wahrscheinlich weil die while Schleife zu viele API Calls generiert hat...
-
-
@vippis sagte in "On" Subscripton: Funktionsaufruf mit Parameter:
Ich bekomme jetzt error 429
Heißt:
429 Too Many Requests
-
Ja genau, das habe ich auch schon herausgefunden. Weißt du wie man da rauskommt oder hilft nur warten?
Hab schon eine Anfrage an feedback@developer.husqvarnagroup.cloud gesendet
-
@vippis sagte in "On" Subscripton: Funktionsaufruf mit Parameter:
Weißt du wie man da rauskommt oder hilft nur warten?
Das weiß nur der Serverbetreiber. Normalerweise sind die Rate Limits für so eine API öffentlich dokumentiert. Gibt es da nix?
-
bei der Automower Connect API gilt:
Limits
The following limitations currently apply to the Automower Connect API:
Max 1 request per second and appKey.
Max 10 000 request per month and appKey.
Any additional requests above these limits will be throttled.https://developer.husqvarnagroup.cloud/apis/automower-connect-api?tab=readme
ist ggf. bei Gardena gleich/ähnlich.
-
On average one call every fifteen minutes.
700 requests per week.
10 requests per 10-second interval.
https://developer.husqvarnagroup.cloud/apis/gardena-smart-system-api?tab=readme
-
Wie könnte man effektiv die API calls monitoren, damit ich die Limits nicht reiße?
Die Calls sollen dann entsprechend delayed werden und eine Ausgabe erfolgen?
Ist das eher was für mein Anwenderskript oder für @jpgorganizer Adapter?
-
@vippis sagte in "On" Subscripton: Funktionsaufruf mit Parameter:
Wie könnte man effektiv die API calls monitoren, damit ich die Limits nicht reiße?
Die meisten APIs liefern in jedem Response auch die restlichen rateLimits mit. Dann weiß man schon, ob man noch Luft hat und wieviele Anfragen verbleiben.
Ist aber sehr individuell. Ich würde einfach mal einen Response genauer anschauen, ob etwas in die Richtung enthalten ist.
-
Ich hab mir unter https://developer.husqvarnagroup.cloud einen frischen API Key erzeugt und bekomme jetzt keinen error 429 mehr