Merge pull request #495 from digineo/refactor_caller_id

Refactor Cti::CallerId
This commit is contained in:
Thorsten 2016-12-06 13:36:08 +01:00 committed by GitHub
commit 1e23cac9a1

View file

@ -18,22 +18,16 @@ module Cti
=end =end
def self.maybe_add(data) def self.maybe_add(data)
records = Cti::CallerId.where( record = find_or_initialize_by(
caller_id: data[:caller_id], caller_id: data[:caller_id],
level: data[:level], level: data[:level],
object: data[:object], object: data[:object],
o_id: data[:o_id], o_id: data[:o_id],
user_id: data[:user_id], user_id: data[:user_id],
) )
return if records[0] return record if !record.new_record?
Cti::CallerId.create( record.comment = data[:comment]
caller_id: data[:caller_id], record.save!
comment: data[:comment],
level: data[:level],
object: data[:object],
o_id: data[:o_id],
user_id: data[:user_id],
)
end end
=begin =begin
@ -47,28 +41,11 @@ returns
=end =end
def self.lookup(caller_id) def self.lookup(caller_id)
result = Cti::CallerId.where( where(caller_id: caller_id)
caller_id: caller_id, .group(:user_id, :id) \
level: 'known', # first known, then maybe, last others
).group(:user_id, :id).order(id: 'DESC').limit(20) .order("level != 'known', level != 'maybe', id DESC")
if !result[0] .limit(20)
result = Cti::CallerId.where(
caller_id: caller_id,
level: 'maybe',
).group(:user_id, :id).order(id: 'DESC').limit(20)
end
if !result[0]
result = Cti::CallerId.where(
caller_id: caller_id,
).order('id DESC').limit(20)
end
# in case do lookups in external sources
if !result[0]
# ...
end
result
end end
=begin =begin
@ -145,9 +122,9 @@ returns
=end =end
def self.rebuild def self.rebuild
Cti::CallerId.delete_all transaction do
map = config delete_all
map.each { |item| config.each { |item|
level = item[:level] level = item[:level]
model = item[:model] model = item[:model]
item[:model].find_each(batch_size: 500) do |record| item[:model].find_each(batch_size: 500) do |record|
@ -155,6 +132,7 @@ returns
end end
} }
end end
end
=begin =begin