Files
chatwoot/app/services/data_import/contact_manager.rb
Shivam Mishra c031cb19d2 fix: downcase email before finding (#8921)
* fix: downcase email when finding

* feat: add `from_email` class

* refactor: use `from_email`

* feat: add rule to disallow find_by email directly

* chore:  remove redundant test

Since the previous imlpmentation didn't do a case-insentive search, a new user would be created, and the error would be raised at the DB layer. With the new changes, this test case is redundant

* refactor: use from_email
2024-02-21 18:51:00 +05:30

69 lines
2.3 KiB
Ruby

class DataImport::ContactManager
def initialize(account)
@account = account
end
def build_contact(params)
contact = find_or_initialize_contact(params)
update_contact_attributes(params, contact)
contact
end
def find_or_initialize_contact(params)
contact = find_existing_contact(params)
contact_params = params.slice(:email, :identifier, :phone_number)
contact_params[:phone_number] = format_phone_number(contact_params[:phone_number]) if contact_params[:phone_number].present?
contact ||= @account.contacts.new(contact_params)
contact
end
def find_existing_contact(params)
contact = find_contact_by_identifier(params)
contact ||= find_contact_by_email(params)
contact ||= find_contact_by_phone_number(params)
update_contact_with_merged_attributes(params, contact) if contact.present? && contact.valid?
contact
end
def find_contact_by_identifier(params)
return unless params[:identifier]
@account.contacts.find_by(identifier: params[:identifier])
end
def find_contact_by_email(params)
return unless params[:email]
@account.contacts.from_email(params[:email])
end
def find_contact_by_phone_number(params)
return unless params[:phone_number]
@account.contacts.find_by(phone_number: format_phone_number(params[:phone_number]))
end
def format_phone_number(phone_number)
phone_number.start_with?('+') ? phone_number : "+#{phone_number}"
end
def update_contact_with_merged_attributes(params, contact)
contact.identifier = params[:identifier] if params[:identifier].present?
contact.email = params[:email] if params[:email].present?
contact.phone_number = format_phone_number(params[:phone_number]) if params[:phone_number].present?
update_contact_attributes(params, contact)
contact.save
end
private
def update_contact_attributes(params, contact)
contact.name = params[:name] if params[:name].present?
contact.additional_attributes ||= {}
contact.additional_attributes[:company] = params[:company] if params[:company].present?
contact.additional_attributes[:city] = params[:city] if params[:city].present?
contact.assign_attributes(custom_attributes: contact.custom_attributes.merge(params.except(:identifier, :email, :name, :phone_number)))
end
end