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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 16.11.2009, 10:36   #1  
Tarasov E is offline
Tarasov E
Участник
Аватар для Tarasov E
 
100 / 11 (1) +
Регистрация: 01.09.2009
Цитата:
Сообщение от a33ik Посмотреть сообщение
CrmService.Update - подойдёт?
В примере в одном видел подобный метод, там шла работа со стандартными CRM'овскими сущностями.
А каким образом загнать новое значение в запись пользовательской сущности new_web, которая породила бизнес-процесс?
Старый 16.11.2009, 11:31   #2  
a33ik is offline
a33ik
Чайный пьяница
Аватар для a33ik
MCP
MCBMSS
Злыдни
Соотечественники
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,243 / 896 (36) +++++++
Регистрация: 02.07.2008
Адрес: Greenville, SC
Цитата:
Сообщение от Tarasov E Посмотреть сообщение
В примере в одном видел подобный метод, там шла работа со стандартными CRM'овскими сущностями.
А каким образом загнать новое значение в запись пользовательской сущности new_web, которая породила бизнес-процесс?
Через DynamicEntity.
__________________
Эмо разработчик, сначала пишу код, потом плачу над его несовершенством.

Подписывайтесь на мой блог, twitter и YouTube канал.
Пользуйтесь моим Ultimate Workflow Toolkit
Старый 16.11.2009, 11:50   #3  
Tarasov E is offline
Tarasov E
Участник
Аватар для Tarasov E
 
100 / 11 (1) +
Регистрация: 01.09.2009
Цитата:
Сообщение от a33ik Посмотреть сообщение
Через DynamicEntity.
В случае с Retrieve делал так:
Код:
targetRetrieve.EntityName = _entitytype;
 targetRetrieve.EntityId = _entityid;
,
но в случае в update не знаю как передать айдишник вызвавшей бизнес-процесс записи. Делаю пока только так:
Код:
targetUpdate.Entity.Name = _entitytype;
Старый 16.11.2009, 12:17   #4  
a33ik is offline
a33ik
Чайный пьяница
Аватар для a33ik
MCP
MCBMSS
Злыдни
Соотечественники
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,243 / 896 (36) +++++++
Регистрация: 02.07.2008
Адрес: Greenville, SC
Цитата:
Сообщение от Tarasov E Посмотреть сообщение
В случае с Retrieve делал так:
Код:
targetRetrieve.EntityName = _entitytype;
 targetRetrieve.EntityId = _entityid;
,
но в случае в update не знаю как передать айдишник вызвавшей бизнес-процесс записи. Делаю пока только так:
Код:
targetUpdate.Entity.Name = _entitytype;
Есть же поисковые механизмы... Например один из результатов:
http://nishantrana.wordpress.com/200...t-dynamic-crm/
__________________
Эмо разработчик, сначала пишу код, потом плачу над его несовершенством.

Подписывайтесь на мой блог, twitter и YouTube канал.
Пользуйтесь моим Ultimate Workflow Toolkit
За это сообщение автора поблагодарили: Tarasov E (1).
Старый 19.11.2009, 12:34   #5  
Tarasov E is offline
Tarasov E
Участник
Аватар для Tarasov E
 
