33 lines
1,004 B
Ruby
33 lines
1,004 B
Ruby
|
class Answer < ActiveRecord::Base
|
||
|
include Elasticsearch::Model
|
||
|
|
||
|
belongs_to :question
|
||
|
|
||
|
JOIN_TYPE = 'answer'.freeze
|
||
|
|
||
|
index_name 'questions_and_answers'.freeze
|
||
|
document_type 'doc'.freeze
|
||
|
|
||
|
before_create :randomize_id
|
||
|
|
||
|
def randomize_id
|
||
|
begin
|
||
|
self.id = SecureRandom.random_number(1_000_000)
|
||
|
end while Answer.where(id: self.id).exists?
|
||
|
end
|
||
|
|
||
|
mapping do
|
||
|
indexes :text
|
||
|
indexes :author
|
||
|
end
|
||
|
|
||
|
def as_indexed_json(options={})
|
||
|
# This line is necessary for differences between ActiveModel::Serializers::JSON#as_json versions
|
||
|
json = as_json(options)[JOIN_TYPE] || as_json(options)
|
||
|
json.merge(join_field: { name: JOIN_TYPE, parent: question_id })
|
||
|
end
|
||
|
|
||
|
after_commit lambda { __elasticsearch__.index_document(routing: (question_id || 1)) }, on: :create
|
||
|
after_commit lambda { __elasticsearch__.update_document(routing: (question_id || 1)) }, on: :update
|
||
|
after_commit lambda {__elasticsearch__.delete_document(routing: (question_id || 1)) }, on: :destroy
|
||
|
end
|