Browse Source

[IMP] make fetch_mail's refactoring more useful by returning the ids of

mails creates/objects matched
[ADD] preliminary docstrings
pull/78/head
Holger Brunn 12 years ago
parent
commit
466d88fb2f
  1. 2
      fetchmail_attach_from_folder/match_algorithm/openerp_standard.py
  2. 64
      fetchmail_attach_from_folder/model/fetchmail_server.py

2
fetchmail_attach_from_folder/match_algorithm/openerp_standard.py

@ -48,4 +48,4 @@ class openerp_standard(base):
if folder.delete_matching: if folder.delete_matching:
connection.store(msgid, '+FLAGS', '\\DELETED') connection.store(msgid, '+FLAGS', '\\DELETED')
return result
return [result]

64
fetchmail_attach_from_folder/model/fetchmail_server.py

@ -83,6 +83,10 @@ class fetchmail_server(Model):
cr, uid, check_original, context) cr, uid, check_original, context)
def handle_folder(self, cr, uid, ids, connection, folder, context=None): def handle_folder(self, cr, uid, ids, connection, folder, context=None):
'''Return ids of objects matched'''
matched_object_ids = []
for this in self.browse(cr, uid, ids, context=context): for this in self.browse(cr, uid, ids, context=context):
logger.info('start checking for emails in %s server %s', logger.info('start checking for emails in %s server %s',
folder.path, this.name) folder.path, this.name)
@ -103,16 +107,23 @@ class fetchmail_server(Model):
continue continue
for msgid in msgids[0].split(): for msgid in msgids[0].split():
this.apply_matching(connection, folder, msgid, match_algorithm)
matched_object_ids += this.apply_matching(
connection, folder, msgid, match_algorithm)
logger.info('finished checking for emails in %s server %s', logger.info('finished checking for emails in %s server %s',
folder.path, this.name) folder.path, this.name)
return matched_object_ids
def get_msgids(self, cr, uid, ids, connection, context=None): def get_msgids(self, cr, uid, ids, connection, context=None):
'''Return imap ids of messages to process'''
return connection.search(None, 'UNDELETED') return connection.search(None, 'UNDELETED')
def apply_matching(self, cr, uid, ids, connection, folder, msgid, def apply_matching(self, cr, uid, ids, connection, folder, msgid,
match_algorithm, context=None): match_algorithm, context=None):
'''Return ids of objects matched'''
matched_object_ids = []
for this in self.browse(cr, uid, ids, context=context): for this in self.browse(cr, uid, ids, context=context):
result, msgdata = connection.fetch(msgid, '(RFC822)') result, msgdata = connection.fetch(msgid, '(RFC822)')
@ -142,6 +153,7 @@ class fetchmail_server(Model):
found_ids[0], folder, mail_message, found_ids[0], folder, mail_message,
msgdata[0][1], msgid, context) msgdata[0][1], msgid, context)
cr.commit() cr.commit()
matched_object_ids += found_ids[:1]
except Exception, e: except Exception, e:
cr.rollback() cr.rollback()
logger.exception( logger.exception(
@ -150,9 +162,15 @@ class fetchmail_server(Model):
elif folder.flag_nonmatching: elif folder.flag_nonmatching:
connection.store(msgid, '+FLAGS', '\\FLAGGED') connection.store(msgid, '+FLAGS', '\\FLAGGED')
return matched_object_ids
def attach_mail( def attach_mail(
self, cr, uid, ids, connection, object_id, folder, self, cr, uid, ids, connection, object_id, folder,
mail_message, msgid, context=None): mail_message, msgid, context=None):
'''Return ids of messages created'''
mail_message_ids = []
for this in self.browse(cr, uid, ids, context): for this in self.browse(cr, uid, ids, context):
partner_id = None partner_id = None
if folder.model_id.model == 'res.partner': if folder.model_id.model == 'res.partner':
@ -181,30 +199,32 @@ class fetchmail_server(Model):
self.pool.get('ir.attachment').create( self.pool.get('ir.attachment').create(
cr, uid, data_attach, context=context)) cr, uid, data_attach, context=context))
self.pool.get('mail.message').create(
cr, uid,
{
'partner_id': partner_id,
'model': folder.model_id.model,
'res_id': object_id,
'body_text': mail_message.get('body'),
'body_html': mail_message.get('body_html'),
'subject': mail_message.get('subject'),
'email_to': mail_message.get('to'),
'email_from': mail_message.get('from'),
'email_cc': mail_message.get('cc'),
'reply_to': mail_message.get('reply'),
'date': mail_message.get('date'),
'message_id': mail_message.get('message-id'),
'subtype': mail_message.get('subtype'),
'headers': mail_message.get('headers'),
'state': folder.msg_state,
'attachment_ids': [(6, 0, attachments)],
},
context)
mail_message_ids.append(
self.pool.get('mail.message').create(
cr, uid,
{
'partner_id': partner_id,
'model': folder.model_id.model,
'res_id': object_id,
'body_text': mail_message.get('body'),
'body_html': mail_message.get('body_html'),
'subject': mail_message.get('subject'),
'email_to': mail_message.get('to'),
'email_from': mail_message.get('from'),
'email_cc': mail_message.get('cc'),
'reply_to': mail_message.get('reply'),
'date': mail_message.get('date'),
'message_id': mail_message.get('message-id'),
'subtype': mail_message.get('subtype'),
'headers': mail_message.get('headers'),
'state': folder.msg_state,
'attachment_ids': [(6, 0, attachments)],
},
context))
if folder.delete_matching: if folder.delete_matching:
connection.store(msgid, '+FLAGS', '\\DELETED') connection.store(msgid, '+FLAGS', '\\DELETED')
return mail_message_ids
def button_confirm_login(self, cr, uid, ids, context=None): def button_confirm_login(self, cr, uid, ids, context=None):
retval = super(fetchmail_server, self).button_confirm_login(cr, uid, retval = super(fetchmail_server, self).button_confirm_login(cr, uid,

Loading…
Cancel
Save