Sha256: 1147c9827dcab97aa0b4231df928fb03445ae40bd970727e4069d2b95f3ac9a4

Contents?: true

Size: 924 Bytes

Versions: 6

Compression:

Stored size: 924 Bytes

Contents

require "imap/backup/logger"

module Imap; end

module Imap::Backup
  class Migrator
    attr_reader :folder
    attr_reader :reset
    attr_reader :serializer

    def initialize(serializer, folder, reset: false)
      @folder = folder
      @reset = reset
      @serializer = serializer
    end

    def run
      count = serializer.uids.count
      folder.create
      folder.clear if reset

      Logger.logger.debug "[#{folder.name}] #{count} to migrate"
      serializer.each_message(serializer.uids).with_index do |message, i|
        next if message.nil?

        log_prefix = "[#{folder.name}] uid: #{message.uid} (#{i + 1}/#{count}) -"
        Logger.logger.debug(
          "#{log_prefix} #{message.body.size} bytes"
        )

        begin
          folder.append(message)
        rescue StandardError => e
          Logger.logger.warn "#{log_prefix} append error: #{e}"
        end
      end
    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
imap-backup-14.4.1 lib/imap/backup/migrator.rb
imap-backup-14.4.0 lib/imap/backup/migrator.rb
imap-backup-14.3.0 lib/imap/backup/migrator.rb
imap-backup-14.2.0 lib/imap/backup/migrator.rb
imap-backup-14.1.1 lib/imap/backup/migrator.rb
imap-backup-14.1.0 lib/imap/backup/migrator.rb