diff options
| author | Mark Longair <mhl@pobox.com> | 2013-06-12 20:58:24 +0100 | 
|---|---|---|
| committer | Mark Longair <mhl@pobox.com> | 2013-06-12 20:58:24 +0100 | 
| commit | aff6523ecd140ae585c646457b13b9c306ed68a2 (patch) | |
| tree | d5f0f4e7833b4f5827f29dd8672c115e8caac4c4 /lib | |
| parent | 3e50311e30e304c8b399cf0b33c8b90fecc94626 (diff) | |
| parent | 87c2b318756fc4d84f42f47e5d22ce8982dcd56d (diff) | |
Merge branch 'hotfix/0.11.0.11' into rails-3-develop
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/tasks/temp.rake | 22 | 
1 files changed, 22 insertions, 0 deletions
| diff --git a/lib/tasks/temp.rake b/lib/tasks/temp.rake index 35ae442c7..fcabb23de 100644 --- a/lib/tasks/temp.rake +++ b/lib/tasks/temp.rake @@ -7,6 +7,28 @@ namespace :temp do          user.save! unless dryrun      end +    desc "Re-extract any missing cached attachments" +    task :reextract_missing_attachments, [:commit] => :environment do |t, args| +        dry_run = args.commit.nil? || args.commit.empty? +        total_messages = 0 +        messages_to_reparse = 0 +        IncomingMessage.find_each :include => :foi_attachments do |im| +            reparse = im.foi_attachments.any? { |fa| ! File.exists? fa.filepath } +            total_messages += 1 +            messages_to_reparse += 1 if reparse +            if total_messages % 1000 == 0 +                puts "Considered #{total_messages} received emails." +            end +            unless dry_run +                im.parse_raw_email! true if reparse +                sleep 2 +            end +        end +        message = dry_run ? "Would reparse" : "Reparsed" +        message += " #{messages_to_reparse} out of #{total_messages} received emails." +        puts message +    end +      desc 'Cleanup accounts with a space in the email address'      task :clean_up_emails_with_spaces => :environment do          dryrun = ENV['DRYRUN'] == '0' ? false : true | 
