WebSocket используется для передачи сообщений. Сообщения, которые получены по WebSocket, Creatio транслирует подписчикам с использованием схемы ClientMessageBridge клиентского модуля. Внутри Creatio сообщения передаются через объект sandbox. Сообщение является широковещательным и ему присваивается имя SocketMessageReceived. Вы можете подписаться на сообщение и обработать полученные данные.
Реализовать пользовательскую логику передачи сообщения
Чтобы реализовать пользовательскую логику передачи сообщения, которое получено по WebSocket:
- Создайте замещающую схему схемы клиентского модуля ClientMessageBridge. Подробнее читайте в статье Клиентский модуль.
- Добавьте сообщение в дополнительное свойство messages схемы. Подробнее читайте в статье Свойство messages.
- Добавьте сообщение, которое получено по WebSocket, в конфигурационный объект сообщений схемы. Для этого реализуйте перегрузку родительского метода init().
- Отследите рассылку сообщения. Для этого реализуйте перегрузку базового метода afterPublishMessage().
Сохранить сообщения в историю
Работа с историей сообщений зависит от обработчика Listener, который присутствует при публикации сообщения в Creatio.
Действия, которые выполняет Creatio, если обработчик Listener не загружен:
- Сохраняет необработанные сообщения в историю.
- Проверяет наличие обработчика Listener перед публикацией сообщения.
- Публикует все сохраненные сообщения в порядке их получения после загрузки обработчика.
- Очищает историю после публикации сообщений из истории.
Абстрактные методы класса BaseMessageBridge, которые реализуют сохранение сообщений в историю и работу с ними через localStorage хранилище браузера:
- saveMessageToHistory() — сохраняет новое сообщение в коллекцию сообщений.
- getMessagesFromHistory() — получает массив сообщений по указанному имени.
- deleteSavedMessages() — удаляет сохраненные сообщения по указанному имени.
В схеме ClientMessageBridge реализованы абстрактные методы родительского класса BaseMessageBridge.
Чтобы реализовать сохранение сообщений в историю, укажите значение true для свойства isSaveHistory при добавлении конфигурационного объекта.
Чтобы реализовать работу с сообщениями через другое хранилище:
- Cоздайте класс-наследник класса BaseMessageBridge.
- В классе-наследнике реализуйте пользовательскую логику методов saveMessageToHistory(), getMessagesFromHistory() и deleteSavedMessages().
1. Создать схему замещающего объекта
- Перейдите в раздел Конфигурация (Configuration) и выберите пользовательский пакет, в который будет добавлена схема.
-
На панели инструментов реестра раздела нажмите Добавить —> Замещающий объект (Add —> Replacing object).
-
Заполните свойства схемы.
- Код (Code) — "Contact".
- Заголовок (Title) — "Контакт" ("Contact").
- Родительский объект (Parent object) — выберите "Contact".
-
В схему добавьте событие.
- Перейдите в узел События (Events) структуры объекта.
-
В блоке Сохранение (Saving) установите признак После сохранения записи (After record saved). Событию присвоено имя ContactSaved.
- На панели инструментов дизайнера объектов нажмите Сохранить (Save).
-
Реализуйте событийный подпроцесс.
- На панели инструментов дизайнера объектов нажмите Открыть процесс (Open process).
-
В области элементов дизайнера нажмите Действия системы (System actions) и разместите элемент Событийный подпроцесс (Event sub-process) в рабочей области дизайнера процессов.
- На панели настройки элементов заполните свойство Заголовок (Title) — "Contact Saved Sub-process".
-
Настройте элементы событийного подпроцесса.
-
Настройте начальное событие Сообщение (Message).
- Заголовок (Title) — "After contact saved".
- При получении какого сообщения запускать процесс? (Which message event should start the process?) — "ContactSaved".
-
Добавьте действие системы Задание-сценарий (Script task).
-
В области элементов дизайнера нажмите Действия системы (System actions) и разместите действие системы Задание-сценарий (Script task) в рабочей области подпроцесса.
- Действию системы Задание-сценарий (Script task) добавьте имя "Опубликовать сообщение по WebSocket" ("Publish a message via WebSocket").
-
Добавьте код действия системы Задание-сценарий (Script task).
- На панели инструментов дизайнера процессов нажмите Сохранить (Save).
-
-
-
Настройте поток управления. Для этого в меню начального события Сообщение (Message) нажмите на кнопку и соедините начальное событие Сообщение (Message) с действием системы Опубликовать сообщение по WebSocket (Publish a message via WebSocket).
Событийный подпроцесс представлен на рисунке ниже.
- На панели инструментов дизайнера процессов нажмите Сохранить (Save), а затем Опубликовать (Publish).
2. Реализовать рассылку сообщения в Creatio
- Перейдите в раздел Конфигурация (Configuration) и выберите пользовательский пакет, в который будет добавлена схема.
-
На панели инструментов реестра раздела нажмите Добавить —> Замещающая модель представления (Add —> Replacing view model).
-
Заполните свойства схемы.
- Код (Code) — "ClientMessageBridge".
- Заголовок (Title) — "ClientMessageBridge".
- Родительский объект (Parent object) — выберите "ClientMessageBridge".
-
Реализуйте рассылку широковещательного сообщения NewMessage.
- В свойстве messages привяжите широковещательное сообщение NewMessage, которое может публиковаться в приложении.
-
В свойстве methods перегрузите родительские методы:
- init() — добавляет сообщение, которое получено по WebSocket, в конфигурационый объект сообщений схемы.
- afterPublishMessage — отслеживает рассылку сообщения.
Исходный код схемы замещающей модели представления представлен ниже.
- На панели инструментов дизайнера нажмите Сохранить (Save).
3. Реализовать подписку на сообщение
- Перейдите в раздел Конфигурация (Configuration) и выберите пользовательский пакет, в который будет добавлена схема.
- На панели инструментов реестра раздела нажмите Добавить —> Замещающая модель представления (Add —> Replacing view model).
-
Заполните свойства схемы.
- Код (Code) — "ContactPageV2".
- Заголовок (Title) — "Display schema - Contact card".
- Родительский объект (Parent object) — выберите "ContactPageV2".
-
Реализуйте подписку на широковещательное сообщение NewMessage.
- В свойстве messages привяжите широковещательное сообщение NewMessage, на которое можно подписаться.
- В свойстве methods перегрузите родительский метод init(). Метод подписывается на сообщение NewMessage. Укажите метод-обработчика onNewMessage(), который обрабатывает полученный в сообщении объект и выводит результат в консоль браузера.
Исходный код схемы замещающей модели представления представлен ниже.
- На панели инструментов дизайнера нажмите Сохранить (Save).
Результат выполнения примера
Чтобы посмотреть результат выполнения примера:
- Очистите кэш браузера.
- Обновите страницу раздела Контакты (Contacts).
- Откройте страницу контакта. Например, Alexander Wilson.
- Откройте вкладку Console в консоли браузера.
- Измените любое поле.
- Сохраните контакт.
В результате полученное и отправленное сообщения NewMessage отображаются в консоли браузера.
Сообщения, которые получены по WebSocket, Creatio транслирует подписчикам с использованием схемы ClientMessageBridge клиентского модуля.
Свойства
Название хранилища, в котором сохраняется история сообщений.
Экземпляр класса, который реализует доступ к локальному хранилищу.
Методы
Инициализирует значение по умолчанию.
Сохраняет сообщение в хранилище, если подписчик отсутствует, а в конфигурационном объекте указан признак необходимости сохранения.
sandboxMessageName: String | Имя сообщения, которое используется при рассылке сообщения в Creatio. |
webSocketBody: Object | Сообщение, которое получено по WebSocket. |
Возвращает массив сохраненных сообщений из хранилища.
sandboxMessageName: String | Имя сообщения, которое используется при рассылке сообщения в Creatio. |
Удаляет из хранилища сохраненное сообщение.
sandboxMessageName: String | Имя сообщения, которое используется при рассылке сообщения в Creatio. |