2012-04-10 14:06:46 +00:00
|
|
|
require 'mail'
|
|
|
|
require 'net/imap'
|
|
|
|
|
|
|
|
class Channel::IMAP
|
|
|
|
include UserInfo
|
|
|
|
|
|
|
|
def fetch (account)
|
|
|
|
puts 'fetching imap'
|
|
|
|
|
2012-04-13 13:51:10 +00:00
|
|
|
imap = Net::IMAP.new(account[:options][:host], 993, true )
|
|
|
|
imap.authenticate('LOGIN', account[:options][:user], account[:options][:password])
|
2012-04-10 14:06:46 +00:00
|
|
|
imap.select('INBOX')
|
|
|
|
imap.search(['ALL']).each do |message_id|
|
|
|
|
msg = imap.fetch(message_id,'RFC822')[0].attr['RFC822']
|
|
|
|
puts '--------------------'
|
|
|
|
# puts msg.to_s
|
|
|
|
|
|
|
|
mail = Mail.new( msg )
|
|
|
|
from_email = Mail::Address.new( mail[:from].value ).address
|
|
|
|
from_display_name = Mail::Address.new( mail[:from].value ).display_name
|
|
|
|
|
|
|
|
# use transaction
|
|
|
|
ActiveRecord::Base.transaction do
|
|
|
|
|
|
|
|
user = User.where( :email => from_email ).first
|
|
|
|
if !user then
|
|
|
|
puts 'create user...'
|
|
|
|
roles = Role.where( :name => 'Customer' )
|
|
|
|
user = User.create(
|
|
|
|
:login => from_email,
|
|
|
|
:firstname => from_display_name,
|
|
|
|
:lastname => '',
|
|
|
|
:email => from_email,
|
|
|
|
:password => '',
|
|
|
|
:active => true,
|
|
|
|
:roles => roles,
|
|
|
|
:created_by_id => 1
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
# set current user
|
|
|
|
UserInfo.current_user_id = user.id
|
|
|
|
|
|
|
|
def conv (charset, string)
|
|
|
|
if charset == 'US-ASCII' then
|
|
|
|
charset = 'LATIN1'
|
|
|
|
end
|
|
|
|
Iconv.conv("UTF8", charset, string)
|
|
|
|
end
|
|
|
|
|
|
|
|
# get ticket# from subject
|
2012-04-13 13:51:10 +00:00
|
|
|
ticket = Ticket.number_check( mail[:subject].value )
|
2012-04-10 14:06:46 +00:00
|
|
|
|
|
|
|
# set ticket state to open if not new
|
|
|
|
if ticket
|
|
|
|
ticket_state = Ticket::State.find( ticket.ticket_state_id )
|
|
|
|
ticket_state_type = Ticket::StateType.find( ticket_state.ticket_state_type_id )
|
|
|
|
if ticket_state_type.name != 'new'
|
|
|
|
ticket.ticket_state = Ticket::State.where( :name => 'open' ).first
|
|
|
|
ticket.save
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# create new ticket
|
|
|
|
if !ticket then
|
|
|
|
ticket = Ticket.create(
|
2012-04-13 13:51:10 +00:00
|
|
|
:group_id => account[:group_id],
|
2012-04-10 14:06:46 +00:00
|
|
|
:customer_id => user.id,
|
|
|
|
:title => conv(mail['subject'].charset || 'LATIN1', mail['subject'].to_s),
|
|
|
|
:ticket_state_id => Ticket::State.where(:name => 'new').first.id,
|
|
|
|
:ticket_priority_id => Ticket::Priority.where(:name => '2 normal').first.id,
|
|
|
|
:created_by_id => user.id
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
# import mail
|
|
|
|
plain_part = mail.multipart? ? (mail.text_part ? mail.text_part.body.decoded : nil) : mail.body.decoded
|
|
|
|
# html_part = message.html_part ? message.html_part.body.decoded : nil
|
|
|
|
article = Ticket::Article.create(
|
|
|
|
:created_by_id => user.id,
|
|
|
|
:ticket_id => ticket.id,
|
|
|
|
:ticket_article_type_id => Ticket::Article::Type.where(:name => 'email').first.id,
|
|
|
|
:ticket_article_sender_id => Ticket::Article::Sender.where(:name => 'Customer').first.id,
|
|
|
|
:body => conv(mail.body.charset || 'LATIN1', plain_part),
|
|
|
|
:from => mail['from'] ? conv(mail['from'].charset || 'LATIN1', mail['from'].to_s) : nil,
|
|
|
|
:to => mail['to'] ? conv(mail['to'].charset || 'LATIN1', mail['to'].to_s) : nil,
|
|
|
|
:cc => mail['cc'] ? conv(mail['cc'].charset || 'LATIN1', mail['cc'].to_s) : nil,
|
|
|
|
:subject => mail['subject'] ? conv(mail['subject'].charset || 'LATIN1', mail['subject'].to_s) : nil,
|
|
|
|
:message_id => mail['message_id'] ? mail['message_id'].to_s : nil,
|
|
|
|
:internal => false
|
|
|
|
)
|
|
|
|
|
|
|
|
# store mail plain
|
|
|
|
Store.add(
|
|
|
|
:object => 'Ticket::Article::Mail',
|
|
|
|
:o_id => article.id,
|
|
|
|
:data => msg,
|
|
|
|
:filename => 'plain.msg',
|
|
|
|
:preferences => {}
|
|
|
|
)
|
|
|
|
|
|
|
|
# store attachments
|
|
|
|
if mail.attachments
|
|
|
|
mail.attachments.each do |attachment|
|
|
|
|
|
|
|
|
# get file preferences
|
|
|
|
headers = {}
|
|
|
|
attachment.header.fields.each do |f|
|
|
|
|
headers[f.name] = f.value
|
|
|
|
end
|
|
|
|
headers_store = {}
|
|
|
|
headers_store['Mime-Type'] = attachment.mime_type
|
|
|
|
if attachment.charset
|
|
|
|
headers_store['Charset'] = attachment.charset
|
|
|
|
end
|
|
|
|
['Content-ID', 'Content-Type'].each do |item|
|
|
|
|
if headers[item]
|
|
|
|
headers_store[item] = headers[item]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# store file
|
|
|
|
Store.add(
|
|
|
|
:object => 'Ticket::Article',
|
|
|
|
:o_id => article.id,
|
|
|
|
:data => attachment.body.decoded,
|
|
|
|
:filename => attachment.filename,
|
|
|
|
:preferences => headers_store
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# delete email from server after article was created
|
|
|
|
if article
|
|
|
|
imap.store(message_id, "+FLAGS", [:Deleted])
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
# execute ticket events
|
|
|
|
Ticket::Observer::Notification.transaction
|
|
|
|
end
|
|
|
|
imap.expunge()
|
|
|
|
imap.disconnect()
|
2012-04-13 13:51:10 +00:00
|
|
|
puts 'done'
|
2012-04-10 14:06:46 +00:00
|
|
|
end
|
2012-04-13 13:51:10 +00:00
|
|
|
def send(attr, notification = false)
|
|
|
|
channel = Channel.where( :area => 'Email::Outbound', :active => true ).first
|
|
|
|
begin
|
|
|
|
c = eval 'Channel::' + channel[:adapter] + '.new'
|
|
|
|
c.send(attr, channel, notification)
|
|
|
|
rescue Exception => e
|
|
|
|
puts "can't use " + 'Channel::' + channel[:adapter]
|
|
|
|
puts e.inspect
|
2012-04-10 14:06:46 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|