* 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
 |