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