100 / 11 (1) +
Регистрация: 01.09.2009
Воспользовался данным примером, но поле new_scandate не обновилось. Возможно ошибка в настройках CRM сервиса?
Вот код:
Код:
protected override ActivityExecutionStatus Execute(ActivityExecutionContext executionContext)
        {
            //Настройка CRM сервиса
            CrmAuthenticationToken myToken = new CrmAuthenticationToken();
            myToken.OrganizationName = "Keysystems";
            myToken.AuthenticationType = 0;
            CrmService myService = new CrmService();
            myService.Credentials = System.Net.CredentialCache.DefaultCredentials;
            myService.Url = "http://vms:5555/MSCrmServices/2007/CrmService.asmx";
            myService.CrmAuthenticationTokenValue = myToken;
            //получение контекста
            IContextService contextService = (IContextService)executionContext.GetService(typeof(IContextService));
            IWorkflowContext workflowContext = contextService.Context;
            ICrmService service = contextService.Context.CreateCrmService(false);
            //Получаем идентификатор записи, породившей запуск бизнес-процесса
            Guid _entityid = workflowContext.PrimaryEntityId;
            string _entitytype = workflowContext.PrimaryEntityName;
            //указываем, какие атрибуты надо получить из CRM
            //ColumnSet cols = new ColumnSet();
            //cols.AddColumns(new string[] {"new_url"});
            //Указываем ID записи, у которой надо получить атрибуты
            TargetRetrieveDynamic targetRetrieve = new TargetRetrieveDynamic();
            targetRetrieve.EntityName = _entitytype;
            targetRetrieve.EntityId = _entityid;
            //устанавливаем свойства метода RetrieveResponse
            RetrieveRequest retrieve = new RetrieveRequest();
            retrieve.Target = targetRetrieve;//из какой записи берем
            retrieve.ColumnSet = new AllColumns();//что берем
            retrieve.ReturnDynamicEntities = true;//о_О
            RetrieveResponse retrieved = (RetrieveResponse)service.Execute(retrieve);
            //Получили саму запись
            DynamicEntity retrievedEntity = (DynamicEntity)retrieved.BusinessEntity;
            //Получили необходимые атрибуты записи
            CrmDateTime sdt = retrievedEntity.Properties.Contains("new_scandate") ? (CrmDateTime)retrievedEntity["new_scandate"] : CrmDateTime.Now;
            string period = retrievedEntity.Properties.Contains("new_periodical") ? (string)retrievedEntity["new_periodical"]: string.Empty;
            double hours = Convert.ToDouble(period);
            DateTime time = Convert.ToDateTime(sdt.Value);
            CrmDateTime dateTime = new CrmDateTime();
            dateTime.Value = time.AddHours(hours).ToString("yyyy-MM-ddTHH:mm:ss")+"+03:00";
           
 //Обновление записи в CRM
            DynamicEntity myDEUpdate = new DynamicEntity();
            myDEUpdate.Name = "new_web";
            KeyProperty myContactGuid = new KeyProperty();
            myContactGuid.Name = "new_webid";
            Key myContactKey=new Key();
            myContactKey.Value=_entityid; //идентификатор записи породившей бизнес-процесс
            myContactGuid.Value = myContactKey;
            myDEUpdate.Properties.Add(myContactGuid);
            // Create a StringProperty with the new updated value
            StringProperty myDateU = new StringProperty();
            myDateU.Name = "new_scandate";
            myDateU.Value = dateTime.Value; ;
            myDEUpdate.Properties.Add(myDateU);
            try
                {
                myService.Update(myDEUpdate);
                }
            catch (SoapException ex)
                {
                    MessageBox.Show(ex.Detail.InnerXml);
                }
                        
             return base.Execute(executionContext);
        }
