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.
		
		
		
		
		
			
		
			
				
					
					
						
							50 lines
						
					
					
						
							1.5 KiB
						
					
					
				
			
		
		
	
	
							50 lines
						
					
					
						
							1.5 KiB
						
					
					
				# frozen_string_literal: true
 | 
						|
 | 
						|
class CreateSearchEnties < ActiveRecord::Migration[8.0]
 | 
						|
  disable_ddl_transaction!
 | 
						|
 | 
						|
  def up
 | 
						|
    return unless adapter_name == 'PostgreSQL'
 | 
						|
 | 
						|
    create_table :search_entries do |t|
 | 
						|
      t.references :record, null: false, polymorphic: true, index: false
 | 
						|
      t.bigint :account_id, null: false
 | 
						|
      t.tsvector :tsvector, null: false
 | 
						|
 | 
						|
      t.timestamps
 | 
						|
    end
 | 
						|
 | 
						|
    begin
 | 
						|
      enable_extension 'btree_gin'
 | 
						|
    rescue StandardError
 | 
						|
      nil
 | 
						|
    end
 | 
						|
 | 
						|
    btree_gin_enabled = extension_enabled?('btree_gin')
 | 
						|
 | 
						|
    add_index :search_entries, btree_gin_enabled ? %i[account_id tsvector] : :tsvector,
 | 
						|
              using: :gin, where: "record_type = 'Submitter'",
 | 
						|
              name: 'index_search_entries_on_account_id_tsvector_submitter'
 | 
						|
    add_index :search_entries, btree_gin_enabled ? %i[account_id tsvector] : :tsvector,
 | 
						|
              using: :gin, where: "record_type = 'Submission'",
 | 
						|
              name: 'index_search_entries_on_account_id_tsvector_submission'
 | 
						|
    add_index :search_entries, btree_gin_enabled ? %i[account_id tsvector] : :tsvector,
 | 
						|
              using: :gin, where: "record_type = 'Template'",
 | 
						|
              name: 'index_search_entries_on_account_id_tsvector_template'
 | 
						|
 | 
						|
    add_index :search_entries, %i[record_id record_type], unique: true
 | 
						|
  end
 | 
						|
 | 
						|
  def down
 | 
						|
    return unless adapter_name == 'PostgreSQL'
 | 
						|
 | 
						|
    drop_table :search_entries
 | 
						|
 | 
						|
    begin
 | 
						|
      disable_extension 'btree_gin'
 | 
						|
    rescue StandardError
 | 
						|
      nil
 | 
						|
    end
 | 
						|
  end
 | 
						|
end
 |