Pārlūkot izejas kodu

Add improved CLI interface for removing remote media (#8411)

./bin/tootctl media remove --days 7 --background

Make the old rake task point to it
master
Eugen Rochko pirms 5 gadiem
committed by GitHub
vecāks
revīzija
793eea2982
Šim parakstam datu bāzē netika atrasta zināma atslēga GPG atslēgas ID: 4AEE18F83AFDEB23
7 mainītis faili ar 68 papildinājumiem un 11 dzēšanām
  1. +1
    -1
      app/workers/maintenance/destroy_media_worker.rb
  2. +1
    -1
      app/workers/maintenance/redownload_account_media_worker.rb
  3. +1
    -1
      app/workers/maintenance/uncache_media_worker.rb
  4. +4
    -0
      bin/tootctl
  5. +11
    -0
      lib/cli.rb
  6. +47
    -0
      lib/mastodon/media_cli.rb
  7. +3
    -8
      lib/tasks/mastodon.rake

+ 1
- 1
app/workers/maintenance/destroy_media_worker.rb Parādīt failu

@@ -6,7 +6,7 @@ class Maintenance::DestroyMediaWorker
sidekiq_options queue: 'pull'

def perform(media_attachment_id)
media = MediaAttachment.find(media_attachment_id)
media = media_attachment_id.is_a?(MediaAttachment) ? media_attachment_id : MediaAttachment.find(media_attachment_id)
media.destroy
rescue ActiveRecord::RecordNotFound
true


+ 1
- 1
app/workers/maintenance/redownload_account_media_worker.rb Parādīt failu

@@ -6,7 +6,7 @@ class Maintenance::RedownloadAccountMediaWorker
sidekiq_options queue: 'pull', retry: false

def perform(account_id)
account = Account.find(account_id)
account = account_id.is_a?(Account) ? account_id : Account.find(account_id)
account.reset_avatar!
account.reset_header!
account.save


+ 1
- 1
app/workers/maintenance/uncache_media_worker.rb Parādīt failu

@@ -6,7 +6,7 @@ class Maintenance::UncacheMediaWorker
sidekiq_options queue: 'pull'

def perform(media_attachment_id)
media = MediaAttachment.find(media_attachment_id)
media = media_attachment_id.is_a?(MediaAttachment) ? media_attachment_id : MediaAttachment.find(media_attachment_id)

return if media.file.blank?



+ 4
- 0
bin/tootctl Parādīt failu

@@ -0,0 +1,4 @@
#!/usr/bin/env ruby
APP_PATH = File.expand_path('../config/application', __dir__)
require_relative '../lib/cli'
Mastodon::CLI.start(ARGV)

+ 11
- 0
lib/cli.rb Parādīt failu

@@ -0,0 +1,11 @@
# frozen_string_literal: true

require 'thor'
require_relative 'mastodon/media_cli'

module Mastodon
class CLI < Thor
desc 'media SUBCOMMAND ...ARGS', 'manage media files'
subcommand 'media', Mastodon::MediaCLI
end
end

+ 47
- 0
lib/mastodon/media_cli.rb Parādīt failu

@@ -0,0 +1,47 @@
# frozen_string_literal: true

require_relative '../../config/boot'
require_relative '../../config/environment'

# rubocop:disable Rails/Output

module Mastodon
class MediaCLI < Thor
option :days, type: :numeric, default: 7
option :background, 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.
DESC
def remove
time_ago = options[:days].days.ago
queued = 0

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|
if options[:background]
queued += media_attachments.size
Maintenance::UncacheMediaWorker.push_bulk(media_attachments.map(&:id))
else
media_attachments.each do |m|
Maintenance::UncacheMediaWorker.new.perform(m)
print '.'
end
end
end

puts
puts "Scheduled the deletion of #{queued} media attachments" if options[:background]
end
end
end

# rubocop:enable Rails/Output

+ 3
- 8
lib/tasks/mastodon.rake Parādīt failu

@@ -512,14 +512,9 @@ namespace :mastodon do

desc 'Remove cached remote media attachments that are older than NUM_DAYS. By default 7 (week)'
task remove_remote: :environment do
time_ago = ENV.fetch('NUM_DAYS') { 7 }.to_i.days.ago
nb_media_attachments = 0

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|
nb_media_attachments += media_attachments.length
Maintenance::UncacheMediaWorker.push_bulk(media_attachments.map(&:id))
end
puts "Scheduled the deletion of #{nb_media_attachments} media attachments"
require_relative '../mastodon/media_cli'
cli = Mastodon::MediaCLI.new([], days: ENV['NUM_DAYS'] || 7)
cli.invoke(:remove)
end

desc 'Set unknown attachment type for remote-only attachments'


Notiek ielāde…
Atcelt
Saglabāt