Сервисы интеграции. Уведомления через колокольчик

10.07.24

Интеграция - Перенос данных 1C

Отправим уведомление и ссылку на документ через колокольчик списку пользователей.

Часть процедур и функций была взята из статьи Сервисы интеграции без Шины и интеграции

Добавим новый сервис интеграции Д_Оповещения и канал Д_ОповещениеПользователей (направление сообщений Отправка)

 

 

 

Добавим общий модуль Д_ОповещениеПользователей (сервер, вызов сервера, привилегированный)

 

 

 

Добавим в этот модуль ниже перечисленные процедуры и функции

 
Д_ОповещениеПользователей

 

Найдем обработку БСП ТекущиеДела

 

 

 

В форму обработки ТекущиеДела добавим новую глобальную переменную, в событие ПриОткрытии добавим обработчик ожидания процедуру ПолучитьСообщенияДляОповещения каждые 15 секунд (можно событие ПриОткрытии перенести в расширение)

 

 

//КЕ
&НаКлиенте
Перем СтруктураПользователяФормы; 
//КЕ


&НаКлиенте
Процедура ПриОткрытии(Отказ)
	
	//КЕ  
	СтруктураПользователяФормы = Д_ОповещениеПользователей.ПолучитьСтруктуруПользователя();
	ПодключитьОбработчикОжидания("ПолучитьСообщенияДляОповещения", 15, Ложь);
	//КЕ
	
КонецПроцедуры 

//КЕ
&НаКлиенте
Процедура ПолучитьСообщенияДляОповещения()
	
	МассивСообщений = Д_ОповещениеПользователей.ПолучитьСообщения("Д_Оповещения", "Д_ОповещениеПользователей", СтруктураПользователяФормы);	
	Если МассивСообщений.Количество() > 0 Тогда
		Для Каждого ТекСообщение Из МассивСообщений Цикл 
			
			Если Не ТекСообщение.Свойство("Сообщение") Тогда 				
				Продолжить;
			КонецЕсли;	
			
			Если ТекСообщение.Свойство("НавигационнаяСсылка") Тогда	 	
				ПоказатьОповещениеПользователя(ТекСообщение.Сообщение
				,ТекСообщение.НавигационнаяСсылка
				,?(ТекСообщение.Свойство("Отправитель"),ТекСообщение.Отправитель,""),
				,СтатусОповещенияПользователя.Важное
				,ТекСообщение.Идентификатор);
				
			Иначе	
				ПоказатьОповещениеПользователя(ТекСообщение.Сообщение,
				,?(ТекСообщение.Свойство("Отправитель"),ТекСообщение.Отправитель,""),
				,СтатусОповещенияПользователя.Важное
				,ТекСообщение.Идентификатор);
			КонецЕсли;			
			
		КонецЦикла;
		
		
		Д_ОповещениеПользователей.ОчиститьВсеСообщенияНаСервере("Д_Оповещения", "Д_ОповещениеПользователей", МассивСообщений);			
	КонецЕсли;	
	
КонецПроцедуры    
//КЕ

 

Откроем стандартную обработку Управление сервисами интеграции, поставим галочку на новый сервис интеграции Оповещения

 

 

 

 

Создадим внешнюю обработку для теста сервиса интеграции. Со списком получатели (пользователи), полем сообщение (Строка), полем документ (ссылка на заказ покупателя)

 

 

 

В модуль формы внешней обработки добавим процедуры

 

 

&НаСервере
Процедура ОтправитьСообщениеВКолокольчикНаСервере()      
	
	МассивПолучатели = Получатели.Выгрузить().ВыгрузитьКолонку("Пользователь");
	Д_ОповещениеПользователей.ОтправитьСообщениеКолокольчикПользователям(МассивПолучатели,Сообщение,Док);
	
КонецПроцедуры 

&НаКлиенте
Процедура ОтправитьСообщениеВКолокольчик(Команда)      
	
	ОтправитьСообщениеВКолокольчикНаСервере();
	
КонецПроцедуры

 

Отправляем сообщение себе и другому пользователю с ссылкой на документ Заказ покупателя

 

 

 

Тестировал: 

  • Библиотека стандартных подсистем, редакция 3.1 (3.1.9.337)
  • 1С:Комплексная автоматизация 2 (2.4.13.209)
  • Платформа 1С:Предприятие 8.3 (8.3.24.1342)

Сервисы интеграции колокольчик

См. также

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Россия Платные (руб)

