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:
		
							parent
							
								
									865cb39e9b
								
							
						
					
					
						commit
						e17f9d5e1a
					
				|  | @ -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| | ||||||
|         account.avatar.reprocess! |         begin | ||||||
|         account.header.reprocess! |           account.avatar.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!' | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue