|
![]() |
#1 |
Участник
|
Заметил странное поведение sysDictField. (Ax2009 RU5)
При работе на серверной и клиентской части есть различия в поведении... Например для пользователя, у которого нет прав на ключ PurchTables, но есть право на просмотр таблицы PurchTable, код : X++: static server void test2() { SysDictField sysDictField = new SysDictField(tablenum(PurchTable), fieldnum(PurchTable, PurchId)); boolean visible; ; visible = sysDictField.visible(); info(strfmt("%1", visible)); } X++: static client void test2() { SysDictField sysDictField = new SysDictField(tablenum(PurchTable), fieldnum(PurchTable, PurchId)); boolean visible; ; visible = sysDictField.visible(); info(strfmt("%1", visible)); } Это, в свою очередь, влияет на работу формы фильтрации SysQueryForm. Пользователь с такими правами может спокойно работать в форме "Заказ на покупку", создавать и разносить закупки... Но не сможет ничего сортировать и фильтровать через форму фильтрации-сортировки. Форма фильтрации нормально работает только тогда, когда у пользователя есть право на ключ безопасности той таблицы, по которой производится фильтрация и сортировка (а не на саму таблицу). В Ax 3.0 все работало корректно, в Ax2009 приходится открывать права на ключ безопасности таблиц целого модуля (чтобы работала сортировка и фильтрация), что не корректно с моей точки зрения. Поменял в X++: SysQueryForm private static server container findFields(tableId _tableId, TmpSysQueryCompanyRange _tmpCompanyRange) private static client container findFields(tableId _tableId, TmpSysQueryCompanyRange _tmpCompanyRange) Таким образом все работает корректно. |
|
|
За это сообщение автора поблагодарили: Logger (2), gl00mie (2), S.Kuskov (5). |
![]() |
#2 |
NavAx
|
В порядке некропостинга.
В AX 4.0 наблюдается то же самое. И более того, и в 2009 и в 4.0 SysDictField может возвращать разные id() поля. На сервере, как будто бы поле - контейнерное с единственным элементом и id как у контейнерного > 65535 (взведенный первый бит 1<<16). На клиенте - нормальное, с id < 65535. Как побочный эффект этого - на форме пользователей наложив фильтр на поле "Имя пользователя" потом невозможно наложить другой фильтр на это же поле в форме расширенного запроса, не перевыбрав поле, которое в той форме теперь называется User Name. Причина - в том, что при вызове формы расширенного фильтра список полей создается на клиенте, а при сохранении валидация полей работает по заново созданному списку полей (в findFields()) на сервере. Указанное изменение лечит и это.
__________________
Жизнь прекрасна! Если, конечно, правильно подобрать антидепрессанты... ![]() Последний раз редактировалось Maximin; 02.03.2020 в 19:00. |
|
|
За это сообщение автора поблагодарили: Logger (1). |