61 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| # == Schema Information
 | |
| #
 | |
| # Table name: bulk_imports
 | |
| #
 | |
| #  id                :bigint(8)        not null, primary key
 | |
| #  type              :integer          not null
 | |
| #  state             :integer          not null
 | |
| #  total_items       :integer          default(0), not null
 | |
| #  imported_items    :integer          default(0), not null
 | |
| #  processed_items   :integer          default(0), not null
 | |
| #  finished_at       :datetime
 | |
| #  overwrite         :boolean          default(FALSE), not null
 | |
| #  likely_mismatched :boolean          default(FALSE), not null
 | |
| #  original_filename :string           default(""), not null
 | |
| #  account_id        :bigint(8)        not null
 | |
| #  created_at        :datetime         not null
 | |
| #  updated_at        :datetime         not null
 | |
| #
 | |
| class BulkImport < ApplicationRecord
 | |
|   self.inheritance_column = false
 | |
| 
 | |
|   ARCHIVE_PERIOD = 1.week
 | |
|   CONFIRM_PERIOD = 10.minutes
 | |
| 
 | |
|   belongs_to :account
 | |
|   has_many :rows, class_name: 'BulkImportRow', inverse_of: :bulk_import, dependent: :delete_all
 | |
| 
 | |
|   enum :type, {
 | |
|     following: 0,
 | |
|     blocking: 1,
 | |
|     muting: 2,
 | |
|     domain_blocking: 3,
 | |
|     bookmarks: 4,
 | |
|     lists: 5,
 | |
|   }
 | |
| 
 | |
|   enum :state, {
 | |
|     unconfirmed: 0,
 | |
|     scheduled: 1,
 | |
|     in_progress: 2,
 | |
|     finished: 3,
 | |
|   }, prefix: true
 | |
| 
 | |
|   validates :type, presence: true
 | |
| 
 | |
|   scope :archival_completed, -> { where(created_at: ..ARCHIVE_PERIOD.ago) }
 | |
|   scope :confirmation_missed, -> { state_unconfirmed.where(created_at: ..CONFIRM_PERIOD.ago) }
 | |
| 
 | |
|   def self.progress!(bulk_import_id, imported: false)
 | |
|     # Use `increment_counter` so that the incrementation is done atomically in the database
 | |
|     BulkImport.increment_counter(:processed_items, bulk_import_id)
 | |
|     BulkImport.increment_counter(:imported_items, bulk_import_id) if imported
 | |
| 
 | |
|     # Since the incrementation has been done atomically, concurrent access to `bulk_import` is now bening
 | |
|     bulk_import = BulkImport.find(bulk_import_id)
 | |
|     bulk_import.update!(state: :finished, finished_at: Time.now.utc) if bulk_import.processed_items == bulk_import.total_items
 | |
|   end
 | |
| end
 |