Currently, it’s unclear whether an FAQ item is generated from a document, derived from a conversation, or added manually. This PR resolves the issue by providing visibility into the source of each FAQ. Users can now see whether an FAQ was generated or manually added and, if applicable, by whom. - Move the document_id to a polymorphic relation (documentable). - Updated the APIs to accommodate the change. - Update the service to add corresponding references. - Updated the specs. <img width="1007" alt="Screenshot 2025-01-15 at 11 27 56 PM" src="https://github.com/user-attachments/assets/7d58f798-19c0-4407-b3e2-748a919d14af" /> --------- Co-authored-by: Sivin Varghese <64252451+iamsivin@users.noreply.github.com>
34 lines
1.3 KiB
Ruby
34 lines
1.3 KiB
Ruby
class ConvertDocumentToPolymorphicAssociation < ActiveRecord::Migration[7.0]
|
|
def up
|
|
add_column :captain_assistant_responses, :documentable_type, :string
|
|
|
|
# rubocop:disable Rails/SkipsModelValidations
|
|
Captain::AssistantResponse
|
|
.where
|
|
.not(document_id: nil)
|
|
.update_all(documentable_type: 'Captain::Document')
|
|
# rubocop:enable Rails/SkipsModelValidations
|
|
remove_index :captain_assistant_responses, :document_id if index_exists?(
|
|
:captain_assistant_responses, :document_id
|
|
)
|
|
|
|
rename_column :captain_assistant_responses, :document_id, :documentable_id
|
|
add_index :captain_assistant_responses, [:documentable_id, :documentable_type],
|
|
name: 'idx_cap_asst_resp_on_documentable'
|
|
end
|
|
|
|
def down
|
|
if index_exists?(
|
|
:captain_assistant_responses, [:documentable_id, :documentable_type], name: 'idx_cap_asst_resp_on_documentable'
|
|
)
|
|
remove_index :captain_assistant_responses, name: 'idx_cap_asst_resp_on_documentable'
|
|
end
|
|
|
|
rename_column :captain_assistant_responses, :documentable_id, :document_id
|
|
remove_column :captain_assistant_responses, :documentable_type
|
|
add_index :captain_assistant_responses, :document_id unless index_exists?(
|
|
:captain_assistant_responses, :document_id
|
|
)
|
|
end
|
|
end
|