Правила в универсальном формате обмена для ERP 2.5, КА 2.5, УТ 11.5, БП 3.0, Розница, УНФ, для последних версий конфигураций. Ссылки на другие конфигурации в описании публикации. Правила совместимы со всеми другими версиями конфигураций новыми и старыми, поддерживающими обмен и синхронизацию в формате EnterpriseData. Не требуется синхронного обновления правил после обновления другой конфигурации, участвующей в обмене. Типовой обмен через планы обмена кнопкой Синхронизация вручную или автоматически по расписанию, или вручную обработкой.

27660 руб.

12.06.2017    143320    821    297    

428

SALE! 10%

Перенос данных 1C Программист Платформа 1С v8.3 1С:Управление производственным предприятием 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Платные (руб)

Перенос документов, начальных остатков и справочной информации из УПП 1.3 в ERP 2 | из УПП 1.3 в УТ 11 | из УПП в КА 2 | Правила конвертации (КД 2) | Более 360 предприятий выполнили переход с использованием этого продукта! | Сэкономьте время - используйте готовое решение для перехода! | Позволяет перенести из УПП 1.3 в ERP / УТ 11 / КА 2 всю возможную информацию | В переносе есть фильтр по организации и множество других опциональных параметров выгрузки | Есть несколько алгоритмов выгрузки остатков на выбор

55778 50200 руб.

04.08.2015    168352    344    279    

380

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 Оперативный учет 1С:Управление торговлей 10 Россия Управленческий учет Платные (руб)

Перенос данных из 1С:Управление торговлей 10.3 в 1С:Управление торговлей 11.5 с помощью правил обмена. Переносятся остатки, документы (обороты за период), справочная информация. Правила проверены на конфигурациях УТ 10.3 (10.3.88.x) и УТ 11.5 (11.5.20.x), также подходят для релиза 11.5 (11.5.19.x).

35000 31500 руб.

23.07.2020    53410    236    73    

192

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 1С:Управление производственным предприятием 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Управленческий учет Платные (руб)

Перенос данных из 1С:Управление производственным предприятием 1.3 в 1С:Бухгалтерия предприятия 3.0 с помощью правил обмена. Переносятся остатки, документы (обороты за период), справочная информация. Правила проверены на конфигурациях УПП 1.3 (1.3.237.x) и БП 3.0 (3.0.166.x). Правила подходят для версии ПРОФ и КОРП.

35000 31500 руб.

15.12.2021    24823    174    51    

132

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x Россия Бухгалтерский учет Управленческий учет Платные (руб)

Перенос данных из ERP в ЗУП 3 | из КА 2 в ЗУП | Готовые правила конвертации данных (КД 2) для переноса остатков, документов с движениями и справочной информации 3 | Есть перенос начальной задолженности по зарплате и начальной штатной расстановки на выбранную дату | Обороты за прошлые годы (данные для расчета среднего) переносятся свернуто в документ "Перенос данных" | Есть фильтр по организациям | Документы за текущий период переносятся сразу с движениями, поэтому не потребуется делать перерасчеты | Перенос можно проверить перед покупкой, обращайтесь!

53111 47800 руб.

03.12.2020    37239    99    66    

95

Перенос данных 1C Программист Бухгалтер Платформа 1С v8.3 Сложные периодические расчеты 1С:Зарплата и Управление Персоналом 3.x Россия Бухгалтерский учет НДФЛ ФОМС, ЕФС Платные (руб)

Обработки для быстрого перехода с конфигураций «КАМИН:Расчет заработной платы 3.0», «КАМИН:Зарплата для бизнеса 4.0» и «КАМИН:Зарплата 5.0» на конфигурацию «Зарплата и управление персоналом» версии 3.1.

12000 руб.

25.09.2016    81564    324    253    

276

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 1С:Комплексная автоматизация 1.х 1С:Управление производственным предприятием 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

Перенос данных из 1С:Управление производственным предприятием 1.3 в 1С:Бухгалтерия предприятия 3.0 с помощью правил обмена | Можно выполнить переход с УПП на БП 3 или запускать выгрузку данных за выбранный период времени | Переносятся документы, начальные остатки и вся справочная информация | Есть фильтр по организации и множество других параметров выгрузки | Поддерживается несколько сценариев работы: как первичный полный перенос, так и перенос только новых документов | Перенос данных возможен в "1С: Бухгалтерия 3.0" версии ПРОФ, КОРП или базовую | Переход с "1С: УПП1.3" / "1С:КА 1.1" на "1С:БП3.0" с помощью правил конвертации будет максимально комфортным! | Можно бесплатно проверить перенос на вашем сервере!

