Node-REDを運用しているときに、異常が発生したときにメールで連絡する方法として、下記のライブラリーがあります。
node-red-node-email (node) – Node-RED
node-red-node-emailとは?
node-red-node-emailは、シンプルにNode-REDでメールの送受信をするためのライブラリです。
data:image/s3,"s3://crabby-images/dd6e6/dd6e68b5638a6c5c7896687dfeed44afc7fdcaa8" alt="UntitledImage.png UntitledImage"
Input Node
data:image/s3,"s3://crabby-images/69342/693423db0a7669ee87c630494b06d20b312c93b6" alt="UntitledImage.png UntitledImage"
IMAPまたはPOP3サーバからメールを取得し、まだ見ていない場合はメッセージとして転送します。
メール件名 | msg.topic |
---|---|
メール本文 | msg.payload (プレーンテキストのメールの場合) msg.html (text/htmlメールの場合) |
送信者 | msg.from |
日時 | msg.date |
ヘッダー | msg.header |
Output Node
msg.topicを件名
msg.payload 本文(htmlも可)。
msg.payloadがbinary bufferだとメールの添付ファイルになり、その場合、ファイル名は msg.filename で指定します。オプションで、本文に msg.description を追加することができます。
msg.attachments には nodemailer フォーマットの添付ファイルを 1 つ以上配列で指定します。
data:image/s3,"s3://crabby-images/44db0/44db025fbe36ed894de1911d544a270890fdcfb9" alt="UntitledImage.png UntitledImage"
このようなフローを作成。
data:image/s3,"s3://crabby-images/30729/307293afc7014fdedd993b1800b93ce4856d916e" alt="UntitledImage.png UntitledImage"
email Outputノードに必要事項を記載。
data:image/s3,"s3://crabby-images/2ad8e/2ad8e91ce9688c88e06fbd5a72fbce508315dfcc" alt="UntitledImage.png UntitledImage"
このようにタイムスタンプが送信されました。
メール送信内容をいじる
data:image/s3,"s3://crabby-images/789b7/789b7f60f817f983731f546c2ec1fa62538a8e46" alt="UntitledImage.png UntitledImage"
このようにtemplateノードを使用。
data:image/s3,"s3://crabby-images/02f8f/02f8f758afdaa9a016e580126ac173132d33ccc7" alt="UntitledImage.png UntitledImage"
中身はこのとおり。
data:image/s3,"s3://crabby-images/0aafc/0aafcd5805ae523b8da7bbb1816f70b4694f4762" alt="UntitledImage.png UntitledImage"
このように、変数をいれこむことができました。
data:image/s3,"s3://crabby-images/33dd7/33dd72d2832aca9ee329ef63ac217ff944c923fe" alt="UntitledImage.png UntitledImage"
Injectノードのmsg.topicにメール件名を入力して送信。
data:image/s3,"s3://crabby-images/5ceed/5ceed3f5e44f8fc82d2a9817f326a8ae763c4c32" alt="UntitledImage.png UntitledImage"
このように件名がはいり受信できました。
まとめ
Node-REDからメールの送信はこのライブラリーを使えばできそうです。
あとは、画像を送信する方法についても引き続き検証していきます。