require "net/imap" require "mail" require "time" require 'base64' require 'fileutils' require 'yaml' require "logger" require "httparty" require "http_service/naviai" require 'openssl' module Client def logger @logger end # # imap_connection # # connect the app with imap server # def imap_connection(server, username, password) # connect to IMAP server imap = Net::IMAP.new server, ssl: true, certs: nil, verify: false Net::IMAP.debug = @net_imap_debug # http://ruby-doc.org/stdlib-2.1.5/libdoc/net/imap/rdoc/Net/IMAP.html#method-i-capability capabilities = imap.capability @logger.debug("imap capabilities: #{capabilities.join(',')}") if @debug if @client_type == 'local' unless capabilities.include? "IDLE" @logger.info "'IDLE' IMAP capability not available in server: #{server}" imap.disconnect exit end end # login imap.login username, password # return IMAP connection handler imap end # # retrieve_emails # # retrieve any mail from a folder, followin specified serach condition # for any mail retrieved call a specified block # def retrieve_emails(imap, search_condition, folder, &process_email_block) # examine will read email and sets flags unread # https://stackoverflow.com/questions/16516464/read-gmail-xoauth-mails-without-marking-it-read imap.examine folder message_ids = imap.search(search_condition) if @debug if message_ids.empty? @logger.debug "\nno messages found.\n" return else @logger.debug "\nProcessing #{message_ids.count} mails.\n" end end message_ids.each_with_index do |message_id, i| # fetch all the email contents data = imap.fetch(message_id, "RFC822") data.each do |d| msg = d.attr['RFC822'] # instantiate a Mail object to avoid further IMAP parameters nightmares mail = Mail.read_from_string msg # call the block with mail object as param process_email_block.call mail # mark as read if @mark_as_read imap.store(message_id, "+FLAGS", [:Seen]) end end end end def process_email(mail) meta = Hash.new custom_uid = (Time.now.to_f * 1000).to_s + "_" + mail.__id__.to_s invalid_to_email = mail.to.nil? || !mail.to.is_a?(Array) invalid_cc_email = mail.cc.nil? || !mail.cc.is_a?(Array) meta["from"] = mail.from.first unless mail.from.nil? meta["to"] = invalid_to_email ? mail.to : mail.to.join(";") meta["cc"] = mail.cc.join(";") unless invalid_cc_email meta["subject"] = mail.subject meta["date"] = mail.date.to_s if mail.multipart? for i in 0...mail.parts.length m = download(mail.parts[i], custom_uid) meta.merge!(m) unless m.nil? end else m = download(mail, custom_uid) meta.merge!(m) unless m.nil? end save(meta, "meta/#{custom_uid}") end def encrypt(data) Base64.encode64(data) end def depcrecated_encrypt(data) cipher = OpenSSL::Cipher::AES.new(256, :CFB) cipher.encrypt yml_config = config key_iv_exists = (yml_config['key'] && yml_config['iv']) ? (!yml_config['key'].empty? && !yml_config['iv'].empty? ) : false if key_iv_exists # this condition must be true for cloud version cipher.key = Base64.decode64(File.read(yml_config['key'])) cipher.iv = Base64.decode64(File.read(yml_config['iv'])) else cipher.key = key = cipher.random_key cipher.iv = iv = cipher.random_iv key_path, iv_path = save_aes_key_iv(key, iv) yml_config['key'] = key_path yml_config['iv'] = iv_path update_config(yml_config) end encrypted = cipher.update(data) Base64.encode64(encrypted) end def time_now Time.now.utc.iso8601(3) end def shutdown(imap) imap.idle_done imap.logout unless imap.disconnected? imap.disconnect @logger.info "#{$0} has ended (crowd applauds)" exit 0 end end