Add --skip-filled-timeline option to tootctl feed build to skip half-filled feeds (#33844)
				
					
				
			This commit is contained in:
		@@ -11,17 +11,21 @@ module Mastodon::CLI
 | 
			
		||||
    option :concurrency, type: :numeric, default: 5, aliases: [:c]
 | 
			
		||||
    option :verbose, type: :boolean, aliases: [:v]
 | 
			
		||||
    option :dry_run, type: :boolean, default: false
 | 
			
		||||
    option :skip_filled_timelines
 | 
			
		||||
    desc 'build [USERNAME]', 'Build home and list feeds for one or all users'
 | 
			
		||||
    long_desc <<-LONG_DESC
 | 
			
		||||
      Build home and list feeds that are stored in Redis from the database.
 | 
			
		||||
 | 
			
		||||
      With the --skip-filled-timelines, timelines which contain more than half
 | 
			
		||||
      the maximum number of posts will be skipped.
 | 
			
		||||
 | 
			
		||||
      With the --all option, all active users will be processed.
 | 
			
		||||
      Otherwise, a single user specified by USERNAME.
 | 
			
		||||
    LONG_DESC
 | 
			
		||||
    def build(username = nil)
 | 
			
		||||
      if options[:all] || username.nil?
 | 
			
		||||
        processed, = parallelize_with_progress(active_user_accounts) do |account|
 | 
			
		||||
          PrecomputeFeedService.new.call(account) unless dry_run?
 | 
			
		||||
          PrecomputeFeedService.new.call(account, skip_filled_timelines: options[:skip_filled_timelines]) unless dry_run?
 | 
			
		||||
        end
 | 
			
		||||
 | 
			
		||||
        say("Regenerated feeds for #{processed} accounts #{dry_run_mode_suffix}", :green, true)
 | 
			
		||||
@@ -30,7 +34,7 @@ module Mastodon::CLI
 | 
			
		||||
 | 
			
		||||
        fail_with_message 'No such account' if account.nil?
 | 
			
		||||
 | 
			
		||||
        PrecomputeFeedService.new.call(account) unless dry_run?
 | 
			
		||||
        PrecomputeFeedService.new.call(account, skip_filled_timelines: options[:skip_filled_timelines]) unless dry_run?
 | 
			
		||||
 | 
			
		||||
        say("OK #{dry_run_mode_suffix}", :green, true)
 | 
			
		||||
      else
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user