48278 43450 руб.

25.02.2015    172010    307    258    

384

Зарплата Внешние источники данных Бюджетный учет Перенос данных 1C Системный администратор Программист Платформа 1С v8.3 Сложные периодические расчеты 1С:Зарплата и кадры государственного учреждения 3 Государственные, бюджетные структуры Россия Бухгалтерский учет Бюджетный учет Платные (руб)

Обработка позволяет перенести кадровую информацию и данные по заработной плате, фактическим удержаниям, НДФЛ, вычетам, страховым взносам из базы Парус 8 учреждений (далее Парус) в конфигурацию 1С:Зарплата и кадры государственного учреждения ред. 3 (далее 1С) и начать с ней работать с любого месяца года.

120000 руб.

19.08.2020    25690    25    1    

27
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Serg O. 300 10.07.24 09:28 Сейчас в теме
а зачем в условии Если МассивСообщений.Количество() > 0 Тогда
после цикла чтобы очистить массив сообщений - снова проверять
Если МассивСообщений.Количество() > 0 Тогда

и даже если Количество() = 0 очистке это не помещает никак
и вообще все Если - лишние, цикл по пустому массиву и так не пойдёт.

//КЕ
&НаКлиенте
Процедура ПолучитьСообщенияДляОповещения()
	
	МассивСообщений = Д_ОповещениеПользователей.ПолучитьСообщения("Д_Оповещения", "Д_ОповещениеПользователей", СтруктураПользователяФормы);

	Для Каждого ТекСообщение Из МассивСообщений Цикл 
						
		ПоказатьОповещениеПользователя(
			, ?(ТекСообщение.Свойство("Сообщение"), ТекСообщение.Сообщение, "Сообщение")
			, ?(ТекСообщение.Свойство("НавигационнаяСсылка"), ТекСообщение.НавигационнаяСсылка, "")
			, ?(ТекСообщение.Свойство("Отправитель"), ТекСообщение.Отправитель, ""),
			, СтатусОповещенияПользователя.Важное
			, ТекСообщение.Идентификатор);		
			
	КонецЦикла;
		
	Д_ОповещениеПользователей.ОчиститьВсеСообщенияНаСервере("Д_Оповещения", "Д_ОповещениеПользователей", МассивСообщений);			
	
КонецПроцедуры    
//КЕ
Показать
DMSDeveloper; +1 Ответить
5. John_d 5911 10.07.24 13:08 Сейчас в теме
(1) Согласен проверка перед циклом лишняя, убрал. Проверка перед Д_ОповещениеПользователей.ОчиститьВсеСообщенияНаСервере нужна, чтобы не вызывать лишний раз процедуру.
6. John_d 5911 10.07.24 13:47 Сейчас в теме
(1) Все таки вернул проверку перед циклом. Эта процедура выполняется каждый 15 секунда и пусть даже не пытается запустить цикл и в рамках этой проверки не отработает лишний раз Д_ОповещениеПользователей.ОчиститьВсеСообщенияНаСервере
2. Fox-trot 163 10.07.24 10:17 Сейчас в теме
ну и тогда мои 5 копеек
используем ИначеЕсли и тогда Продолжить уже не пригодится
3. Дмитрий74Чел 238 10.07.24 12:32 Сейчас в теме
Прошу уточнить:
1) для работы механизма надо устанавливать сервер взаимодействия, или какой-то другой компонент?
2) такое же сообщение ведь можно отправить через чат системы взаимодействия, без написания кода?
4. John_d 5911 10.07.24 13:02 Сейчас в теме
(3)
1) ничего не нужно
2) это если в конфигурацию уже внедрена система взаимодействий, по умолчанию нет
7. Дмитрий74Чел 238 10.07.24 16:30 Сейчас в теме
Для инфо читающим. За вывод в колокольчик отвечает СтатусОповещенияПользователя.Важное в ПоказатьОповещениеПользователя().
IIroxod4uk; dfgdsfgsdfg2011; TimurD; +3 Ответить
8. Sapiens_bru 4 11.07.24 17:46 Сейчас в теме
Всё то же можно сделать на обычном регистре сведений. С теми же трудозатратами и почти тем же кодом.

