Merge branch 'main' into glitch-soc/merge-upstream
Conflicts: - `app/views/admin/reports/show.html.haml`: Conflicts due to glitch-soc's theming system.
This commit is contained in:
		@@ -1,45 +0,0 @@
 | 
			
		||||
# frozen_string_literal: true
 | 
			
		||||
 | 
			
		||||
class Form::StatusBatch
 | 
			
		||||
  include ActiveModel::Model
 | 
			
		||||
  include AccountableConcern
 | 
			
		||||
 | 
			
		||||
  attr_accessor :status_ids, :action, :current_account
 | 
			
		||||
 | 
			
		||||
  def save
 | 
			
		||||
    case action
 | 
			
		||||
    when 'nsfw_on', 'nsfw_off'
 | 
			
		||||
      change_sensitive(action == 'nsfw_on')
 | 
			
		||||
    when 'delete'
 | 
			
		||||
      delete_statuses
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  private
 | 
			
		||||
 | 
			
		||||
  def change_sensitive(sensitive)
 | 
			
		||||
    media_attached_status_ids = MediaAttachment.where(status_id: status_ids).pluck(:status_id)
 | 
			
		||||
 | 
			
		||||
    ApplicationRecord.transaction do
 | 
			
		||||
      Status.where(id: media_attached_status_ids).reorder(nil).find_each do |status|
 | 
			
		||||
        status.update!(sensitive: sensitive)
 | 
			
		||||
        log_action :update, status
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    true
 | 
			
		||||
  rescue ActiveRecord::RecordInvalid
 | 
			
		||||
    false
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def delete_statuses
 | 
			
		||||
    Status.where(id: status_ids).reorder(nil).find_each do |status|
 | 
			
		||||
      status.discard
 | 
			
		||||
      RemovalWorker.perform_async(status.id, immediate: true)
 | 
			
		||||
      Tombstone.find_or_create_by(uri: status.uri, account: status.account, by_moderator: true)
 | 
			
		||||
      log_action :destroy, status
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    true
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
		Reference in New Issue
	
	Block a user