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 /lib/tasks | |
parent | 4e52b417b748446d58484815237c4502f28420cc (diff) | |
parent | aff6523ecd140ae585c646457b13b9c306ed68a2 (diff) |
Merge branch 'rails-3-develop' of ssh://git.mysociety.org/data/git/public/alaveteli into rails-3-develop
Diffstat (limited to 'lib/tasks')
-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 |