2014-05-28 11:50:49 +10:00
|
|
|
desc "Refresh all avatars (download missing gravatars, refresh system)"
|
|
|
|
task "avatars:refresh" => :environment do
|
|
|
|
i = 0
|
2014-06-26 19:50:16 +02:00
|
|
|
|
2014-05-28 11:50:49 +10:00
|
|
|
puts "Refreshing avatars"
|
|
|
|
puts
|
2014-06-26 19:50:16 +02:00
|
|
|
|
2014-05-28 11:50:49 +10:00
|
|
|
User.find_each do |user|
|
2019-04-14 14:26:12 +05:30
|
|
|
begin
|
|
|
|
user.refresh_avatar
|
|
|
|
user.user_avatar.update_gravatar!
|
2019-04-15 14:06:29 +05:30
|
|
|
rescue => e
|
|
|
|
puts "", "Failed to refresh avatar for #{user.username}", e, e.backtrace.join("\n")
|
2019-04-14 14:26:12 +05:30
|
|
|
end
|
2014-06-23 16:57:21 +02:00
|
|
|
putc "." if (i += 1) % 10 == 0
|
|
|
|
end
|
2014-06-26 19:50:16 +02:00
|
|
|
|
2014-06-23 16:57:21 +02:00
|
|
|
puts
|
|
|
|
end
|
|
|
|
|
|
|
|
desc "Clean up all avatar thumbnails (use this when the thumbnail algorithm changes)"
|
|
|
|
task "avatars:clean" => :environment do
|
|
|
|
i = 0
|
2014-06-26 19:50:16 +02:00
|
|
|
|
2014-06-23 16:57:21 +02:00
|
|
|
puts "Cleaning up avatar thumbnails"
|
|
|
|
puts
|
2014-06-25 23:06:15 +02:00
|
|
|
|
2016-05-20 15:12:25 +08:00
|
|
|
OptimizedImage.where("upload_id IN (SELECT custom_upload_id FROM user_avatars) OR
|
|
|
|
upload_id IN (SELECT gravatar_upload_id FROM user_avatars) OR
|
|
|
|
upload_id IN (SELECT uploaded_avatar_id FROM users)")
|
2017-07-28 10:20:09 +09:00
|
|
|
.find_each do |optimized_image|
|
2018-02-23 18:15:07 +05:30
|
|
|
begin
|
|
|
|
optimized_image.destroy!
|
2019-04-15 14:06:29 +05:30
|
|
|
rescue => e
|
2019-04-15 14:09:52 +05:30
|
|
|
puts "", "Failed to cleanup avatar (optimized_image_id: #{optimized_image.id}, optimized_image_url: #{optimized_image.url})", e, e.backtrace.join("\n")
|
2018-02-23 18:15:07 +05:30
|
|
|
end
|
2014-06-23 16:57:21 +02:00
|
|
|
putc "." if (i += 1) % 10 == 0
|
2014-05-28 11:50:49 +10:00
|
|
|
end
|
2014-06-26 19:50:16 +02:00
|
|
|
|
2014-05-28 11:50:49 +10:00
|
|
|
puts
|
|
|
|
end
|