On Mon, Oct 19, 2020 at 03:08:13PM +0800, Wu Fengguang wrote:
On Mon, Oct 19, 2020 at 02:57:27PM +0800, Luan Shengde wrote:
mail robot for email application
monitor mailbox check new added email file in new check new mail's subject return if unmatched subject call answerback-email check to apply uuid/account
Signed-off-by: Luan Shengde luanshengde2@huawei.com
container/mail-robot/mail-robot.rb | 43 ++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100755 container/mail-robot/mail-robot.rb
diff --git a/container/mail-robot/mail-robot.rb b/container/mail-robot/mail-robot.rb new file mode 100755 index 0000000..70b8b25 --- /dev/null +++ b/container/mail-robot/mail-robot.rb @@ -0,0 +1,43 @@ +#!/usr/bin/env ruby +# SPDX-License-Identifier: MulanPSL-2.0+ +# Copyright (c) 2020 Huawei Technologies Co., Ltd. All rights reserved. +# frozen_string_literal: true
+require 'json' +require 'yaml' +require 'listen' +require 'mail' +require 'fileutils' +require_relative 'answerback-email.rb'
+mail_inbox = '/srv/cci/Maildir/.compass-ci/new/' +mail_drafts = '/srv/cci/Maildir/.compass-ci/cur/'
Please combine the 2 variables into maildir. And use
$maildir/new $maildir/cur
below. It's how maildir is defined.
I got it
+def monitor_dir(mail_inbox, mail_drafts)
- listener = Listen.to(mail_inbox) do |_modified, added, _removed|
- unless added.empty?
unless => next if too many indent levels.
I got it
added.each do |mail_file|
begin
check_to_send_account(mail_file, mail_drafts)
rescue StandardError => e
puts e.message
puts e.backtrace
end
end
- end
- end
- listener.start
- sleep
+end
+def check_to_send_account(mail_file, mail_drafts)
- mail_content = Mail.read(mail_file)
What if the robot will handle one more kind of email? Then we should add one more function which accepts the mail_content instead of mail_file. So let's do such split now.
the mail robot just listen the mail dir for new email file. if you want to listen more than one mail directories, just use: listener = Listen.to(maildir1, maildir2)
- subject = mail_content.subject
- return unless subject =~ /apply account/i
Please use exact match like this
subject == 'apply account'
I got it
Thanks Luan Shengde
- assign_uuid = AssignUuid.new(mail_content)
- assign_uuid.send_account
- FileUtils.mv(mail_file, mail_drafts)
+end
+monitor_dir(mail_inbox, mail_drafts)
2.23.0