NEWS
Emails empfangen.
-
@salzer-michael sagte in Emails empfangen.:
Wollte das grad testen
Danke für s Anleitenleider bekomm ich im Javascript jetzt angezeigt
e
19:06:00.723 info javascript.0 (2602) script.js.common.störungsmailabruf.mailundtabelle: {'type':'no','textCode':'ALERT','source':'authentication'}hab aber nüscht geändert gegenüber mittag
Ideen ?Achso bekomm dadurch jetzt keine mails mehr angezeigt in vis
-
die tabelle braucht keine authentication - irgendwas mit deinem email passwort oder user stimmt wohl nicht mehr
-
hab neue e-mail angelegt
gmail machte problemewas sollte eigentlich bei dp "reception" angelegt werden ?
der bleibt mir leer ?bis auf meine alarmquittierung klappt das so weit.
bekomm derzeit noch nit hin das wenn "neue mail " da ist und die anrufe gestartet werden das mit nem quittieren die anrufe bende.für jeden denkanstoß dankbar wäre .
oder nach was könnt suchen im forum ? -
reception ist ein überbleibsel von einem anderen script - wird nicht aktualisiert !
was meinst du mit anrufe quittieren ? wo bzw wie willst du quittieren. bei einem neuen mail, kommt es zu einem anruf. den kannst du annehmen oder "wegdrücken" - dann kommt doch erst wieder ein anruf, wenn ein neues mail da ist
-
@liv-in-sky
hab ne schleife drinnen
neues mail
anruf und nachricht per telegram
max 10 wiederholungen wenn in der nacht nicht höre
quittieren wenns gehört wurde damit nicht noch x mal angerufen wirdso sollts funktionieren
Vielen lieben Dank für die Unterstützung
-
jetzt verstehe ich, du möchtest den call mit einem datenpunkt bestätigen (also von hand) - das problem bei dem blockly baustein mit dem anrufen ist, dass man kein feedback bekommt, ob der anruf angenommen wurde.
mit diesem baustein kann man auch direkt den apibot nutzen und bekommt dann ein feedback
damit kann man dann einfach ein script machen, welches automatisch die call-antwort erkennt. das script kann wahrscheinlich noch verbessert werden
- es versucht 10 mal anzurufen, wenn der call nicht beanrwortet wird
- wird der call angenommen oder "rejected" wird das script nicht weiter anrufen
- es prüft, dass zwischen den anrufen mind. 65 sek sind, da der bot sonst nicht anruft
script für import:
-
wenn du das script importierst,
- mußt du noch den datenpunkt für die mailanzahl definieren
- deinen usernamen im request blockly eingeben
- und definieren, was der anruf sagen soll
-
Hallo Forum,
das Script hier ist genau das, was ich gesucht habe! Leider komme ich nicht mehr weiter und benötige Hilfe:
Ich habe in der Instanz des Javascript-Adapters die folgenden npm-Pakete eingetragen:
Und dann ein Script angelegt, wie es hier im Thread zu finden ist:var mailobj = {val: { from: "", topic: "", text: "", } }; createState("Email.Reception",mailobj); createState("Email.from_address"); createState("Email.from_name"); createState("Email.mail_subject"); createState("Email.mail_text"); schedule("*/2 * * * *", function (obj) { var MailListener = require("mail-listener2"); var mailListener = new MailListener({ username: "meine Mailadresse", password: "mein Passwort", host: "mein Host", port: 993, // imap port tls: true, connTimeout: 10000, // Default by node-imap authTimeout: 5000, // Default by node-imap, debug: console.log, // Or your custom function with only one incoming argument. Default: null tlsOptions: { rejectUnauthorized: false }, mailbox: "INBOX", // mailbox to monitor searchFilter: ["UNSEEN", "FLAGGED"], // the search filter being used after an IDLE notification has been retrieved markSeen: false, // all fetched email willbe marked as seen and not fetched next time fetchUnreadOnStart: true, // use it only if you want to get all unread email on lib start. Default is `false`, mailParserOptions: {streamAttachments: false}, // options to be passed to mailParser lib. attachments: false, // download attachments as they are encountered to the project directory attachmentOptions: { directory: "attachments/" } // specify a download directory for attachments }); mailListener.start(); // start listening mailListener.on("server:connected", function(){console.log("imapconconnected");}); mailListener.on("server:disconnected", function(){console.log("imapDisconnected");}); mailListener.on("error", function(err){console.log(err);}); mailListener.on("mail", function(mail, seqno, attributes){ log(mail.from[0].address); log(mail.from[0].name); log(mail.subject); log( mail.text); console.log('Mailabsender: '+mail.from[0].address); console.log('Absendername: '+mail.from[0].name); console.log('Betreff: '+mail.subject); var mailobj = {val: { from: mail.from[0].name, topic: mail.subject, text: mail.text } }; setState("Email.Reception", mailobj); setState("Email.from_address", mail.from[0].address); setState("Email.from_name", mail.from[0].name); setState("Email.mail_subject", mail.subject); setState("Email.mail_text", mail.text); }); mailListener.on("attachment", function(attachment){console.log(attachment.path);}); setTimeout(function(){mailListener.stop();},20000); });
Das Script scheint grundsätzlich zu funktionieren, denn im Log-File erhalte ich die entsprechenden Meldungen:
Allerdings werden weder die console.log-Anweisungen in der obigen Funktion: mailListener.on("mail", function(mail, seqn, attributes){... ausgegeben, noch die Datenpunkte mit Werten befüllt - was natürlich logisch ist, wenn die Funktion nicht ausgeführt wird.
Ein Neustart von Adapter und Iobroker bringt leider nichts.
Könnte es evtl. mit der folgenden Meldung zusammen hängen:
Was ist zu tun?Danke Euch vorab!
-
So, wie es häufig zugeht: Wenn man jemand um Hilfe bittet, findet man das Problem oft doch selbst. Für alle die das gleiche Problem haben sollten:
Es scheint wohl mit dem Mailserver zusammenzuhängen. Nachdem ich im Script unter searchFilter "Flagged" entfernt habe, funktioniert es nun:
searchFilter: ["UNSEEN"], // the search filter being used after an IDLE notification has been retrieved
-
Hallo,
ich konnte das Script erfolgreich installieren. Leider funktioniert die Option nicht, dass eingelesene Emails nicht als gelesen markiert werden.
markSeen: false, // all fetched email will be marked as seen and not fetched next time
Dennoch werden die Emails im Postfach durch das Script als gelesen markiert. Woran könnte das liegen?
Bei dem Postfach handelt es sich um ein Apple iCloud Postfach. -
Ich habe einen Fehler im Log:
script.js.common.Automatisierung.ioBroker.Mail_listener: <= 'A1 NO [AUTHENTICATIONFAILED] Invalid credentials (Failure)'
Das Problem ist aber die Logindaten stimmen zu 100%
hat jemand eine Idee?
-
Tja, was soll ich sagen. Es liegt an Gmail. Es ist nicht möglich dieses Skript mit Gmail zu nutzen. Ein anderer Anbieter und es funktioniert auf Anhieb...
Danke trotzdem für die Hilfe.
-
ich bin mitttlerweile auf nodered umgestiegen, um emails zu lesen - mail-listener funktioniert bei mir auch nicht mehr richtig
-
@dragon Man kann auch mit Google gmail das Script nutzen. Man muss dann nur ein sogenanntes APP-Passwort nutzen. Mit dem normalen Google-Passwort klappt es nicht, da dort 2-Faktoren-Authentifizierung genutzt wird.
-
@liv-in-sky Gibt es da Infos oder eine Anleitung, wie ich sowas mit Nodered umsetzte, Mails zu lesen. Ich würde hier ganz gern auf Mails von Teams Accounts hören, damit ich dann in der VIS angezeigt bekomme, das Lehrer geschrieben haben. Bei mehr als einem Kind wirds schon schwierig, ich will ja nicht ständig die Accounts switchen um zu sehen ob jemand was geschrieben hat.
-
habe das vor kurzem gemacht: https://forum.iobroker.net/post/859755
evtl kannst du das mal importieren (in nodered) und für dich angleichen - ich lese nur bestimmte absender aus und brauche die subjects der mails - welche dann in einem json landen und in ener tabelle in der vis angezeigt werden
-
@mcu Danke für die Info. mal schauen ob ich dazu was finde...
-
-
@mcu super! vielen dank!
-
Kann mir jemand damit weiterhelfen???
EMails werden zwar abgerufen und im Datenpunkt angezeigt, aber es kommt zu diesem Error.
Habe versucht die NPM Module direkt zu installieren oder über die Java Instanz. Bei beiden Varianten ist es das gleiche Problem.host.iobroker 2022-10-22 10:40:34.202 error instance system.adapter.javascript.0 terminated with code 1 (JS_CONTROLLER_STOPPED) host.iobroker 2022-10-22 10:40:34.202 error Caught by controller[1]: at processImmediate (node:internal/timers:466:21) host.iobroker 2022-10-22 10:40:34.202 error Caught by controller[1]: at MailParser._process (/opt/iobroker/node_modules/iobroker.javascript/node_modules/mailparser/lib/mailparser.js:227:22) host.iobroker 2022-10-22 10:40:34.202 error Caught by controller[1]: at MailParser._processStateHeader (/opt/iobroker/node_modules/iobroker.javascript/node_modules/mailparser/lib/mailparser.js:309:61) host.iobroker 2022-10-22 10:40:34.201 error Caught by controller[1]: at MailParser._generateFileName (/opt/iobroker/node_modules/iobroker.javascript/node_modules/mailparser/lib/mailparser.js:1407:27) host.iobroker 2022-10-22 10:40:34.201 error Caught by controller[1]: TypeError: mime.extension is not a function javascript.0 2022-10-22 10:40:34.124 error TypeError: mime.extension is not a function at MailParser._generateFileName (/opt/iobroker/node_modules/iobroker.javascript/node_modules/mailparser/lib/mailparser.js:1407:27) at MailParser._processStateHeader (/opt/iobroker/node_modules/iobroker.javascript/node_modules/mailparser/lib/mailparser.js:309:61) at MailParser._process (/opt/iobroker/node_modules/iobroker.javascript/node_modules/mailparser/lib/mailparser.js:227:22) at processImmediate (node:internal/timers:466:21) javascript.0 2022-10-22 10:40:34.124 error Error: mime.extension is not a function javascript.0 2022-10-22 10:40:34.124 error An error happened which is most likely from one of your scripts, but the originating script could not be detected.