понимаю, что в Odoo права доступа на read, write, delete работают на уровне записей в таблице. Нельзя настроить, чтобы такие проверки были на поля отдельные? на колонки в базе.
Надо, например, сделать так, чтобы определённая колонка была только read only, если у человека такая-то роль
Нельзя. Можно переопределять write. Смотреть какие поля изменяет пользователь и выводить ошибку
Вот например https://github.com/odoo/odoo/blob/e3d47af72080c6910e64e3df1ab5937af1a39a23/odoo/addons/base/models/res_users.py#L446
я знаю минимум 2 способа: 1. добавляешь копию филда с readonly=1 для группы у которой нет нужных прав Проверяешь вот так: groups="!my_super_role_which_allowe_write_this_field" и такое же поле только без readonly=1 для группы у которой ЕСТЬ нужные права Проверяешь вот так: groups="my_super_role_which_allowe_write_this_field" 2. наследуешь вьюху, у поля добавляешь атрибут readonly=1. Т.е. поле запрещено длля редактирования всем. Затем для роли, которой доступна делаешь еще одну вьюху(слой), которая наследует эту вьюху в меняет атрибут readonly на 0. секрет в том, чтобы в определинии вюьхи добавить код: <field name="groups_id" eval="[(4, ref('group_pos_user'))]"/>
как вью запрещает менять через апи?
кто-полезет менять через апи? обычно достаточно скрыть в интерфейсе
Обсуждают сегодня