2014-05-27 21:50:49 -04:00
|
|
|
desc "Refresh all avatars (download missing gravatars, refresh system)"
|
|
|
|
task "avatars:refresh" => :environment do
|
|
|
|
i = 0
|
2014-06-26 13:50:16 -04:00
|
|
|
|
2014-05-27 21:50:49 -04:00
|
|
|
puts "Refreshing avatars"
|
|
|
|
puts
|
2014-06-26 13:50:16 -04:00
|
|
|
|
2014-05-27 21:50:49 -04:00
|
|
|
User.find_each do |user|
|
2019-04-14 04:56:12 -04:00
|
|
|
begin
|
|
|
|
user.refresh_avatar
|
|
|
|
user.user_avatar.update_gravatar!
|
2019-04-15 04:36:29 -04:00
|
|
|
rescue => e
|
|
|
|
puts "", "Failed to refresh avatar for #{user.username}", e, e.backtrace.join("\n")
|
2019-04-14 04:56:12 -04:00
|
|
|
end
|
2014-06-23 10:57:21 -04:00
|
|
|
putc "." if (i += 1) % 10 == 0
|
|
|
|
end
|
2014-06-26 13:50:16 -04:00
|
|
|
|
2014-06-23 10:57:21 -04: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 13:50:16 -04:00
|
|
|
|
2014-06-23 10:57:21 -04:00
|
|
|
puts "Cleaning up avatar thumbnails"
|
|
|
|
puts
|
2014-06-25 17:06:15 -04:00
|
|
|
|
2016-05-20 03:12:25 -04: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-27 21:20:09 -04:00
|
|
|
.find_each do |optimized_image|
|
2018-02-23 07:45:07 -05:00
|
|
|
begin
|
|
|
|
optimized_image.destroy!
|
2019-04-15 04:36:29 -04:00
|
|
|
rescue => e
|
2019-04-15 04:39:52 -04:00
|
|
|
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 07:45:07 -05:00
|
|
|
end
|
2014-06-23 10:57:21 -04:00
|
|
|
putc "." if (i += 1) % 10 == 0
|
2014-05-27 21:50:49 -04:00
|
|
|
end
|
2014-06-26 13:50:16 -04:00
|
|
|
|
2014-05-27 21:50:49 -04:00
|
|
|
puts
|
|
|
|
end
|