Pular para o conteúdo
Menu
Esta pergunta foi sinalizada
1 Responder
6340 Visualizações

how to insert current user name into one2many field when i hit 'approval' button ,

this is the code :

  def wtc_approval(self, cr, uid, vals, context=None):
        groups_id = self.pool.get('res.users').browse(cr, uid, uid)['groups_id']
        data = self.pool.get("wtc.apps.po").browse(cr,uid,groups_id)
        pelaksana = []
        
        for x in data :
            pelaksana.insert((1, 5,{'pelaksana':x.pelaksana}))
        vals["app_line"] = pelaksana
        print "---dfdfdfd--------------dfdfd-------------------------------",vals

 

it said :

Traceback (most recent call last): File "/home/ajeng/odoo/openerp-8.0/openerp/http.py", line 499, in _handle_exception return super(JsonRequest, self)._handle_exception(exception) File "/home/ajeng/odoo/openerp-8.0/openerp/http.py", line 516, in dispatch result = self._call_function(**self.params) File "/home/ajeng/odoo/openerp-8.0/openerp/http.py", line 282, in _call_function return checked_call(self.db, *args, **kwargs) File "/home/ajeng/odoo/openerp-8.0/openerp/service/model.py", line 113, in wrapper return f(dbname, *args, **kwargs) File "/home/ajeng/odoo/openerp-8.0/openerp/http.py", line 279, in checked_call return self.endpoint(*a, **kw) File "/home/ajeng/odoo/openerp-8.0/openerp/http.py", line 732, in __call__ return self.method(*args, **kw) File "/home/ajeng/odoo/openerp-8.0/openerp/http.py", line 375, in response_wrap response = f(*args, **kw) File "/home/ajeng/odoo/addons/HONDA/web/controllers/main.py", line 948, in call_button action = self._call_kw(model, method, args, {}) File "/home/ajeng/odoo/addons/HONDA/web/controllers/main.py", line 936, in _call_kw return getattr(request.registry.get(model), method)(request.cr, request.uid, *args, **kwargs) File "/home/ajeng/odoo/openerp-8.0/openerp/api.py", line 237, in wrapper return old_api(self, *args, **kwargs) File "/home/ajeng/odoo/addons/HONDA/wtc_approval/approval.py", line 44, in wtc_approval pelaksana.insert((1, 5,{'pelaksana':x.pelaksana})) File "/home/ajeng/odoo/openerp-8.0/openerp/fields.py", line 711, in __get__ self.determine_value(record) File "/home/ajeng/odoo/openerp-8.0/openerp/fields.py", line 806, in determine_value record._prefetch_field(self) File "/home/ajeng/odoo/openerp-8.0/openerp/api.py", line 235, in wrapper return new_api(self, *args, **kwargs) File "/home/ajeng/odoo/openerp-8.0/openerp/models.py", line 3180, in _prefetch_field result = records.read(list(fnames), load='_classic_write') File "/home/ajeng/odoo/openerp-8.0/openerp/api.py", line 235, in wrapper return new_api(self, *args, **kwargs) File "/home/ajeng/odoo/openerp-8.0/openerp/models.py", line 3127, in read self._read_from_database(stored) File "/home/ajeng/odoo/openerp-8.0/openerp/api.py", line 235, in wrapper return new_api(self, *args, **kwargs) File "/home/ajeng/odoo/openerp-8.0/openerp/models.py", line 3237, in _read_from_database cr.execute(query, [tuple(sub_ids)] + rule_params) File "/home/ajeng/odoo/openerp-8.0/openerp/sql_db.py", line 158, in wrapper return f(self, *args, **kwargs) File "/home/ajeng/odoo/openerp-8.0/openerp/sql_db.py", line 234, in execute res = self._obj.execute(query, params) File "/usr/lib/python2.7/dist-packages/psycopg2/extensions.py", line 129, in getquoted pobjs = [adapt(o) for o in self._seq] ProgrammingError: can't adapt type 'res.groups'

Avatar
Cancelar
Autor

@Bruno , i hit an error , it said can't adapt type 'res.groups'

Melhor resposta

Hello Ajeng,

in your code you have: 

groups_id = self.pool.get('res.users').browse(cr, uid, uid)['groups_id']
data = self.pool.get("wtc.apps.po").browse(cr,uid,groups_id)

reading the logs, your problem is the groups_id variable, groups_id contains a "browse_list" or res.groups, and you try to use it as a list of ids (to populate the "data" variable).

You try to browse the table wtc.apps.po with this browse_list instead using a list of ids, and that's the problem returned by the logs.

Then, i don't know the model wtc.apps.po, but are you sure you can retrieve the records by using the groups ids ?

Hope i helped you,

Regards

Avatar
Cancelar
Publicações relacionadas Respostas Visualizações Atividade
2
set. 22
4537
0
mar. 19
3118
1
nov. 21
6401
1
set. 17
4154
2
nov. 15
6194