1 # -*- coding: utf-8 -*-
2 ##############################################################################
4 # OpenERP, Open Source Management Solution
5 # Copyright (C) 2004-2010 Tiny SPRL (<http://tiny.be>).
7 # This program is free software: you can redistribute it and/or modify
8 # it under the terms of the GNU Affero General Public License as
9 # published by the Free Software Foundation, either version 3 of the
10 # License, or (at your option) any later version.
12 # This program is distributed in the hope that it will be useful,
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 # GNU Affero General Public License for more details.
17 # You should have received a copy of the GNU Affero General Public License
18 # along with this program. If not, see <http://www.gnu.org/licenses/>.
20 ##############################################################################
25 super class for all mapper class
26 They are call before import data
27 to transform the mapping into real value that we
30 the call function receive a dictionary with external data
31 'external_field' : value
33 def __call__(self, external_values):
34 raise NotImplementedError()
36 class dbmapper(mapper):
38 Super class for mapper that need to access to
39 data base or any function of the import_framework
41 self.parent contains a reference to the instance of
44 def set_parent(self, parent):
50 Use : contact('field_name1', 'field_name2', delimiter='_')
51 concat value of fields using the delimiter, delimiter is optional
52 and by default is a space
55 def __init__(self, *arg, **delimiter):
57 self.delimiter = delimiter and delimiter.get('delimiter', ' ') or ' '
59 def __call__(self, external_values):
60 return self.delimiter.join(map(lambda x : external_values.get(x,''), self.arg))
62 class ppconcat(mapper):
64 Use : contact('field_name1', 'field_name2', delimiter='_')
65 concat external field name and value of fields using the delimiter,
66 delimiter is optional and by default is a two line feeds
69 def __init__(self, *arg, **delimiter):
71 self.delimiter = delimiter and delimiter.get('delimiter', ' ') or '\n\n'
73 def __call__(self, external_values):
74 return self.delimiter.join(map(lambda x : x + ": " + external_values.get(x,''), self.arg))
81 def __init__(self, val):
84 def __call__(self, external_values):
89 Use : value(external_field_name)
90 Return the value of the external field name
91 this is equivalent to the a single string
93 usefull for call if you want your call get the value
94 and don't care about the name of the field
95 call(self.method, value('field1'))
97 def __init__(self, val, default=''):
99 self.default = default
101 def __call__(self, external_values):
102 return external_values.get(self.val, self.default)
104 class map_val(mapper):
106 Use : map_val(external_field, val_mapping)
107 where val_mapping is a dictionary
108 with external_val : openerp_val
110 usefull for selection field like state
113 def __init__(self, val, map, default='draft'):
114 self.val = value(val)
116 self.default = default
118 def __call__(self, external_values):
119 return self.map.get(self.val(external_values), self.default)
123 Use : ref(table_name, external_id)
124 return the xml_id of the ressource
126 to associate an already imported object with the current object
128 def __init__(self, table, field_name):
130 self.field_name = field_name
132 def __call__(self, external_values):
133 return self.parent.xml_id_exist(self.table, external_values.get(self.field_name))
135 class refbyname(dbmapper):
137 Use : refbyname(table_name, external_name, res.model)
138 same as ref but use the name of the ressource to find it
140 def __init__(self, table, field_name, model):
142 self.field_name = field_name
145 def __call__(self, external_values):
146 v = external_values.get(self.field_name, '')
147 return self.parent.name_exist(self.table, v , self.model)
151 Use : call(function, arg1, arg2)
152 to call the function with external val follow by the arg specified
154 def __init__(self, fun, *arg):
158 def __call__(self, external_values):
161 if isinstance(arg, mapper):
162 args.append(arg(external_values))
165 return self.fun(external_values, *args)