NEWS
Hilfe bei der Script erstellung
-
@t0bit3ch
Du müsstest zumindest kleine Syntaxfehler selbst beheben. shedule - ein Schreibfehler es ist schedule und bei meinem Beispiel setIntervall ist setInterval ebenfalls ein Schreibfehler der ohne Editor halt mal vorkommt. Die sind meist unterstrichen, was nicht heißt das alles unterstrichene ein Fehler ist.in deinem Beispiel code fehlt auch ein weiteres:
});
am Ende
hier siehst du die ioBroker Funktionen: https://github.com/ioBroker/ioBroker.javascript/blob/master/docs/en/javascript.mdAußerdem hat der Adapter zumindest bei mir den Bug das er mir die letzten 3-5 Zeilen nicht anzeigt und ich erstmal ganz ans ende mit den Cursortasten gehe und ein paar Leerzeilen einfüge.
-
@ticaki
sorry für die späte rückmeldung. erstmal danke für deine hilfe, leider bin ich mit dem javascript noch nicht so ganz vertraut.
habe mir übers wochenende aber schon einiges an lektüre durchgelesen. jetzt wo ich den tip mit den schreibfehler bekommen habe hatte ich gesehen das es im code unterstrichen war. hab ich wohl vor lauter code übersehen.habe den code jetzt mit
setIntervall(function() { axios(config).then(function (response) {... }).catch(function(error) { console.log(error); }); }, 5 * 1000);
am laufen.
vielen dank euch nochmal für die unterstützung, ihr seid klasse.
-
Guten Abend Profis,
Ich habe folgendes Problem welches schnellstmöglich gelöst werden muss da ich leider keine Alarme mehr bekomme.
Heute hat mein ioBroker ein Update gemacht und jetzt läuft meine Alarmierung nicht mehr.hier mein bis heute vor dem Update funktionierendes Skript
const axios = require('axios'); var alarmmeldung_ml = "0_userdata.0.Alarmmeldungen.Alarmierungstext_Variable"; console.log(getState("0_userdata.0.E-Message_Data.E-Message-TrackingID").val); function auth() { axios.post('https://api.emessage.de/auth/login',{ username: '******', //* E*Message Benutzername */ password: '*******' //* E*Message Kennwort */ },{ headers: { 'Authorization': 'Basic Og==', 'Content-Type': 'application/json', } }).then(function (response) { if (response.status==200) { var token = response.data.data.jwt; setState("0_userdata.0.E-Message_Data.E-Message-Token", response.data.data.jwt, true); sendMessage(token) } }) .catch(function (error) { console.log(error); }); } function sendMessage(token) { axios.post('https://api.emessage.de/rs/eSendMessages',{ "messageText": getState(alarmmeldung_ml).val, //* Pocsag Nachricht an Pager */ //* bei mir durch einen Datenpunkt ersetzt */ "recipients": [ { "serviceName": "2wayS", //* Alarmierungstyp */ //* eCityruf - eBos - 2wayS */ eCityruf */ "identifier": "******" //* E*Message Funkrufnummer */ } ] },{ headers: { 'Content-Type': 'application/json', 'Authorization': 'Bearer ' + token, } }).then(function (response) { if (response.status==200) { setState("0_userdata.0.E-Message_Data.E-Message-TrackingID", response.data.data.trackingId, true); // var recipients = JSON.stringify(response.data.data.recipients); setState("0_userdata.0.E-Message_Data.E-Message-Recipients", recipients, true); // console.log (JSON.stringify(response.data.data)); //(tridneu); createEventlog("Alarmierung :" , getState(alarmmeldung_ml).val); // //var trid = JSON.stringify(response.data.data.trackingId); //var tridneu = trid.substr(1, trid.length - 2); //setState("0_userdata.0.E-Message.E-Message-TrackingID", tridneu); } }) .catch(function (error) { console.log(error); }); } auth();
nach dem Update kommt folgender fehler in der Log
javascript.0 (4430) script.js.Alarmierung_Pager_via_Wago.Pager_ausloesen.Pager_ausloesen: {'message':'Request failed with status code 401','name':'AxiosError','config':{'transitional':{'silentJSONParsing':true,'forcedJSONParsing':true,'clarifyTimeoutError':false},'transformRequest':[null],'transformResponse':[null],'timeout':0,'xsrfCookieName':'XSRF-TOKEN','xsrfHeaderName':'X-XSRF-TOKEN','maxContentLength':-1,'maxBodyLength':-1,'env':{},'headers':{'Accept':'application/json, text/plain, */*','Content-Type':'application/json','User-Agent':'axios/0.27.2','Content-Length':100},'method':'post','url':'https://api.emessage.de/rs/eSendMessages','data':'{\'messageText\':\'keine Aktive Meldung\',\'recipients\':[{\'serviceName\':\'2wayS\',\'identifier\':\'******\'}]}'},'code':'ERR_BAD_REQUEST','status':401}
Ich hoffe Ihr könnt mir bei dem Problem behilflich sein.
Gruß
-
@t0bit3ch hat das irgendwas mit dem bisherigen Thread zu tun?
wenn nein, bitte neuen Thread mit allen notwendigen Informationen aufmachenhttps://forum.iobroker.net/topic/51555/hinweise-für-gute-forenbeiträge/1
-
@t0bit3ch sagte in Hilfe bei der Script erstellung:
@Homoran ja hat es.
@T0biT3ch
Die Fehlermeldung ist etwas uneinheitlich-
Fehlermeldung 401 bedeutet eigentlich Unauthorized
https://developer.mozilla.org/de/docs/Web/HTTP/Status/401
Stimmen deine Anmeldeparameter? -
Weiterhin steht aber auch ERR_BAD_REQUEST (was auch der Fehlercode 400 sein kann)
Der steht dafür das der Server die Anfrage nicht verarbeiten kann, was auf eine evtl API-Änderung hinweisen kann -
als messageText steht auch "keine Aktive Meldung"
Was ja als normale Rückmeldung zu werten wäre.
Kannst du mal 1+2 Überprüfen ob es da Änderungen gab?
-
-
zu 1. Ja die Anmeldeparameter Stimmen, habe alles mit dem Programm Postman überprüft.
zu 2. Ich denke die API Parameter sind noch korrekt da ich Sie grad in Postman getestet habe und Sie heute Vormittag vor dem Update auch noch Funktioniert haben.
zu 3. der Text "keine Aktive Meldung" wir nach jedem Senden einer Alarmmeldung Automatisch in den Datenpunkt geschrieben und dient nur als Dummy
-
@t0bit3ch
und mit postman kannst du dich anmelden, den token abholen
und auch die daten abrufen? -
ja damit funktioniert es
-
@oliverio
Es wurde an den Programmen nichts verändert oder an den Einstellungen vom ioBroker. Es lief alles wunderbar und nach dem Update habe ich mich gewundert das kein Alarm mehr gesendet wird. habe auch versucht den JavaScript Adapter auf eine vorherige Version zurück zu setzen, aber ohne erfolg. -
dann muss es noch ein unterschied zwischen deinen aufbereiteten daten und den vom postman geben.
kann ich aber schlecht vergleichender abruf des tokens funktionier?
dann kann man den ersten teil schon mal abhaken.für den 2.Teil jede einzelne Information prüfen, ob sie in der richtigen form in das objekt wandert. am besten das objekt vor absenden einmal ausgeben. also das hier
{ "messageText": getState(alarmmeldung_ml).val, //* Pocsag Nachricht an Pager */ //* bei mir durch einen Datenpunkt ersetzt */ "recipients": [ { "serviceName": "2wayS", //* Alarmierungstyp */ //* eCityruf - eBos - 2wayS */ eCityruf */ "identifier": "******" //* E*Message Funkrufnummer */ } ] },{ headers: { 'Content-Type': 'application/json', 'Authorization': 'Bearer ' + token, } }
und dann auch mit den daten vom postman vergleichen, ob das genau identisch aufgebaut ist.
nicht das in der message zeichen enthalten sind die nicht erlaubt sind
oder nicht escapete Anführungsstriche -
hatte es nochmal im ioBroker mit diesen Scripten probiert
var axios = require('axios'); var data = JSON.stringify({ "username": "USERNAME", "password": "PASSWORD" }); var config = { method: 'post', url: 'https://api.emessage.de/auth/login', headers: { 'Authorization': 'Basic Og==', 'Content-Type': 'application/json' }, data : data }; axios(config) .then(function (response) { console.log(JSON.stringify(response.data)); }) .catch(function (error) { console.log(error); });
var axios = require('axios'); var data = JSON.stringify({ "messageText": "Testnachricht", "recipients": [ { "serviceName": "eCityruf", "identifier": "********" } ] }); var config = { method: 'post', url: 'https://api.emessage.de/rs/eSendMessages', headers: { 'Authorization': 'Bearer hgöfhogsioghösibnovdjuös<opriheourhweidjmanspkf<gob vuodsöahgbfdosuib0dsifohw84u0ü93rhfouisjhbgnvsoifedsökgpfingüer4984utißqü+äowfmägjhipoqehwfüouasdhgousgjohugurhgjiwehfgiwhfwquhbdcasukojgbhikgögloadfjasfghitiu<fbghkjybgvidfgdhfhgkjhlkzthgtzjklioölzfkdtjrhgstgfzhjui.k,mnjhbgvfadeshgjm', 'Content-Type': 'application/json' }, data : data }; axios(config) .then(function (response) { console.log(JSON.stringify(response.data)); }) .catch(function (error) { console.log(error); });
und damit hat es funktioniert. Ich kann in meinem Script keinen unterschied feststellen
-
Hatte jetzt nochmal dieses Script genommen
const axios = require('axios'); function auth() { axios.post('https://api.emessage.de/auth/login',{ username: 'USERNAME', password: 'PASSWORD' },{ headers: { 'Authorization': 'Basic Og==', 'Content-Type': 'application/json', } }).then(function (response) { if (response.status==200) { var token = response.data.data.jwt; sendMessage(token) } }) .catch(function (error) { console.log(error); }); } function sendMessage(token) { axios.post('https://api.emessage.de/rs/eSendMessages',{ "messageText": "Testnachricht", "recipients": [ { "serviceName": "eCityruf", "identifier": "********" } ] },{ headers: { 'Content-Type': 'application/json', 'Authorization': 'Bearer ' + token, } }) .catch(function (error) { console.log(error); }); } auth();
und bekomme diese Log
javascript.0 (4430) script.js.Alarmierung_Pager_via_Wago.Pager_ausloesen.Test: {'message':'Request failed with status code 401','name':'AxiosError','config':{'transitional':{'silentJSONParsing':true,'forcedJSONParsing':true,'clarifyTimeoutError':false},'transformRequest':[null],'transformResponse':[null],'timeout':0,'xsrfCookieName':'XSRF-TOKEN','xsrfHeaderName':'X-XSRF-TOKEN','maxContentLength':-1,'maxBodyLength':-1,'env':{},'headers':{'Accept':'application/json, text/plain, */*','Content-Type':'application/json','User-Agent':'axios/0.27.2','Content-Length':93},'method':'post','url':'https://api.emessage.de/rs/eSendMessages','data':'{\'messageText\':\'Testnachricht\',\'recipients\':[{\'serviceName\':\'2wayS\',\'identifier\':\'*****\'}]}'},'code':'ERR_BAD_REQUEST','status':401}
und der Pager bleibt still
-
@t0bit3ch
der unterschied ist, das du einmal das token fest vorgegeben hast und beim anderen life abfragstdann stimmt an der abfrage des tokens oder dem einfügen des tokens etwas nicht
-
und beim ersten wird data als JSON.stringify hinzugefügt
Beim 2. direkt als Objekt.
mach da auch mal ein stringify drum rumbeim 2. sind auch noch header dabei, beim ersten nicht
-
aber in diesem Script wird der Token doch in keinem Datenpunkt hinterlegt oder?
const axios = require('axios'); function auth() { axios.post('https://api.emessage.de/auth/login',{ username: 'USERNAME', password: 'PASSWORD' },{ headers: { 'Authorization': 'Basic Og==', 'Content-Type': 'application/json', } }).then(function (response) { if (response.status==200) { var token = response.data.data.jwt; sendMessage(token) } }) .catch(function (error) { console.log(error); }); } function sendMessage(token) { axios.post('https://api.emessage.de/rs/eSendMessages',{ "messageText": "Testnachricht", "recipients": [ { "serviceName": "eCityruf", "identifier": "********" } ] },{ headers: { 'Content-Type': 'application/json', 'Authorization': 'Bearer ' + token, } }) .catch(function (error) { console.log(error); }); } auth();
-
ich verstehe nur Bahnhof
-
habe es jetzt erstmal so gelöst damit zumindest wieder Alarmierungen kommen...
das Script zum Token holen
var axios = require('axios'); var data = JSON.stringify({ "username": "********", "password": "********" }); var config = { method: 'post', url: 'https://api.emessage.de/auth/login', headers: { 'Authorization': 'Basic Og==', 'Content-Type': 'application/json' }, data : data }; axios(config) .then(function (response) { console.log(JSON.stringify(response.data)); setState("0_userdata.0.E-Message_Data.E-Message-Token", response.data.data.jwt, true); }) .catch(function (error) { console.log(error); }); await wait(2000); setState("javascript.0.scriptEnabled.Alarmierung_Pager_via_Wago.Pager_ausloesen.abfrage"/*scriptEnabled.Alarmierung_Pager_via_Wago.Pager_ausloesen.abfrage*/, true); await wait(1000); setState("javascript.0.scriptEnabled.Alarmierung_Pager_via_Wago.Pager_ausloesen.Test"/*scriptEnabled.Alarmierung_Pager_via_Wago.Pager_ausloesen.Pager_ausloesen_CityRuf*/, false);
dann starte ich das Script zum Meldungen senden
var axios = require('axios'); var alarmmeldung_ml = "0_userdata.0.Alarmmeldungen.Alarmierungstext_Variable"; var token = "0_userdata.0.E-Message_Data.E-Message-Token"; var data = JSON.stringify({ "messageText": getState(alarmmeldung_ml).val, "recipients": [ { "serviceName": "2wayS", "identifier": "*******" } ] }); var config = { method: 'post', url: 'https://api.emessage.de/rs/eSendMessages', headers: { 'Authorization': 'Bearer ' + getState(token).val, 'Content-Type': 'application/json' }, data : data }; axios(config) .then(function (response) { if (response.status==200) { setState("0_userdata.0.E-Message_Data.E-Message-TrackingID", response.data.data.trackingId, true); // var recipients = JSON.stringify(response.data.data.recipients); setState("0_userdata.0.E-Message_Data.E-Message-Recipients", recipients, true); // console.log (JSON.stringify(response.data.data)); //(tridneu); createEventlog("Alarmierung :" , getState(alarmmeldung_ml).val); // //var trid = JSON.stringify(response.data.data.trackingId); //var tridneu = trid.substr(1, trid.length - 2); //setState("0_userdata.0.E-Message.E-Message-TrackingID", tridneu); } console.log(JSON.stringify(response.data)); }) .catch(function (error) { console.log(error); }); await wait(1000); setState("javascript.0.scriptEnabled.Alarmierung_Pager_via_Wago.Pager_ausloesen.abfrage"/*scriptEnabled.Alarmierung_Pager_via_Wago.Pager_ausloesen.abfrage*/, false);
Die abfrage der Quittung funktioniert weiter wie bisher.
vielleicht könnt ihr mir ja helfen die Scripte wieder zu vereinen. damit es so wie vor dem Update läuft.
Vielen dank und einen schönen Abend
-
sehr gut, du hast selber rausgefunden was ich mit meinem post gemeint habe, oder?
JSON.stringify mit den Messagedaten und
die header aus der Anfrage entfernt. -
Moin,
Ja nach langem lesen, vergleichen und probieren hab ich mir was zusammen gestrickt. Wirklich schlauer bin ich aber immer noch nicht. mir ist es schleierhaft warum das alte funktionierende script nicht mehr funktioniert
-
magst du hier einmal drüber gucken?
var axios = require('axios'); var data = JSON.stringify({ "username": "******", "password": "*******" }); var config = { method: 'post', url: 'https://api.emessage.de/auth/login', headers: { 'Authorization': 'Basic Og==', 'Content-Type': 'application/json' }, data : data }; axios(config) .then(function (response) { if (response.status==200) { var token = response.data.data.jwt; setState("0_userdata.0.E-Message_Data.E-Message-Token", response.data.data.jwt, true); sendMessage(token) console.log(JSON.stringify(response.data)); } }) .catch(function (error) { console.log(error); }); function sendMessage(token) { var data = JSON.stringify({ "messageText": "Test-Alarm", "recipients": [ { "serviceName": "2wayS", "identifier": "******" } ] }); var config = { method: 'post', url: 'https://api.emessage.de/rs/eSendMessages', headers: { 'Authorization': 'Bearer ' + getState(token).val, 'Content-Type': 'application/json' }, data : data }; axios(config) .then(function (response) { if (response.status==200) { setState("0_userdata.0.E-Message_Data.E-Message-TrackingID", response.data.data.trackingId, true); // var recipients = JSON.stringify(response.data.data.recipients); setState("0_userdata.0.E-Message_Data.E-Message-Recipients", recipients, true); // console.log (JSON.stringify(response.data.data)); //(tridneu); createEventlog("Alarmierung :" , getState(alarmmeldung_ml).val); // } console.log(JSON.stringify(response.data)); }) .catch(function (error) { console.log(error); });
bekomme diesen fehler in der log
error javascript.0 (1687) script.js.Ordner_1.Skript_1 compile failed: at script.js.Ordner_1.Skript_1:74
aber das script hat doch keine 74 zeilen