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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 26.03.2020, 16:15   #1  
Ion is offline
Ion
Участник
 
332 / 16 (1) ++
Регистрация: 19.12.2012
Generate CRM Reports
Привет.

В данный момент пытаюсь сгенерировать репорт в консольном приложении. Для этого предварительно уже зарегистрировал приложение в Ажуре, успешно получаю токен и могу с ним кверить сущности через постман.

Теперь проблема с этим токен достучатся до СРМ

Насколько концептуально понимаю - надо делать два запроса
  • Один на "/CRMReports/rsviewer/reportviewer.aspx"
  • Второй на "/Reserved.ReportViewerWebControl.axd";



X++:
        private Tuple<string, string> GetReportSession(Entity report, string parameters)
        {
            var name = report.GetAttributeValue<string>("reportnameonsrs");
            var isCustom = name == null;

            var url = "/CRMReports/rsviewer/reportviewer.aspx";
            var data = new Dictionary<string, dynamic>()
            {
                ["id"] = report.Id.ToString("B"),
                ["uniquename"] = "org15604879",
                ["reporttypecode"] = "1",
                ["reportName"] = "Quote Bundle Details",
                ["isScheduledReport"] = "false",
                ["CRM_FilterText"] = "Quotes",
                ["iscustomreport"] = isCustom.ToString().ToLower(),
                ["reportnameonsrs"] = name,
                ["CRM_Filter"] = "<ReportFilter><ReportEntity+paramname='CRM_quote'+displayname='Quotes'+donotconvert='1'><fetch+version='1.0'+output-format='xml-platform'+mapping='logical'+distinct='false'><entity+name='quote'><all-attributes/><filter+type='and'><condition+attribute='quoteid'+operator='eq'+uiname='#+mm+test+1000'+uitype='quote'+value='c63b402d-ef0a-ea11-a811-002248078004'/></filter></entity></fetch></ReportEntity></ReportFilter>"
            };

            var response = Encoding.UTF8.GetString(GetResponse(GetRequest("POST", url, UrlEncode(data))));
            var sessionId = response.Substring(response.LastIndexOf("ReportSession=") + 14, 24);
            var controlId = response.Substring(response.LastIndexOf("ControlID=") + 10, 32);

            return new Tuple<string, string>(sessionId, controlId);
        }

X++:
        public byte[] RenderReport(Entity report, string format, string parameters)
        {
            var session = GetReportSession(report, parameters);

            var url = "/Reserved.ReportViewerWebControl.axd";
            var lcid = report.GetAttributeValue<int>("languagecode");
            format = format.ToUpper();
            if (format == "WORD" || format == "EXCEL")
            {
                format = format + "OPENXML";
            }
            var data = new Dictionary<string, dynamic>()
            {
                ["OpType"] = "Export",
                ["Format"] = format,
                ["ContentDisposition"] = "AlwaysAttachment",
                ["FileName"] = string.Empty,
                ["Culture"] = lcid.ToString(),
                ["CultureOverrides"] = "False",
                ["UICulture"] = lcid.ToString(),
                ["UICultureOverrides"] = "False",
                ["ReportSession"] = session.Item1,
                ["ControlID"] = session.Item2
            };

            return GetResponse(GetRequest("GET", $"{url}?{UrlEncode(data)}"));
        }
Проблема в том, что когда делаю первый запрос на /CRMReports/rsviewer/reportviewer.aspx в респонсе вижу вообще непонятную ошибку

Последний раз редактировалось Ion; 26.03.2020 в 16:21.
Старый 26.03.2020, 16:18   #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
Сам таким не занимался, но вы можете посмотреть как подобное делается тут - https://github.com/bguidinger/Xrm.ReportScheduler
__________________
Эмо разработчик, сначала пишу код, потом плачу над его несовершенством.

Подписывайтесь на мой блог, twitter и YouTube канал.
Пользуйтесь моим Ultimate Workflow Toolkit
За это сообщение автора поблагодарили: Roman08 (1).
Старый 27.03.2020, 19:41   #3  
Ion is offline
Ion
Участник
 
332 / 16 (1) ++
Регистрация: 19.12.2012
Цитата:
Сообщение от a33ik Посмотреть сообщение
Сам таким не занимался, но вы можете посмотреть как подобное делается тут - https://github.com/bguidinger/Xrm.ReportScheduler
Спасибо, по сути это и есть тот же код))
Может быть дело в секюрити АД
Старый 27.03.2020, 20:53   #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
По правде говоря в изначальном посте кода не было. Апдейт вы выложили на 3 минуты позже, чем я выложил ссылку.
А вот по поводу самого кода - не подскажу - не было необходимости именно в такой функциональности.
__________________
Эмо разработчик, сначала пишу код, потом плачу над его несовершенством.

Подписывайтесь на мой блог, twitter и YouTube канал.
Пользуйтесь моим Ultimate Workflow Toolkit
Старый 30.03.2020, 13:26   #5  
Ion is offline
Ion
Участник
 
332 / 16 (1) ++
Регистрация: 19.12.2012
Цитата:
Сообщение от a33ik Посмотреть сообщение
По правде говоря в изначальном посте кода не было. Апдейт вы выложили на 3 минуты позже, чем я выложил ссылку.
А вот по поводу самого кода - не подскажу - не было необходимости именно в такой функциональности.
Значит Вы бысто отреагировали на сообщение - не видел ваш коммент. Суть проблемы была в настройках Conditional access
Старый 30.03.2020, 15:26   #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
Цитата:
Сообщение от Ion Посмотреть сообщение
Суть проблемы была в настройках Conditional access
А поподробнее расскажете? Интересно же.
__________________
Эмо разработчик, сначала пишу код, потом плачу над его несовершенством.

Подписывайтесь на мой блог, twitter и YouTube канал.
Пользуйтесь моим Ultimate Workflow Toolkit
Старый 07.04.2020, 14:54   #7  
Ion is offline
Ion
Участник
 
332 / 16 (1) ++
Регистрация: 19.12.2012
Цитата:
Сообщение от a33ik Посмотреть сообщение
А поподробнее расскажете? Интересно же.
Я бы с большим удовольствием рассказал бы, но проблему решили админы. У меня к нет доступа к ажуру клиента!
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
crminthefield: Podcast and Overview: Microsoft Dynamics CRM 2011 Update Rollup 15 Blog bot Dynamics CRM: Blogs 1 10.02.2016 10:26
crminthefield: Podcast and Overview: Microsoft Dynamics CRM 2011 Update Rollup 17 Blog bot Dynamics CRM: Blogs 0 10.05.2014 06:30
crminthefield: Podcast and Overview: Microsoft Dynamics CRM 2013 Update Rollup 2 Blog bot Dynamics CRM: Blogs 0 15.04.2014 01:15
crminthefield: Podcast and Overview: Microsoft Dynamics CRM 2011 Update Rollup 16 Blog bot Dynamics CRM: Blogs 0 23.01.2014 03:15
crminthefield: Podcast and Overview: Microsoft Dynamics CRM 2011 Update Rollup 10 Blog bot Dynamics CRM: Blogs 0 17.08.2012 03:27

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

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

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