fix: Revert the changes for SyncCustomFilterCountJob (#8238)
This commit is contained in:
@@ -1,9 +0,0 @@
|
||||
class CustomFiltersRecordsCountUpdateJob < ApplicationJob
|
||||
queue_as :low
|
||||
|
||||
def perform
|
||||
CustomFilter.find_each(batch_size: 25) do |filter|
|
||||
SyncCustomFilterCountJob.perform_later(filter)
|
||||
end
|
||||
end
|
||||
end
|
||||
@@ -1,9 +0,0 @@
|
||||
class SyncCustomFilterCountJob < ApplicationJob
|
||||
queue_as :low
|
||||
|
||||
def perform(filter)
|
||||
Redis::Alfred.set(filter.filter_count_key, 0) if filter.filter_records.nil?
|
||||
|
||||
filter.set_record_count_in_redis
|
||||
end
|
||||
end
|
||||
@@ -24,29 +24,6 @@ class CustomFilter < ApplicationRecord
|
||||
enum filter_type: { conversation: 0, contact: 1, report: 2 }
|
||||
validate :validate_number_of_filters
|
||||
|
||||
def records_count
|
||||
fetch_record_count_from_redis
|
||||
end
|
||||
|
||||
def filter_records
|
||||
Conversations::FilterService.new(query.with_indifferent_access, user, account).perform
|
||||
end
|
||||
|
||||
def set_record_count_in_redis
|
||||
records = filter_records
|
||||
Redis::Alfred.set(filter_count_key, records[:count][:all_count])
|
||||
end
|
||||
|
||||
def fetch_record_count_from_redis
|
||||
number_of_records = Redis::Alfred.get(filter_count_key)
|
||||
SyncCustomFilterCountJob.perform_later(self) if number_of_records.nil?
|
||||
number_of_records.to_i
|
||||
end
|
||||
|
||||
def filter_count_key
|
||||
format(::Redis::Alfred::CUSTOM_FILTER_RECORDS_COUNT_KEY, account_id: account_id, filter_id: id, user_id: user_id)
|
||||
end
|
||||
|
||||
def validate_number_of_filters
|
||||
return true if account.custom_filters.where(user_id: user_id).size < MAX_FILTER_PER_USER
|
||||
|
||||
|
||||
@@ -4,4 +4,3 @@ json.filter_type resource.filter_type
|
||||
json.query resource.query
|
||||
json.created_at resource.created_at
|
||||
json.updated_at resource.updated_at
|
||||
json.count resource.records_count
|
||||
|
||||
Reference in New Issue
Block a user