mirror of https://github.com/docusealco/docuseal
				
				
				
			
			You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							80 lines
						
					
					
						
							2.4 KiB
						
					
					
				
			
		
		
	
	
							80 lines
						
					
					
						
							2.4 KiB
						
					
					
				# frozen_string_literal: true
 | 
						|
 | 
						|
class PopulateCompletedSubmittersAndDocuments < ActiveRecord::Migration[7.2]
 | 
						|
  disable_ddl_transaction!
 | 
						|
 | 
						|
  class MigrationSubmitter < ApplicationRecord
 | 
						|
    self.table_name = 'submitters'
 | 
						|
 | 
						|
    belongs_to :submission, class_name: 'MigrationSubmission'
 | 
						|
    has_many :submission_sms_events, -> { where(event_type: %w[send_sms send_2fa_sms]) },
 | 
						|
             class_name: 'MigrationSubmissionEvent', foreign_key: :submitter_id
 | 
						|
  end
 | 
						|
 | 
						|
  class MigrationSubmission < ApplicationRecord
 | 
						|
    self.table_name = 'submissions'
 | 
						|
  end
 | 
						|
 | 
						|
  class MigrationSubmissionEvent < ApplicationRecord
 | 
						|
    self.table_name = 'submission_events'
 | 
						|
  end
 | 
						|
 | 
						|
  class MigrationCompletedSubmitter < ApplicationRecord
 | 
						|
    self.table_name = 'completed_submitters'
 | 
						|
  end
 | 
						|
 | 
						|
  class MigrationCompletedDocument < ApplicationRecord
 | 
						|
    self.table_name = 'completed_documents'
 | 
						|
  end
 | 
						|
 | 
						|
  def up
 | 
						|
    submitters = MigrationSubmitter.where.not(completed_at: nil)
 | 
						|
                                   .preload(:submission, :submission_sms_events)
 | 
						|
 | 
						|
    count = submitters.count
 | 
						|
 | 
						|
    puts "Updating the database - it might take ~#{(count / 1000 * 3) + 1} seconds" if count > 2000
 | 
						|
 | 
						|
    submitters.find_each do |submitter|
 | 
						|
      completed_submitter = MigrationCompletedSubmitter.find_or_initialize_by(submitter_id: submitter.id)
 | 
						|
 | 
						|
      next if completed_submitter.persisted?
 | 
						|
 | 
						|
      submission = submitter.submission
 | 
						|
 | 
						|
      completed_submitter.assign_attributes(
 | 
						|
        submission_id: submitter.submission_id,
 | 
						|
        account_id: submission.account_id,
 | 
						|
        template_id: submission.template_id,
 | 
						|
        source: submission.source,
 | 
						|
        sms_count: submitter.submission_sms_events.size,
 | 
						|
        completed_at: submitter.completed_at,
 | 
						|
        created_at: submitter.completed_at,
 | 
						|
        updated_at: submitter.completed_at
 | 
						|
      )
 | 
						|
 | 
						|
      completed_submitter.save!
 | 
						|
    end
 | 
						|
 | 
						|
    attachments = ActiveStorage::Attachment.where(record_type: 'Submitter', name: 'documents').preload(:blob)
 | 
						|
 | 
						|
    attachments.find_each do |attachment|
 | 
						|
      sha256 = attachment.metadata['sha256']
 | 
						|
 | 
						|
      next if sha256.blank?
 | 
						|
 | 
						|
      completed_document = MigrationCompletedDocument.find_or_initialize_by(submitter_id: attachment.record_id, sha256:)
 | 
						|
 | 
						|
      next if completed_document.persisted?
 | 
						|
 | 
						|
      completed_document.assign_attributes(created_at: attachment.created_at, updated_at: attachment.created_at)
 | 
						|
 | 
						|
      completed_document.save!
 | 
						|
    end
 | 
						|
  end
 | 
						|
 | 
						|
  def down
 | 
						|
    nil
 | 
						|
  end
 | 
						|
end
 |