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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 04.03.2008, 16:19   #1  
HorrR is offline
HorrR
Участник
 
340 / 30 (2) +++
Регистрация: 18.02.2008
Адрес: Киев
Red face TwC: Validate access to return value from display/edit method.
Ребята, вероятно мой вопрос окажется бояном, но я честно искал и не нашел(
Итак, следующий BP: TwC: Validate access to return value from display/edit method.

Вот собсна метод.
X++:
display Addressing address()
{
    Addressing address;
    ;
    address=Address::find(this.TableId, this.RecId, AddressType::Delivery).Address;
    if(!(hasSecurityKeyAccess(securitykeyNum(My_SK), AccessType::View))
      &&isConfigurationkeyEnabled(configurationkeyNum(MY_CK))  )
    {
        throw error("@SYS57330");
    }
    return address;
}
То есть, как видите, валидейшен я провожу, но компилю его видимо мало. Что ещё надо проверять?
__________________
Axapta has seduced me deadly!
Старый 04.03.2008, 16:29   #2  
kashperuk is offline
kashperuk
Участник
Аватар для kashperuk
MCBMSS
Соотечественники
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,361 / 2084 (78) +++++++++
Регистрация: 30.05.2004
Адрес: Atlanta, GA, USA
//BP Deviation Documented
перед названием метода влепи.
Старый 04.03.2008, 16:42   #3  
HorrR is offline
HorrR
Участник
 
340 / 30 (2) +++
Регистрация: 18.02.2008
Адрес: Киев
Да это ясно) Просто хотелось без такой гадости, хотя посмотрел стандартный функционал, там тоже не смотря на проверки, сверху документируеццо БП. А потом всё-таки отрыл на форуме похожую тему и тут стало всё свои на места:
Цитата:
Так как дисплей/едит метод может возвращать данные с другой таблицы, к которой у вас может и не быть доступа, это предупреждение выводится, чтобы вы проверили, возможно ли такое нарушение секурити - поставили например проверку на конфигурейшен и секурити ключи.
И это чисто на совести программиста, потому что можно ситуацию исправить упомянутой уже строчкой .
И, кстати, бест практис не оценивает содержимое метода, а просто всегда бросает ошибку, если видит ключевые слова дисплей/едит.
А я то дурень полагал, что компиль сцобако умный и отслеживает какие-то небезопасные связи)
__________________
Axapta has seduced me deadly!

Последний раз редактировалось HorrR; 04.03.2008 в 16:53.
Старый 04.03.2008, 18:03   #4  
Vadik is offline
Vadik
Модератор
Аватар для Vadik
Лучший по профессии 2017
Лучший по профессии 2015
 
3,631 / 1849 (69) ++++++++
Регистрация: 18.11.2002
Адрес: гражданин Москвы
Таким образом достигается zero X++ best practice errors in the SYS layer ?

__________________
-ТСЯ или -ТЬСЯ ?
Старый 04.03.2008, 18:22   #5  
kashperuk is offline
kashperuk
Участник
Аватар для kashperuk
MCBMSS
Соотечественники
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,361 / 2084 (78) +++++++++
Регистрация: 30.05.2004
Адрес: Atlanta, GA, USA
На самом деле все ж хорошо.
В том смысле, что это так специально сделано.

Компилятор будет выдавать предупреждение до тех пор, пока программист не проанализирует код, и не напишет его так, чтобы учитывать права доступа. После этого он, как бы, выставляет флажок, что, мол, проверено - права учитываются. А флажок этот - это как раз этот комментарий
Старый 04.03.2008, 19:32   #6  
belugin is offline
belugin
Участник
Аватар для belugin
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,622 / 2925 (107) +++++++++
Регистрация: 16.01.2004
Записей в блоге: 5
Интересно, они действительно это проверяют?
Старый 04.03.2008, 20:04   #7  
Eldar9x is offline
Eldar9x
MCTS
Аватар для Eldar9x
Oracle
MCBMSS
 
1,064 / 166 (8) ++++++
Регистрация: 29.09.2006
Адрес: Казань
Цитата:
А флажок этот - это как раз этот комментарий
С каких пор комментарии стали инструкциями для компилятора ?
Старый 04.03.2008, 23:56   #8  
kashperuk is offline
kashperuk
Участник
Аватар для kashperuk
MCBMSS
Соотечественники
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,361 / 2084 (78) +++++++++
Регистрация: 30.05.2004
Адрес: Atlanta, GA, USA
Цитата:
Сообщение от Eldar9x Посмотреть сообщение
С каких пор комментарии стали инструкциями для компилятора ?
А это не компилятор делает.
Это тулзень, вызываемая во время компиляции - совсем разные вещи.
Код, кстати, вдруг кто не знает, можно посмотреть/подкорректировать в классах, которые начинаются на SysBPCheck


Цитата:
Сообщение от belugin
Интересно, они действительно это проверяют?
Должны. Хотя, думаю, что в реалити получается все то же правило 80/20.

Последний раз редактировалось kashperuk; 05.03.2008 в 11:27.
Старый 05.03.2008, 11:22   #9  
Eldar9x is offline
Eldar9x
MCTS
Аватар для Eldar9x
Oracle
MCBMSS
 
1,064 / 166 (8) ++++++
Регистрация: 29.09.2006
Адрес: Казань
[offtop]
Хотел было написать "выглядит дико", но тут вспомнилось "// TODO", хотя опять же, кажется, это MS фича.
Когда искал решение этой проблемы, то привел вид метода edit, в точности к виду какого-то edit метода на SYS слое, за исключением того самого комментария. Предупреждение осталось. Была мысль, что это комментарий виноват, но отбросили ее как бредовую . Пока, наконец, не заглянули на форум...
[/offtop]
Старый 05.03.2008, 11:48   #10  
belugin is offline
belugin
Участник
Аватар для belugin
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,622 / 2925 (107) +++++++++
Регистрация: 16.01.2004
Записей в блоге: 5
Советую еще прочитать:

http://download.microsoft.com/downlo...X++%20Code.doc
За это сообщение автора поблагодарили: HorrR (1).
Старый 05.03.2008, 12:17   #11  
HorrR is offline
HorrR
Участник
 
340 / 30 (2) +++
Регистрация: 18.02.2008
Адрес: Киев
Предполагаю, что со всеми TWC BP та же ситуёвина. Как минимум с тем, что ругается на Assert.
__________________
Axapta has seduced me deadly!
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
axaptapedia: Display method Blog bot DAX Blogs 0 29.08.2007 16:30
TwC: Validate access to return value from display/edit method. алька DAX: Программирование 3 20.04.2007 14:15
Говорят вышел SP2 для Axapta 3. Кто нибуть что знает на эту тему? soin DAX: Прочие вопросы 10 13.10.2003 10:43
display() method on Grid Control DK DAX: Программирование 5 31.01.2003 22:09
edit и display методы Maxim Gorbunov DAX: База знаний и проекты 4 15.01.2002 12:58

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

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

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