* Move more tasks to tootctl - tootctl feeds build - tootctl feeds clear - tootctl accounts refresh Clean up exit codes and help messages * Move user modifying to tootctl * Improve user modification through CLI, rename commands add -> create mod -> modify del -> delete To remove ambiguity * Fix code style issues * Fix not being able to unset admin/mod role
		
			
				
	
	
		
			61 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| require_relative '../../config/boot'
 | |
| require_relative '../../config/environment'
 | |
| require_relative 'cli_helper'
 | |
| 
 | |
| module Mastodon
 | |
|   class MediaCLI < Thor
 | |
|     option :days, type: :numeric, default: 7
 | |
|     option :background, type: :boolean, default: false
 | |
|     option :verbose, type: :boolean, default: false
 | |
|     option :dry_run, type: :boolean, default: false
 | |
|     desc 'remove', 'Remove remote media files'
 | |
|     long_desc <<-DESC
 | |
|       Removes locally cached copies of media attachments from other servers.
 | |
| 
 | |
|       The --days option specifies how old media attachments have to be before
 | |
|       they are removed. It defaults to 7 days.
 | |
| 
 | |
|       With the --background option, instead of deleting the files sequentially,
 | |
|       they will be queued into Sidekiq and the command will exit as soon as
 | |
|       possible. In Sidekiq they will be processed with higher concurrency, but
 | |
|       it may impact other operations of the Mastodon server, and it may overload
 | |
|       the underlying file storage.
 | |
| 
 | |
|       With the --dry-run option, no work will be done.
 | |
| 
 | |
|       With the --verbose option, when media attachments are processed sequentially in the
 | |
|       foreground, the IDs of the media attachments will be printed.
 | |
|     DESC
 | |
|     def remove
 | |
|       time_ago  = options[:days].days.ago
 | |
|       queued    = 0
 | |
|       processed = 0
 | |
|       dry_run = options[:dry_run] ? '(DRY RUN)' : ''
 | |
| 
 | |
|       if options[:background]
 | |
|         MediaAttachment.where.not(remote_url: '').where.not(file_file_name: nil).where('created_at < ?', time_ago).select(:id).reorder(nil).find_in_batches do |media_attachments|
 | |
|           queued += media_attachments.size
 | |
|           Maintenance::UncacheMediaWorker.push_bulk(media_attachments.map(&:id)) unless options[:dry_run]
 | |
|         end
 | |
|       else
 | |
|         MediaAttachment.where.not(remote_url: '').where.not(file_file_name: nil).where('created_at < ?', time_ago).reorder(nil).find_in_batches do |media_attachments|
 | |
|           media_attachments.each do |m|
 | |
|             Maintenance::UncacheMediaWorker.new.perform(m) unless options[:dry_run]
 | |
|             options[:verbose] ? say(m.id) : say('.', :green, false)
 | |
|             processed += 1
 | |
|           end
 | |
|         end
 | |
|       end
 | |
| 
 | |
|       say
 | |
| 
 | |
|       if options[:background]
 | |
|         say("Scheduled the deletion of #{queued} media attachments #{dry_run}", :green, true)
 | |
|       else
 | |
|         say("Removed #{processed} media attachments #{dry_run}", :green, true)
 | |
|       end
 | |
|     end
 | |
|   end
 | |
| end
 |