Unite all mandatory rake tasks in mastodon:daily (#1887)

* Unite all mandatory rake tasks in mastodon:daily
Add mastodon:media:remove_remote task
Make mastodon:maintenance:add_static_avatars more resilient to exceptions

* Fix typo in task description
This commit is contained in:
Eugen 2017-04-16 12:53:58 +02:00 committed by GitHub
parent 865cb39e9b
commit e17f9d5e1a
1 changed files with 29 additions and 6 deletions

View File

@ -1,6 +1,16 @@
# frozen_string_literal: true # frozen_string_literal: true
namespace :mastodon do namespace :mastodon do
desc 'Execute daily tasks'
task :daily do
Rake::Task['mastodon:feeds:clear'].invoke
Rake::Task['mastodon:media:clear'].invoke
Rake::Task['mastodon:users:clear'].invoke
Rake::Task['mastodon:push:refresh'].invoke
end
desc 'Turn a user into an admin, identified by the USERNAME environment variable'
task make_admin: :environment do task make_admin: :environment do
include RoutingHelper include RoutingHelper
@ -13,12 +23,13 @@ namespace :mastodon do
desc 'Manually confirms a user with associated user email address stored in USER_EMAIL environment variable.' desc 'Manually confirms a user with associated user email address stored in USER_EMAIL environment variable.'
task confirm_email: :environment do task confirm_email: :environment do
email = ENV.fetch('USER_EMAIL') email = ENV.fetch('USER_EMAIL')
user = User.where(email: email).first user = User.find_by(email: email)
if user if user
user.update(confirmed_at: Time.now.utc) user.update(confirmed_at: Time.now.utc)
puts "User #{email} confirmed." puts "#{email} confirmed"
else else
abort "User #{email} not found." abort "#{email} not found"
end end
end end
@ -32,6 +43,13 @@ namespace :mastodon do
task remove_silenced: :environment do task remove_silenced: :environment do
MediaAttachment.where(account: Account.silenced).find_each(&:destroy) MediaAttachment.where(account: Account.silenced).find_each(&:destroy)
end end
desc 'Remove cached remote media attachments that are older than a week'
task remove_remote: :environment do
MediaAttachment.where.not(remote_url: '').where('created_at < ?', 1.week.ago).find_each do |media|
media.file.destroy
end
end
end end
namespace :push do namespace :push do
@ -60,7 +78,7 @@ namespace :mastodon do
end end
end end
desc 'Clears all timelines so that they would be regenerated on next hit' desc 'Clears all timelines'
task clear_all: :environment do task clear_all: :environment do
Redis.current.keys('feed:*').each { |key| Redis.current.del(key) } Redis.current.keys('feed:*').each { |key| Redis.current.del(key) }
end end
@ -126,8 +144,13 @@ namespace :mastodon do
Rails.logger.debug 'Generating static avatars/headers for GIF ones...' Rails.logger.debug 'Generating static avatars/headers for GIF ones...'
Account.unscoped.where(avatar_content_type: 'image/gif').or(Account.unscoped.where(header_content_type: 'image/gif')).find_each do |account| Account.unscoped.where(avatar_content_type: 'image/gif').or(Account.unscoped.where(header_content_type: 'image/gif')).find_each do |account|
begin
account.avatar.reprocess! account.avatar.reprocess!
account.header.reprocess! account.header.reprocess!
rescue StandardError => e
Rails.logger.error "Error while generating static avatars/headers for account #{account.id}: #{e}"
next
end
end end
Rails.logger.debug 'Done!' Rails.logger.debug 'Done!'