This question has been flagged
1 Reply
3256 Views

While defining records in security.xml file, we can sometimes see lines similar to:

<field name="categ_ids" eval="[(6,0,[ref('categ_meet1'), ref('categ_meet2')])]"/>

In other places, there are lines like:

<field name="groups" eval="[(4, ref('base.group_portal'))]"/> 

I know there is some concept about implied ids, but I don't know what these numbers mean and how to use them. Can someone please help me understand it?  


Avatar
Discard
Best Answer

See ORM API documentation:


One2many and Many2many use a special “commands” format to manipulate the set of records stored in/associated with the field.

This format is a list of triplets executed sequentially, where each triplet is a command to execute on the set of records. Not all commands apply in all situations. Possible commands are:

(0, _, values)

adds a new record created from the provided value dict.

(1, id, values)

updates an existing record of id id with the values in values. Can not be used in create().

(2, id, _)

removes the record of id id from the set, then deletes it (from the database). Can not be used in create().

(3, id, _)

removes the record of id id from the set, but does not delete it. Can not be used on One2many. Can not be used in create().

(4, id, _)

adds an existing record of id id to the set. Can not be used on One2many.

(5, _, _)

removes all records from the set, equivalent to using the command 3 on every record explicitly. Can not be used on One2many. Can not be used in create().

(6, _, ids)

replaces all existing records in the set by the ids list, equivalent to using the command 5 followed by a command 4 for each id in ids. Can not be used on One2many.

Note

Values marked as _ in the list above are ignored and can be anything, generally 0 or False.


Avatar
Discard
Author

Thanks zbik. I will read up on the ORM docs more thoroughly.