NEWS
Adapter Paketverfolgung DHL, Briefe, Amazon, DPD,GLS,UPS,17T
-
@rene55 Du hast bei Amazon 2FA aktiviert, ein aktuellen code musst du beim ersten einloggen mit angeben.
Es müssen keine Pakete installiert werden.
Die Fehler bei der Briefankündigung können ignoriert werden -
@tombox Danke für die Fingerführung. Läuft, sogar mein für morgen angekündigte Amazon-Paket wird schon angezeigt. Auch nochmal von mir: Toller Adapter, super Arbeit.
-
@tombox
Hermes einzubauen dürfte vermutlich nicht funktionieren.
Dazu müsste ich irgendwie den Flux-Kompensator an den ioBroker fummeln:
-
UPS zickt noch etwas:
2022-02-21 20:55:03.692 - error: parcel.0 (4495) https://onlinetools.ups.com/mychoice/v1/shipments/details/AddressToken?loc=de_DE 2022-02-21 20:55:03.692 - error: parcel.0 (4495) TypeError [ERR_HTTP_INVALID_HEADER_VALUE]: Invalid value "undefined" for header "AuthenticationToken"
Oh, irgendwelche Troubles mit meinem PW... Da muss ich erstmal bei mir schauen...
Zickt doch nix:
2022-02-21 21:21:23.655 - info: parcel.0 (4698) Login to DHL 2022-02-21 21:21:24.404 - info: parcel.0 (4698) Login to DHL successful 2022-02-21 21:21:24.424 - info: parcel.0 (4698) Login to DPD 2022-02-21 21:21:26.057 - info: parcel.0 (4698) Login to DPD successful 2022-02-21 21:21:26.065 - info: parcel.0 (4698) Login to T17 User 2022-02-21 21:21:28.593 - info: parcel.0 (4698) Login to 17T successful 2022-02-21 21:21:28.601 - info: parcel.0 (4698) Login to Amazon 2022-02-21 21:21:32.240 - info: parcel.0 (4698) Login to Amazon successful 2022-02-21 21:21:32.249 - info: parcel.0 (4698) Login to GLS 2022-02-21 21:21:35.789 - info: parcel.0 (4698) Login to GLS successful 2022-02-21 21:21:35.797 - info: parcel.0 (4698) Login to UPS 2022-02-21 21:21:36.801 - info: parcel.0 (4698) Login to UPS successful 2022-02-21 21:21:43.721 - info: parcel.0 (4698) undefined is not a valid state value for id "parcel.0.17tuser.trackinginfo.json"
-
@thomas-braun
Hab noch eine weitere Meldung, zu UPS(denke ich):parcel.0 2022-02-21 21:49:12.261 error TypeError [ERR_HTTP_INVALID_HEADER_VALUE]: Invalid value "undefined" for header "addresstoken" parcel.0 2022-02-21 21:49:12.259 error https://onlinetools.ups.com/mychoice/v1/shipments/details/AddressToken?loc=de_DE parcel.0 2022-02-21 21:49:02.271 error TypeError: Cannot read property 'MYCEnrollmentSummary' of undefined
Siehe unterste Meldung
-
@tombox sagte in Adapter Paketverfolgung DHL, Briefe, Amazon, DPD,GLS,UPS,17T:
Amazon:
Login eingeben
Wenn nötig vorab ein OTP token aus der 2FA App eingeben.Ich habe da mal eine Frage
Wo bekomme ich denn den Token her? -
@tombox
Schön das du die optische Anpassung eingebaut hast!Kann man irgendwie verhindern, dass man beim Start des Adaptern immer eine Liste aller aktuellen und vergangenen Pakete bekommt?
Idealerweise würde man hier lediglich noch nicht zugestellte Pakete als Benachrichtigung erhalten.Was auch später noch klasse wäre, wäre eine Liste als Widget.
Ich verwende da meistens die von @liv-in-sky, die funktioniert super.//HIER WIRD PFAD UND FILENAME DEFINIERT const path = "/htmlexample.html"; //FIlenamen definieren const home ='vis.0' //wo soll das file im iobroker-file-system liegen ? (oder z.b auch iqontrol.meta) let braucheEinFile=false; // bei true wird ein file geschrieben let braucheEinVISWidget=true; // bei true wird ein html-tabelle in einen dp geschrieben - siehe nächste zeile let dpVIS=DPPath //WICHTIG wenn braucheEinVISWidget auf true gesetzt !! dp zusätzlich für VIS-HTML-Basic-Widget //--------------------------------------- //HIER DIE SPALTEN ANZAHL DEFINIEREN - jede Spalte einen Wert - in diesem Beispiel sind es 2 var htmlFeld1='Gerät'; // überschrift Tabellen Spalte1 var htmlFeld2='Wert'; // überschrift Tabellen Spalte2 //----------------------------------- //hier werden die styles für die tabelle definiert //ÜBERSCHRIFT ÜBER TABELLE let htmlUberschrift=true; // mit Überschrift über der tabelle const htmlFeldUeber='Stromkosten'; // Überschrift const htmlFarbUber="#2C7FB6"; // Farbe der Überschrift //MEHRERE TABELLEN NEBENEINANDER let mehrfachTabelle=Spalten; // bis zu 4 Tabellen werden nebeneinander geschrieben- verkürzt das Ganze, dafür etwas breiter - MÖGLICH 1,2,3,oder 4 !!! const htmlFarbZweiteTabelle="#42A6EA"; // Farbe der Überschrift bei jeder 2.ten Tabelle const htmlFarbTableColorUber="#2C7FB6"; // Überschrift in der tabelle - der einzelnen Spalten //GANZE TABELLE const htmlSchriftart="RobotoCondensed-Regular"; const htmlSchriftgroesse="13px"; //FELDER UND RAHMEN const htmlFarbFelderschrift="#DADFDA"; // SchriftFarbe der Felder const htmlFarbFelderschrift2="#E3FBE2"; // SchriftFarbe der Felder für jede 2te Tabelle const htmlFarbTableColorGradient1="#3F403F"; // Gradient - Hintergrund der Tabelle - Verlauffarbe const htmlFarbTableColorGradient2="#3F403F"; // Gradient - Hintergrund der Tabelle - ist dieser Wert gleich Gradient1 gibt es keinen verlauf const htmlFarbTableBorderColor="#2C7FB6"; // Farbe des Rahmen - is tdieser gleich den gradienten, sind die rahmen unsichtbar const htmlRahmenLinien=1; // Format für Rahmen(Gitter)linien 1=alle - 2=nur vertikal - 3= nur horizontal - 4=keine // HIER NICHTS ÄNDERN const htmlEnd= '</table></body>'; const htmlStart= '<!DOCTYPE html><html lang="de"><head><title>Vorlage</title><meta http-equiv="content-type" content="text/html; charset=utf-8"></head><body>'; const htmlUeber= "<p style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-weight: bold\">"+htmlFeldUeber+"</p>"; const htmlTabStyleCol= "<table bordercolor=\""+htmlFarbTableBorderColor+"\" border=\"3\" cellspacing=\"3\" cellpadding=\"3\" rules=\"cols\" style=\"color:"+htmlFarbFelderschrift+"; font-size:"+htmlSchriftgroesse+ "; font-family:"+htmlSchriftart+";background-image: linear-gradient(42deg,"+htmlFarbTableColorGradient2+","+htmlFarbTableColorGradient1+");\">"; const htmlTabStyleRow= "<table bordercolor=\""+htmlFarbTableBorderColor+"\" border=\"3\" cellspacing=\"3\" cellpadding=\"3\" rules=\"rows\" style=\"color:"+htmlFarbFelderschrift+"; font-size:"+htmlSchriftgroesse+ "; font-family:"+htmlSchriftart+";background-image: linear-gradient(42deg,"+htmlFarbTableColorGradient2+","+htmlFarbTableColorGradient1+");\">"; const htmlTabStyleAll= "<table bordercolor=\""+htmlFarbTableBorderColor+"\" border=\"3\" cellspacing=\"3\" cellpadding=\"3\" rules=\"all\" style=\"color:"+htmlFarbFelderschrift+"; font-size:"+htmlSchriftgroesse+ "; font-family:"+htmlSchriftart+";background-image: linear-gradient(42deg,"+htmlFarbTableColorGradient2+","+htmlFarbTableColorGradient1+");\">"; const htmlTabStyleNone= "<table bordercolor=\""+htmlFarbTableBorderColor+"\" border=\"3\" cellspacing=\"3\" cellpadding=\"3\" rules=\"none\" style=\"color:"+htmlFarbFelderschrift+"; font-size:"+htmlSchriftgroesse+ "; font-family:"+htmlSchriftart+";background-image: linear-gradient(42deg,"+htmlFarbTableColorGradient2+","+htmlFarbTableColorGradient1+");\">"; const htmlTabUeber1="<tr style=\"color:"+htmlFarbTableColorUber+"; font-weight: bold\">"; const htmlTabUeber3="</tr>"; ////NICHTS ÄNDERN - abhängig von den oben definierten _Spalten - in diesem Beispiel sind es 2 var htmlTabUeber2="<td align=center> "+htmlFeld1+" </td><td align=center> "+htmlFeld2+" </td>"; var htmlTabUeber2_1="<td align=center style=\"color:"+htmlFarbZweiteTabelle+"\"> "+htmlFeld1+" </td><td align=center style=\"color:"+htmlFarbZweiteTabelle+"\"> "+htmlFeld2+ " </td>"; //------------------------------------------------------ var htmlOut=""; function writeHTML(){ var htmlTabStyle; switch (+htmlRahmenLinien) { case 1: htmlTabStyle=htmlTabStyleAll; break; case 2: htmlTabStyle=htmlTabStyleCol; break; case 3: htmlTabStyle=htmlTabStyleRow; break; case 4: htmlTabStyle=htmlTabStyleNone; break; }; htmlOut=""; var counter=-1; var htmlTabUeber=""; switch (mehrfachTabelle) { case 1: htmlTabUeber=htmlTabUeber1+htmlTabUeber2+htmlTabUeber3; break; case 2: htmlTabUeber=htmlTabUeber1+htmlTabUeber2+htmlTabUeber2_1+htmlTabUeber3; break; case 3: htmlTabUeber=htmlTabUeber1+htmlTabUeber2+htmlTabUeber2_1+htmlTabUeber2+htmlTabUeber3; break; case 4: htmlTabUeber=htmlTabUeber1+htmlTabUeber2+htmlTabUeber2_1+htmlTabUeber2+htmlTabUeber2_1+htmlTabUeber3; break; }; //HIER SIND DIE § WERTE, DIE IN DER SCHLEIFE GEFILTERET WER%DEN - Jede spalte einen wert var val1; var val0; //------------------------------------------------------------ //SCHLEIFE FÜR DIE WERTE for (var x=0;x<myList.length;x++){ counter++; if(myList[x][1]!=null){ val0 = myList[x][0]; val1 = myList[x][1] //if (val1==false) {val1="❌"} else{val1="✅"} } //HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT - hat man oben 2 Felder definiert, braucht man hier 2 Werte switch (mehrfachTabelle) { case 1: htmlOut=htmlOut+"<tr><td> "+val0+" </td><td align=center> "+val1+" </td></tr>"; break; case 2: if(counter%2==0) {htmlOut = htmlOut+"<tr><td> "+val0+" </td><td align=center> "+val1+" </td>"; } else {htmlOut = htmlOut+"<td style=\"color:"+htmlFarbFelderschrift2+"\"> "+val0+" </td><td align=center style=\"color:"+htmlFarbFelderschrift2+"\"> "+val1+" </td></tr>";} break; case 3: if(counter%3==0 ) {htmlOut = htmlOut+"<tr><td> "+val0+" </td><td align=center> "+val1+" </td>"; } else { if(counter%3==1 ) { htmlOut = htmlOut+"<td style=\"color:"+htmlFarbFelderschrift2+"\"> "+val0+" </td><td align=center style=\"color:"+htmlFarbFelderschrift2+"\"> "+val1+" </td>";} else {htmlOut = htmlOut+"<td> "+val0+" </td><td align=center> "+val1+" </td></tr>";} } break; case 4: if(counter%4==0) {htmlOut = htmlOut+"<tr><td> "+val0+" </td><td align=center> "+val1+" </td>"; } else {if(counter%2==1 ) { htmlOut = htmlOut+"<td style=\"color:"+htmlFarbFelderschrift2+"\"> "+val0+" </td><td align=center style=\"color:"+htmlFarbFelderschrift2+"\"> "+val1+" </td>";} else {if(counter%2==1 && counter%4==3) { htmlOut= htmlOut+"<td style=\"color:"+htmlFarbFelderschrift2+"\"> "+val0+" </td><td align=center style=\"color:"+htmlFarbFelderschrift2+"\"> "+val1+" </td></tr>";} else {htmlOut = htmlOut = htmlOut+"<td> "+val0+" </td><td> "+val1+" </td>";}} } break; } //switch ende //--------------------------------------------- }; //Schleifen ende //Ausgabe über VIS html widget - tabelle in datenpunkt schreiben - html tabelle ohne html header und body var htmlOutVIS=""; htmlUberschrift ? htmlOutVIS=htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+"</table>" : htmlOutVIS=htmlTabStyle+htmlTabUeber+htmlOut+"</table>"; //log(htmlOutVIS); if (braucheEinVISWidget) setState(dpVIS, htmlOutVIS ); //mit oder ohne überschrift htmlUberschrift ? htmlOut=htmlStart+htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+htmlEnd : htmlOut=htmlStart+htmlTabStyle+htmlTabUeber+htmlOut+htmlEnd; //log(htmlOut); } // function ende //hier wird schleife gestartet und das file geschrieben //schedule("*/20 * * * * *", function () { writeHTML(); if (braucheEinFile) {writeFile(home, path ,htmlOut, function (error) { /* log('file written');*/ });} //});
-
@wszene Naja wenn du 2FA bei amazon aktiviert hast, hast du doch eine AuthApp aktiv wo du deine Token herbekommst oder wie kommst du an dein 2FA Token
@senger1985 Ich habe den check bei ups verbessert
@Christoph1337 Es ist eigentlich absicht damit man sieht das bei adapter start alles funktioniert. Eigentlich sollte der Adapter ja nie neugestartet werden außer jetzt wo die Updatefrequenz hoch ist
Gibt es denn ein Beispiel oder Adapter der so ein Widget eingebaut hat? -
@tombox sagte in Adapter Paketverfolgung DHL, Briefe, Amazon, DPD,GLS,UPS,17T:
@wszene Naja wenn du 2FA bei amazon aktiviert hast, hast du doch eine AuthApp aktiv wo du deine Token herbekommst oder wie kommst du an dein 2FA Token
Die Nummer bekommen wir per SMS zugesendet
-
@tombox
Vielleicht kann man den Versand ja beim Start optional machen. Einfach eine Checkbox im Adapter?Als Beispiel kann ich z.B. das hier nennen:
https://forum.iobroker.net/topic/28789/script-fürtabelle-der-batterie-zuständeEs gibt auch einige andere dieser Tabellen.
Ziemlich nützlich und prima für die einfache Darstellung in der VIS. -
Wie stellt ihr denn die Amazon Lieferungen in Vis dar, die sich aktuell in der Lieferung befinden, hab mittlerweile ne große Liste mit zugestellten Paketen aber die sich in Zustellung befinden gehen halt total unter. Hätte auf meiner Vis Infoseite gerne eine Benachrichtigung das sich ein Paket heute in Zustellung befindet, evtl. sogar Paketdienstleister übergreifend. Hat das jemand realisiert?
-
@xsev Genau das habe ich ja eben nachgefragt.
-
@christoph1337 Ja wobei ich persönlich jetzt keine Tabelle benötige, mir würde ein einfacher Datenpunkt genügen, mir dem ich mir eine dezente Info auf meinem Infoscreen schalten kann. Habs gern minimalistisch aber das ja Geschmackssache.
-
@xsev Könnte nochmal filtern die "In Zustellung" im status haben aber kenne nicht alle Texte aller anbieter
-
@tombox ja sowas wollte ich per Skript selber lösen aber bsp. Amazon hat durch die Lieferzeit, die in der Nachricht steht immer unterschiedliche Meldungen, daher konnte ich den Wert nicht triggern. Aber du hast da sicher deutlich mehr Möglichkeiten wie ich. Das wäre halt ideal wenn man bsp. ein Delivery-today hätte der dann auf true gestellt wird und das über den Status "in Zustellung" abgefragt werden könnte.
edit:
Ich hab aktuell nur DHL und Amazon in Betrieb, daher weiß ich auch nicht wie es bei den anderer Anbietern ist. DHL ist da mit den Infos die im Adapter geliefert werden genial. -
@tombox
Also im Moment sind die Telegrams der kompletten Pakete und Briefe bei jedem Neustart noch absolut ok. Ist da was geplant wenns ins latest geht ?
Grüßle -
@tombox
habe eben Amazon bei mir mit eingefügt und ich bekomme alle 15 Minuten per Telegram ALLE zugestellten Paketbenachrichtigungen zugesendet..... oder ich muss irgendwas vergessen haben zu installieren -
-
Ich habe es jetzt auch erfolgreich zum laufen gebracht
Hier mal meine Amazon VIS
-
@DJMarc75
@Rene55
Wiederholende Benachrichtigung von Amazon Paket bei den es auch ein DHL Status gibt wurde behoben.Alle Benachrichtigung bei Neustart muss erstmal so bleiben ich müsste mir sonst alle Benachrichtigungen merken und der Datenpunkt würde dann schnell sehr groß werden.
@Xsev Ich habe mal ein Datenpunkt inDelivery eingebaut