Не стоит использовать механизмы платформы в сценариях для них не предназначенных, тем более новые механизмы. Выйдет новая платформа и решение перестанет работать.
9. dsdred 3755 11.07.24 18:00 Сейчас в теме
(8) 1 не все тоже можно сделать на регистре сведений.
2 Между тем если изменят в платформе, то разом сломаются все интеграции через 1с шину.
Уверены, что 1с решится на такой подвиг?


П.С. Обойтись Регистром, справочником, документом можно, но есть ряд нюансов.
Может выйти вариант когда под каждый вид оповещений начнут плодится все новые и новые сущности.

В сервисах интеграции, в сообщении есть свойство "Параметр", в который можно добавлять сколько угодно ключей для выборки. Например добавить ключ "ТипОповещение" и т.д.
Соответственно мы получаем очень гибкий механизм. Добавив один канал на него можем вешать разные оповещалки без доработок.
10. Sapiens_bru 4 11.07.24 22:33 Сейчас в теме
(9) Что нельзя сделать на регистре того что можно только на сервисе интеграции? Канал сервиса интеграции это две простые таблички в базе данных. Там даже индекса по идентификатору нет. По сути это два регистра сведений, в одном лежит очередь сообщений, в другом тело сообщений.
Свойство "Параметр" хранится в виде текста, то есть проходит процедуру сериализации/десериализации каждый раз при обращении к базе. Например выбрать данные по значению параметра не получится, только выбрать всё и прочитать все параметры. Реализовать ту же логику на регистре сведений не проблема, но смысла нет. Гораздо проще в регистр сведений добавить ещё одно поле и получить возможность отбора/поиска по нему.
Регистр сведений гораздо более гибкий механизм, потому что составом колонок мы управляем напрямую, а не используем фиксированную структуру, к тому-же доступную только через методы сервисов интеграции.

Завтра вас попросят прикрутить к сообщению поле ДатаПрочтения, или сделать возможность сохранить уже доставленные уведомления Х дней для отчетности. И всё. И Конец. В сервис интеграции такое не впихнёшь.

А если в базе начинают плодится регистры сведений это не к добру, нужно искать причину такого размножения и устранять.
11. dsdred 3755 11.07.24 22:47 Сейчас в теме
(10)
Канал сервиса интеграции это две простые таблички в базе данных. Там даже индекса по идентификатору нет. По сути это два регистра сведений, в одном лежит очередь сообщений, в другом тело сообщений.


Одна таблица IntegChannelOutQueueXX
Тело лежит в поле MessageBody
Параметры лежат в поле MessageHeader

Статейка по этой информации -> https://infostart.ru/1c/articles/2042916/

Гораздо проще в регистр сведений добавить ещё одно поле и получить возможность отбора/поиска по нему.

И выгнать всех из 1С. А если окна обновления в данный момент нет, а добавить надо?

Завтра вас попросят прикрутить к сообщению поле ДатаПрочтения, или сделать возможность сохранить уже доставленные уведомления Х дней для отчетности. И всё. И Конец. В сервис интеграции такое не впихнёшь.

Я не спорю для каких то задач, например для обменов по старинке регистр сведений подходит лучше.
Но для каких то задач сервисы интеграции интереснее.

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

Согласен, но в жизни так бывает.
cleaner_it; d4rkmesa; +2 Ответить
12. rozer 312 12.07.24 16:01 Сейчас в теме
В чем отличия от оригинальной статьи ?
Новаторство только в "ТекущиеДела" и отправка списку ?
13. John_d 5911 12.07.24 17:19 Сейчас в теме
(12) -отправка списку,
-причесал код,
-вывел программный интерфейс отправка уведомления одной строкой Д_ОповещениеПользователей.ОтправитьСообщениеКолокольчикПользователям(МассивПолучатели,Сообщение,Док);
14. aximo 2112 15.08.24 07:42 Сейчас в теме
Новинка появилась в 3.1.10 на сколько я понял
15. Bezdar 4 03.09.24 15:29 Сейчас в теме
(11)
Но для каких то задач сервисы интеграции интереснее.

очень интересно узнать, для каких задач сервис лучше регистра и что нельзя сделать в регистре, а можно в сервисе?
16. dsdred 3755 03.09.24 15:48 Сейчас в теме
(15) Все задачи которые сделаны по принципу "конверта" то есть содержащие тело сообщения и шапку гораздо интереснее делать через сервисы интеграции. Так как в шапку сообщения можно добивать свойства программно.
Сделать такое можно через регистр, но тут надо либо хранилище значений для шапки либо изгаляется используя другие объекты.
Оставьте свое сообщение