Sha256: 38abf1bd8886f4384f4fd49ba5aec6ecd1074c0dbeb27050174c6ef4a5ba3497

Contents?: true

Size: 1.13 KB

Versions: 5

Compression:

Stored size: 1.13 KB

Contents

module Imap::Backup
  class Serializer::Appender
    attr_reader :imap
    attr_reader :folder
    attr_reader :mbox

    def initialize(folder:, imap:, mbox:)
      @folder = folder
      @imap = imap
      @mbox = mbox
    end

    def run(uid:, message:)
      raise "Can't add messages without uid_validity" if !imap.uid_validity

      uid = uid.to_i
      if imap.include?(uid)
        Logger.logger.debug(
          "[#{folder}] message #{uid} already downloaded - skipping"
        )
        return
      end

      do_append uid, message
    end

    private

    def do_append(uid, message)
      mboxrd_message = Email::Mboxrd::Message.new(message)
      initial = mbox.length || 0
      mbox_appended = false
      begin
        mbox.append mboxrd_message.to_serialized
        mbox_appended = true
        imap.append uid
      rescue StandardError => e
        mbox.rewind(initial) if mbox_appended

        message = <<-ERROR.gsub(/^\s*/m, "")
          [#{folder}] failed to append message #{uid}:
          #{message}. #{e}:
          #{e.backtrace.join("\n")}"
        ERROR
        Logger.logger.warn message
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
imap-backup-6.3.0 lib/imap/backup/serializer/appender.rb
imap-backup-6.2.1 lib/imap/backup/serializer/appender.rb
imap-backup-6.1.0 lib/imap/backup/serializer/appender.rb
imap-backup-6.0.1 lib/imap/backup/serializer/appender.rb
imap-backup-6.0.0 lib/imap/backup/serializer/appender.rb