AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX: Программирование
DAX
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 23.11.2010, 16:00   #1  
someOne is offline
someOne
Участник
Аватар для someOne
 
174 / 432 (15) +++++++
Регистрация: 11.12.2008
Адрес: Москва
Заметил странное поведение 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));
}
Возвращает false, а
X++:
static client void test2()
{
    SysDictField    sysDictField = new SysDictField(tablenum(PurchTable), fieldnum(PurchTable, PurchId));
    boolean         visible;
    ;
    visible = sysDictField.visible();

    info(strfmt("%1", visible));
}
Возвращает true

Это, в свою очередь, влияет на работу формы фильтрации 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).
Старый 02.03.2020, 18:57   #2  
Maximin is offline
Maximin
NavAx
NavAx Club
 
415 / 361 (13) ++++++
Регистрация: 09.10.2002
Адрес: Москва
В порядке некропостинга.

В 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).
Теги
ax2009, ax4.0, sysdictfield, sysqueryform

 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Ошибка XML в "Таблица" Причина: Ошибочное значение Poleax DAX: Программирование 7 08.10.2009 16:45
теряется значение переменной laxel DAX: Программирование 3 05.02.2009 10:07
Visible для FormListItem petr DAX: Программирование 3 30.09.2008 11:03
Не берется значение контрола Sada DAX: Программирование 11 21.06.2006 10:24
Как при вводе новой записи установить значение поля по умолчанию Zman DAX: Программирование 3 17.01.2005 10:23

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 20:29.