diff --git a/fetchmail.py b/fetchmail.py
index 7272ceaf..d9a12610 100644
--- a/fetchmail.py
+++ b/fetchmail.py
@@ -36,6 +36,7 @@ class fetchmail_server(orm.Model):
'file_type': fields.selection(_get_file_type, 'File Type',
help='The file type will show some special option'),
'company_id': fields.many2one('res.company', 'Company', required=True),#Why this field do not exist by default?
+ 'file_document_condition_ids': fields.one2many('file.document.condition', 'server_id', 'File Document ')
}
_defaults = {
diff --git a/fetchmail_view.xml b/fetchmail_view.xml
index f8f91110..9c7b5fdb 100644
--- a/fetchmail_view.xml
+++ b/fetchmail_view.xml
@@ -12,6 +12,9 @@
+
+
+
diff --git a/file_document.py b/file_document.py
index 7e26412c..9653a0cb 100644
--- a/file_document.py
+++ b/file_document.py
@@ -21,6 +21,7 @@
###############################################################################
from openerp.osv import fields, orm
+import base64
class file_document(orm.Model):
@@ -30,10 +31,6 @@ class file_document(orm.Model):
'fetchmail_server_id': fields.many2one('fetchmail.server', 'Email Server'),
}
- _sql_constraints = [
- ('fecthmail_server_ext_id_uniq', 'unique(fetchmail_server_id, ext_id)',
- 'The combination of Email Server and External id must be unique !'),
- ]
def message_process(self, cr, uid, model, message, custom_values=None,
@@ -65,7 +62,23 @@ class file_document(orm.Model):
context=context,
content_subtype=content_subtype,
**kwargs)
-
+
+
+ def prepare_data_from_basic_condition(self, cr, uid, condition, msg, context=None):
+ vals = {}
+ if condition.from_email in msg['from'] and condition.mail_subject == msg['subject']:
+ for att in msg['attachments']:
+ if condition.file_extension in att[0]:
+ vals = {
+ 'name': msg['subject'],
+ 'direction': 'input',
+ 'date': msg['date'],
+ 'ext_id': msg['message_id'],
+ 'datas_fname': att[0],
+ 'datas': base64.b64encode(att[0][1])
+ }
+ break
+ return vals
def _prepare_data_for_file_document(self, cr, uid, msg, context=None):
@@ -76,7 +89,19 @@ class file_document(orm.Model):
:return: a list of dictionnary that containt the file document data
:rtype: list
"""
- return []
+ res = []
+ server_id = context.get('default_fetchmail_server_id', False)
+ doc_file_condition_obj = self.pool.get('file.document.condition')
+ cond_ids = doc_file_condition_obj.search(cr, uid, [('server_id', '=', server_id)])
+ if cond_ids:
+ for cond in doc_file_condition_obj.browse(cr, uid, cond_ids):
+ if cond.type == 'normal':
+ vals = self.prepare_data_from_basic_condition(cr, uid, cond, msg, context=context)
+ else:
+ vals = getattr(self, cond.type)(cr, uid, cond, msg, context=context)
+ if vals:
+ res.append(vals)
+ return res
def message_new(self, cr, uid, msg, custom_values, context=None):
created_ids = []
@@ -94,3 +119,30 @@ class file_document(orm.Model):
return created_ids[0]
return None
+
+class file_document_condition(orm.Model):
+ _name = "file.document.condition"
+ _description = "File Document Conditions"
+
+ def _get_file_document_condition_type(self, cr, uid, context=None):
+ return self.get_file_document_condition_type(cr, uid, context=context)
+
+ def get_file_document_condition_type(self, cr, uid, context=None):
+ return [('normal', 'Normal')]
+ _columns = {
+ 'from_email': fields.char('Email', size=64),
+ 'mail_subject': fields.char('Mail Subject', size=64),
+ 'type': fields.selection(_get_file_document_condition_type,
+ 'Type', help="Create your own type if the normal type \
+ do not correspond to your need", required=True),
+ 'file_extension' : fields.char('File Extension', size=64,
+ help="File extension or file name",
+ required=True),
+ 'server_id': fields.many2one('fetchmail.server', 'Server Mail'),
+ }
+
+
+ _defaults = {
+ 'type': 'normal'
+ }
+
diff --git a/file_document_view.xml b/file_document_view.xml
index 1529e47d..7addf407 100644
--- a/file_document_view.xml
+++ b/file_document_view.xml
@@ -15,6 +15,46 @@
+
+
+ view_file_document_condition_tree
+ file.document.condition
+
+
+
+
+
+
+
+
+
+
+
+
+ view_file_document_condition_form
+ file.document.condition
+
+
+
+
+
+
+ Configuration
+ file.document.condition
+ form
+ tree,form
+
+
+