Method: Command::Mail#execute

Defined in:
lib/command/mail.rb

#execute(argv) ⇒ Object



41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
# File 'lib/command/mail.rb', line 41

def execute(argv)
  super
  send_all = false
  device = Narou.get_device
  database = Database.instance
  begin
    mailer = Mailer.create
  rescue Mailer::SettingNotFound
    install_mailer_setting
    return
  rescue Mailer::SettingUncompleteError => e
    error e.message
    exit Narou::EXIT_ERROR_CODE
  end
  if argv.empty?
    send_all = true
    database.each_key do |id|
      next if Narou.novel_frozen?(id)
      argv << id
    end
  end
  tagname_to_ids(argv)
  argv.each do |target|
    ebook_path = Narou.get_ebook_file_path(target, device ? device.ebook_file_ext : ".epub")
    unless ebook_path
      error "#{target} は存在しません" unless send_all
      next
    end
    data = Downloader.get_data_by_target(target)
    if send_all && !@options["force"]
      new_arrivals_date = data["new_arrivals_date"] || Time.now
      if data["last_mail_date"] && new_arrivals_date < data["last_mail_date"]
        next   # すでに送信済みなので送信しない
      end
    end
    unless File.exist?(ebook_path)
      error "まだファイル(#{File.basename(ebook_path)})が無いようです" unless send_all
      next
    end
    id = data["id"]
    title = data["title"]
    puts "<bold><green>ID:#{id} #{TermColorLight.escape(title)}</green></bold>".termcolor
    print "メールを送信しています"
    exit_mail = false
    mail_result = nil
    Thread.new do
      mail_result = mailer.send(File.basename(ebook_path), ebook_path)
      exit_mail = true
    end
    until exit_mail
      print "."
      sleep(0.5)
    end
    puts
    if mail_result
      puts File.basename(ebook_path) + " をメールで送信しました"
      database[id]["last_mail_date"] = Time.now
    else
      error "#{mailer.error_message}"
      exit Narou::EXIT_ERROR_CODE   # next しても次も失敗する可能性が高いのでここで終了
    end
  end
rescue Interrupt
  puts "メール送信を中断しました"
  exit Narou::EXIT_ERROR_CODE
ensure
  database.save_database if database
end