123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- module Import
- module OTRS
- class ArticleCustomer
- include Import::Helper
- def initialize(article)
- import(article)
- rescue Exceptions::UnprocessableEntity
- log "ERROR: Can't extract customer from Article #{article[:id]}"
- end
- def self.mutex
- @mutex ||= Mutex.new
- end
- class << self
- def find(article)
- email = local_email(article['From'])
- return if !email
- user = ::User.find_by(email: email)
- user ||= ::User.find_by(login: email)
- user
- end
- def local_email(from)
- # TODO: should get unified with User#check_email
- email = extract_email(from)
- return if !email
- email.downcase
- end
- private
- def extract_email(from)
- Mail::Address.new(from).address
- rescue
- return from if from !~ %r{<\s*([^>]+)}
- $1.strip
- end
- end
- private
- def import(article)
- find_or_create(article)
- end
- def find_or_create(article)
- self.class.mutex.synchronize do
- return if self.class.find(article)
- create(article)
- end
- end
- def create(article)
- email = self.class.local_email(article['From'])
- ::User.create(
- login: email,
- firstname: extract_display_name(article['From']),
- lastname: '',
- email: email,
- password: '',
- active: true,
- role_ids: roles,
- updated_by_id: 1,
- created_by_id: 1,
- )
- end
- def roles
- [
- Role.find_by(name: 'Customer').id
- ]
- end
- def extract_display_name(from)
- # do extra decoding because we needed to use field.value
- Mail::Field.new('X-From', parsed_display_name(from)).to_s
- end
- def parsed_display_name(from)
- parsed_address = Mail::Address.new(from)
- return parsed_address.display_name if parsed_address.display_name
- return from if parsed_address.comments.blank?
- parsed_address.comments[0]
- rescue
- from
- end
- end
- end
- end
|