NEWS
Hilfe bei der Script erstellung
-
super das es letztendlich doch geklappt hat.
-
@oliverio
Moin Moin,
Ich bin zwischendurch noch ein bisschen am probieren den status vom pager abzurufen.
ich hänge grad wieder bei einem problem. ich lasse mir einen datenpunkt schreiben der so aussieht"46b61d10-10c3-11ec-8787-7dd1f95191be"
ich möchte das die " am anfang und ende nicht mit in den datenpunkt geschrieben werden. wie bekomme ich das hin?
hab schon so einiges probiert, aber nichts hat bisher funktioniert.
hier mal eins von meinen versuchensetState("0_userdata.0.E-Message.E-Message-TrackingID", trid).val.replace('"');
-
@t0bit3ch sagte in Hilfe bei der Script erstellung:
@oliverio
Moin Moin,
Ich bin zwischendurch noch ein bisschen am probieren den status vom pager abzurufen.
ich hänge grad wieder bei einem problem. ich lasse mir einen datenpunkt schreiben der so aussieht"46b61d10-10c3-11ec-8787-7dd1f95191be"
ich möchte das die " am anfang und ende nicht mit in den datenpunkt geschrieben werden. wie bekomme ich das hin?
hab schon so einiges probiert, aber nichts hat bisher funktioniert.
hier mal eins von meinen versuchensetState("0_userdata.0.E-Message.E-Message-TrackingID", trid).val.replace('"');
hab es hinbekommen
so langsam verstehe ich das JS
-
@t0bit3ch
Das gequotete Beispiel sieht aber nicht aus als wenns funktionieren würde. -
@ticaki sagte in Hilfe bei der Script erstellung:
@t0bit3ch
Das gequotete Beispiel sieht aber nicht aus als wenns funktionieren würde.hatte das funktionierende beispiel wohl vergessen
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);
-
@t0bit3ch sagte in Hilfe bei der Script erstellung:
@ticaki sagte in Hilfe bei der Script erstellung:
@t0bit3ch
Das gequotete Beispiel sieht aber nicht aus als wenns funktionieren würde.hatte das funktionierende beispiel wohl vergessen
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);
Eigentor! Du hast dir die Hochkommas selbst reingebastelt, durch das nicht notwendige JSON.stringify(). das hier reicht völlig
let trid=response.data.data.trackingId; setState("0_userdata.0.E-Message.E-Message-TrackingID", trid);
-
@fastfoot
Danke für den Tipp. Werde es morgen mal versuchenMan lernt nie aus
-
setState("0_userdata.0.E-Message.E-Message-TrackingID", response.data.data.trackingId);
-
@ticaki sagte in Hilfe bei der Script erstellung:
setState("0_userdata.0.E-Message.E-Message-TrackingID", response.data.data.trackingId);
klar doch, ich halte es aber für einen Anfänger für besser das aufzusplitten. Dadurch ist es besser nachvollziehbar was da passiert. Der kürzeste Code ist halt nicht immer der Beste...
-
-
@t0bit3ch
Let ist wie var und deklariert eine variable.
let wurde mit ES6 (da wurde javascript vom syntax etwas modernisiert) eingeführt und hat leichte abweichungen zu var (speziell zu hoisting und scope behandlung).
aber als anfänger kannst du das erst mal genau so wie var verwenden.https://developer.mozilla.org/de/docs/Web/JavaScript/Reference/Statements/let
-
@oliverio
okay danke.
den Link werde ich mir übers wochenende mal genauer angucken -
@OliverIO
@ticaki
@fastfoot
@HomoranGuten Abend Profis,
ich benötige nochmal eure hilfe.
var axios = require('axios'); var trid = "0_userdata.0.E-Message.E-Message-TrackingID"; var token = "0_userdata.0.E-Message.E-Message-Token"; var data = ''; var config = { method: 'get', url: 'https://api.emessage.de/rs/eGetMessages/External/' + getState(trid).val , headers: { 'Authorization': 'Bearer ' + getState(token).val, }, data : data }; axios(config) .then(function (response) { var recipients = JSON.stringify(response.data.data.recipients); setState("0_userdata.0.E-Message_Response.Recipients", recipients, true); }) .catch(function (error) { console.log(error); });
wie bekomme ich es hin das mir die zurück gelieferten daten sortiert in datenpunkte geschrieben werden?
hiermit
setState("0_userdata.0.E-Message_Response.Recipients", recipients, true);
bekomme ich folgende ausgabe
[{"externalRecipient":"2W:123456","identifier":"123456","service":"2wayS","numberOfRecipients":"1","status":[{"answer":"01","answerNo":"1","devices":[{"deviceName":"Testpager","deviceSerial":"S0ABC123456789"}]}]}]
brauche es für die weitere verarbeitung so
datenpunkt0.wert1 = wert von identifer (123456) datenpunkt0.wert2 = wert von service (2wayS) datenpunkt0.wert3 = wert von answer (01) usw.
ich bin am verzweifeln
-
@t0bit3ch sagte in Hilfe bei der Script erstellung:
ich bin am verzweifeln
log(recipients[0].identifier) log(recipients[0].service) log(recipients[0].status[0].answer)
-
@fastfoot
was haben die [0] zu bedeuten?
Was ist denn der Unterschied zuJSON.stringify(response.data.data.recipients)
-
@fastfoot
Werde es morgen mal direkt probieren. -
@t0bit3ch sagte in Hilfe bei der Script erstellung:
@fastfoot
was haben die [0] zu bedeuten?
Was ist denn der Unterschied zuJSON.stringify(response.data.data.recipients)
in der Antwort sind Arrays enthalten, 0 spricht das erste Element an. Es gibt auch jeweils nur ein Element in Deinem Beispiel
Da ist kein Unterschied, das sind ganz verschiedene Dinge. JSON.stringify() erzeugt aus einem Objekt einen String. mein Beispiel zerlegt das Objekt in seine Einzelteile, weshalb du auch das JSON.stringify() weglassen musst.
Du musst dir die Struktur des JSON(=Ergebnis) mit zB einem Onlineviewer anschauen
var recipients = response.data.data.recipients; setState(id, recipients[0].identifier); . . .
-
danke für die tolle erklärung. hat funktioniert
-
bekommt man es noch hin das, dass script alle 5 sek. überprüft ob sich die werte geändert haben?
habe es jetzt mit blockly gelöst indem ich das script alle 5 sek. aktiviere und deaktiviere, aber das ist nicht die schönste methode.var axios = require('axios'); var trid = "0_userdata.0.E-Message.E-Message-TrackingID"; var token = "0_userdata.0.E-Message.E-Message-Token"; var data = ''; var config = { method: 'get', url: 'https://api.emessage.de/rs/eGetMessages/External/' + getState(trid).val , headers: { 'Authorization': 'Bearer ' + getState(token).val, }, data : data }; axios(config) .then(function (response) { var recipients = response.data.data.recipients; setState("0_userdata.0.E-Message_Response.QuittierungCode", recipients[0].status[0].answer, true); console.log('Rueckmeldung: ' + recipients[0].status[0].answer) // setState("0_userdata.0.E-Message_Response.Identifer", recipients[0].identifier, true); console.log('PagerRufnummer: ' + recipients[0].identifier) // setState("0_userdata.0.E-Message_Response.Service", recipients[0].service, true); console.log('ServiceTyp: ' + recipients[0].service) // setState("0_userdata.0.E-Message_Response.PagerName", recipients[0].status[0].devices[0].deviceName, true); console.log('PagerName: ' + recipients[0].status[0].devices[0].deviceName) // setState("0_userdata.0.E-Message_Response.PagerSerial", recipients[0].status[0].devices[0].deviceSerial, true); console.log('Seriennummer: ' + recipients[0].status[0].devices[0].deviceSerial) }) .catch(function (error) { console.log(error); });
-
Technisch ganz einfach: Den entscheidenden Aufruf des Skripts in einen Zeitplan kapseln, der alle 5 sekunden aktiv wird.
shedule("*/5 * * * * *", function() { axios(config).then(function (response) {... }).catch(function(error) { console.log(error); }); });
Da wo die ... stehen muss natürlich die der gleiche code stehen wie in dem Beispiel oben.
Allerdings bedeutet das das du alle 5 Sekunden eine externe Abfrage stellst - 17280 pro Tag.
Da solltest du bei dem Provider der API mal nachschauen was es für Grenzen für die Abfrage gibt.
A.