diff options
| author | Louise Crow <louise.crow@gmail.com> | 2013-06-12 13:08:04 -0700 | 
|---|---|---|
| committer | Louise Crow <louise.crow@gmail.com> | 2013-06-12 13:08:04 -0700 | 
| commit | d0e7b8e97015b0743ff973475ac35e788be385a5 (patch) | |
| tree | f94d8e1560e1993b4cf71e5852b322c65bae1e91 | |
| parent | 4e52b417b748446d58484815237c4502f28420cc (diff) | |
| parent | aff6523ecd140ae585c646457b13b9c306ed68a2 (diff) | |
Merge branch 'rails-3-develop' of ssh://git.mysociety.org/data/git/public/alaveteli into rails-3-develop
| -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 | 
