# Copyright (C) 2012-2021 Zammad Foundation, http://zammad-foundation.org/ class SearchIndexJob < ApplicationJob include HasActiveJobLock low_priority retry_on StandardError, attempts: 20, wait: lambda { |executions| executions * 10.seconds } def lock_key # "SearchIndexJob/User/42" "#{self.class.name}/#{arguments[0]}/#{arguments[1]}" end def perform(object, o_id) @object = object @o_id = o_id record = @object.constantize.find_by(id: @o_id) return if !exists?(record) update_search_index(record) end def update_search_index(record) record.search_index_update_backend end private def exists?(record) return true if record Rails.logger.info "Can't index #{@object}.find_by(id: #{@o_id}), no such record found" false end end