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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 04.01.2011, 04:33   #14  
gl00mie is offline
gl00mie
Участник
MCBMSS
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,684 / 5803 (201) ++++++++++
Регистрация: 28.11.2005
Адрес: Москва
Записей в блоге: 3
На базе приведенного примера сделал джобик, который позволяет "поднять" конфигурационный ключ на таблицах с нижележащего слоя, если на текущем слое он после обновления или еще каких действий получился "неправильный". В режиме проверки (если на вопрос "изменять конф. ключи" ответить "Нет") только выводит информацию о найденных расхождениях. Если прописываемый ключ оказался выключенным, а прежний - включенным, выводится предупреждение и запрашивается дополнительное подтверждение. Но в любом случае до синхронизации изменения не вступят в силу.
X++:
#macrolib.Properties
static void ChangeConfigurationKey(Args _args)
{
    UtilElements    ueCurrLayer;
    UtilElements    uePrevLayer;
    CheckFix        modeCheckFix;
    Counter         nChanged;
    Counter         nFound;

    boolean tryChangeConfigKey4Table(UtilElements _ue, UtilEntryLevel _prevLayer)
    {
        SysInfoAction       infoAction;
        TreeNode            tnCurr;
        TreeNode            tnPrev;
        configurationkeyid  currKeyId;
        configurationkeyid  prevKeyId;
        str                 currKeyName;
        str                 prevKeyName;
        str                 warnMsg;
        boolean             isConfirmed;
        boolean             ret;
        ;
        setprefix( strfmt( "@SYS55826", _ue.name ) );
        if (_ue.utilLevel <= _prevLayer)
        {
            throw error( Error::wrongUseOfFunction( funcname() ) );
        }
        tnCurr = xUtilElements::getNode( _ue );
        if (tnCurr)
        {
            tnPrev = tnCurr.getNodeInLayer( _prevLayer, false );
        }
        if (tnPrev)
        {
            currKeyName = findProperty( tnCurr.AOTgetProperties(), #PropertyConfigurationkey );
            prevKeyName = findProperty( tnPrev.AOTgetProperties(), #PropertyConfigurationkey );
            if (currKeyName != prevKeyName)
            {
                infoAction = new SysInfoAction_Properties( tnCurr.treeNodePath() );
                info( strfmt( @"Конф.ключ на %1 (%2) отличается от %3 (%4)", tnCurr.applObjectLayer(), currKeyName, _prevLayer, prevKeyName ), '', infoAction );
                currKeyId = configurationkeyname2id( currKeyName );
                prevKeyId = configurationkeyname2id( prevKeyName );
                isConfirmed = modeCheckFix == CheckFix::Fix;
                if (   !isConfigurationKeyEnabled( prevKeyId )
                    &&  isConfigurationKeyEnabled( currKeyId )
                   )
                {
                    warnMsg = strfmt( @"Конфигурационный ключ %1 выключен, изменения могут привести к потере данных", prevKeyName );
                    if (modeCheckFix == CheckFix::Fix)
                    {
                        isConfirmed = Box::yesNo( warnMsg + @". Все равно изменить?", DialogButton::No, "@SYS866" ) == DialogButton::Yes;
                    }
                    else
                    {
                        warning( warnMsg );
                    }
                }
                if (isConfirmed)
                {
                    tnCurr.AOTsetProperties( setProperty( tnCurr.AOTgetProperties(), #PropertyConfigurationkey, prevKeyName ) );
                    tnCurr.AOTsave();
                    tnCurr.AOTcompile();
                    info( prevKeyName ? strfmt( @"Ключ изменен на %1", prevKeyName ) : @"Ключ удален" );
                    ret = true;
                }
            }
        }
        return ret;
    }
    ;
    setprefix( @"Перебивка конфигурационных ключей на таблицах" );
    switch (Box::yesNoCancel( @"Изменять конфигурационные ключи?", DialogButton::No ))
    {
        case DialogButton::Yes :
            modeCheckFix = CheckFix::Fix;
            break;
        case DialogButton::Cancel :
            error( "@SYS18738" );
            return;
        default :
            break;
    }
    while select ueCurrLayer
        where   ueCurrLayer.utilLevel   == currentAOLayer()
            &&  ueCurrLayer.recordType  == UtilElementType::Table
    {
        select firstonly reverse utilLevel, RecId
            from    uePrevLayer
            order by utilLevel
            where   uePrevLayer.name        == ueCurrLayer.name
                &&  uePrevLayer.recordType  == ueCurrLayer.recordType
                &&  uePrevLayer.utilLevel   <  ueCurrLayer.utilLevel
                    ;
        if (uePrevLayer)
        {
            nFound++;
            if (tryChangeConfigKey4Table( ueCurrLayer, uePrevLayer.utilLevel ))
            {
                nChanged++;
            }
        }
    }
    info( strfmt( @"Обработано таблиц: %1, изменено %2", nFound, nChanged ) );
}
Теги
ax2009, законченный пример, конфигурационный ключ, таблица

 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Смена доступа на таблицу в конкретной форме Perc DAX: Программирование 5 05.11.2006 23:08
Настройка прав доступа??? nicko DAX: Администрирование 9 23.03.2006 09:36
Разграничение доступа на записи Роман Кошелев DAX: Функционал 11 26.07.2004 10:56
Что имеет наибольший приоритет при настройке прав доступа? tov DAX: Администрирование 11 19.07.2003 10:19
Проблемы настройки прав доступа пользователям axot DAX: Администрирование 25 16.05.2002 10:47
Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

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

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

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