Старый 19.11.2009, 12:53   #6  
a33ik is offline
a33ik
Чайный пьяница
Аватар для a33ik
MCP
MCBMSS
Злыдни
Соотечественники
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,243 / 896 (36) +++++++
Регистрация: 02.07.2008
Адрес: Greenville, SC
Цитата:
Сообщение от Tarasov E Посмотреть сообщение
Воспользовался данным примером, но поле new_scandate не обновилось. Возможно ошибка в настройках CRM сервиса?
Вот код:
Код:
protected override ActivityExecutionStatus Execute(ActivityExecutionContext executionContext)
        {
            //Настройка CRM сервиса
            CrmAuthenticationToken myToken = new CrmAuthenticationToken();
            myToken.OrganizationName = "Keysystems";
            myToken.AuthenticationType = 0;
            CrmService myService = new CrmService();
            myService.Credentials = System.Net.CredentialCache.DefaultCredentials;
            myService.Url = "http://vms:5555/MSCrmServices/2007/CrmService.asmx";
            myService.CrmAuthenticationTokenValue = myToken;
            //получение контекста
            IContextService contextService = (IContextService)executionContext.GetService(typeof(IContextService));
            IWorkflowContext workflowContext = contextService.Context;
            ICrmService service = contextService.Context.CreateCrmService(false);
            //Получаем идентификатор записи, породившей запуск бизнес-процесса
            Guid _entityid = workflowContext.PrimaryEntityId;
            string _entitytype = workflowContext.PrimaryEntityName;
            //указываем, какие атрибуты надо получить из CRM
            //ColumnSet cols = new ColumnSet();
            //cols.AddColumns(new string[] {"new_url"});
            //Указываем ID записи, у которой надо получить атрибуты
            TargetRetrieveDynamic targetRetrieve = new TargetRetrieveDynamic();
            targetRetrieve.EntityName = _entitytype;
            targetRetrieve.EntityId = _entityid;
            //устанавливаем свойства метода RetrieveResponse
            RetrieveRequest retrieve = new RetrieveRequest();
            retrieve.Target = targetRetrieve;//из какой записи берем
            retrieve.ColumnSet = new AllColumns();//что берем
            retrieve.ReturnDynamicEntities = true;//о_О
            RetrieveResponse retrieved = (RetrieveResponse)service.Execute(retrieve);
            //Получили саму запись
            DynamicEntity retrievedEntity = (DynamicEntity)retrieved.BusinessEntity;
            //Получили необходимые атрибуты записи
            CrmDateTime sdt = retrievedEntity.Properties.Contains("new_scandate") ? (CrmDateTime)retrievedEntity["new_scandate"] : CrmDateTime.Now;
            string period = retrievedEntity.Properties.Contains("new_periodical") ? (string)retrievedEntity["new_periodical"]: string.Empty;
            double hours = Convert.ToDouble(period);
            DateTime time = Convert.ToDateTime(sdt.Value);
            CrmDateTime dateTime = new CrmDateTime();
            dateTime.Value = time.AddHours(hours).ToString("yyyy-MM-ddTHH:mm:ss")+"+03:00";
           
 //Обновление записи в CRM
            DynamicEntity myDEUpdate = new DynamicEntity();
            myDEUpdate.Name = "new_web";
            KeyProperty myContactGuid = new KeyProperty();
            myContactGuid.Name = "new_webid";
            Key myContactKey=new Key();
            myContactKey.Value=_entityid; //идентификатор записи породившей бизнес-процесс
            myContactGuid.Value = myContactKey;
            myDEUpdate.Properties.Add(myContactGuid);
            // Create a StringProperty with the new updated value
            StringProperty myDateU = new StringProperty();
            myDateU.Name = "new_scandate";
            myDateU.Value = dateTime.Value; ;
            myDEUpdate.Properties.Add(myDateU);
            try
                {
                myService.Update(myDEUpdate);
                }
            catch (SoapException ex)
                {
                    MessageBox.Show(ex.Detail.InnerXml);
                }
                        
             return base.Execute(executionContext);
        }
Тяжело чтото сказать вразумительное. Отлаживайте.
__________________
Эмо разработчик, сначала пишу код, потом плачу над его несовершенством.

Подписывайтесь на мой блог, twitter и YouTube канал.
Пользуйтесь моим Ultimate Workflow Toolkit
Старый 24.11.2009, 08:53   #7  
Tarasov E is offline
Tarasov E
Участник
Аватар для Tarasov E
 
100 / 11 (1) +
Регистрация: 01.09.2009
Доброе утро! Для отладки стал регистрировать стэп на Disk и при регистрации мне вернулась вот такая ошибка:
Код:
Unhandled Exception: System.Web.Services.Protocols.SoapException: Server was unable to process request.
Detail: <detail><error>
  <code>0x80040216</code>
  <description>An unexpected error occurred.</description>
  <type>Platform</type>
</error></detail>
   в System.Web.Services.Protocols.SoapHttpClientProtocol.ReadResponse(SoapClientMessage message, WebResponse response, Stream responseStream, Boolean asyncCall)
   в System.Web.Services.Protocols.SoapHttpClientProtocol.Invoke(String methodName, Object[] parameters)
   в PluginRegistrationTool.CrmSdk.CrmService.Create(BusinessEntity entity)
   в PluginRegistrationTool.RegistrationHelper.RegisterPluginType(CrmOrganization org, CrmPlugin plugin)
   в PluginRegistrationTool.PluginRegistrationForm.btnRegister_Click(Object sender, EventArgs e)
Из-за чего может возникать данная ошибка? При регистрации в Database все было нормально...
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Бизнес-процесс висит в состоянии ожидания Evgenia_f Dynamics CRM: Функционал 70 21.12.2009 18:53
Странности бизнес-процесса на изменение атрибутов записи SLK Dynamics CRM: Функционал 6 19.05.2009 08:14
Событие "Назначение записи" для бизнес-процесса Lazarus Dynamics CRM: Функционал 1 22.01.2009 19:54
Работает неопубликованный бизнес-процесс sergeyjb Dynamics CRM: Разработка 1 22.12.2008 09:16
Бизнес-процесс и список ожидания Evgenia_f Dynamics CRM: Разработка 16 07.10.2008 16:22

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

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

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 12:37.
Powered by vBulletin® v3.8.5. Перевод: zCarot
Контактная информация, Реклама.