RU2783782C1 - System and method for managing notifications - Google Patents
System and method for managing notifications Download PDFInfo
- Publication number
- RU2783782C1 RU2783782C1 RU2021138675A RU2021138675A RU2783782C1 RU 2783782 C1 RU2783782 C1 RU 2783782C1 RU 2021138675 A RU2021138675 A RU 2021138675A RU 2021138675 A RU2021138675 A RU 2021138675A RU 2783782 C1 RU2783782 C1 RU 2783782C1
- Authority
- RU
- Russia
- Prior art keywords
- objects
- notification
- expression
- list
- alert
- Prior art date
Links
- 230000014509 gene expression Effects 0.000 claims abstract description 208
- 238000004364 calculation method Methods 0.000 claims abstract description 21
- 230000002688 persistence Effects 0.000 claims description 24
- 239000003999 initiator Substances 0.000 claims description 21
- 230000000875 corresponding Effects 0.000 claims description 2
- 238000005516 engineering process Methods 0.000 abstract description 2
- 239000000126 substance Substances 0.000 abstract 1
- 238000011156 evaluation Methods 0.000 description 21
- 230000003993 interaction Effects 0.000 description 13
- 238000007726 management method Methods 0.000 description 9
- 238000000034 method Methods 0.000 description 9
- 210000004544 DC2 Anatomy 0.000 description 5
- 238000010586 diagram Methods 0.000 description 5
- 230000002530 ischemic preconditioning Effects 0.000 description 5
- 230000004044 response Effects 0.000 description 3
- 230000001960 triggered Effects 0.000 description 3
- 230000015572 biosynthetic process Effects 0.000 description 2
- 238000005755 formation reaction Methods 0.000 description 2
- 230000000007 visual effect Effects 0.000 description 2
- 230000004075 alteration Effects 0.000 description 1
- 238000006243 chemical reaction Methods 0.000 description 1
- 239000000463 material Substances 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000006011 modification reaction Methods 0.000 description 1
- 229920001690 polydopamine Polymers 0.000 description 1
- 230000001340 slower Effects 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
Images
Abstract
Description
Область техникиTechnical field
[1] Настоящее изобретение относится к системам и способам управления оповещениями, обеспечивающим эффективную и быструю идентификацию событий и изменений данных в базах данных, цифровых файлах, документах и др. Настоящее изобретение может использоваться в корпоративных информационных системах для организации взаимодействия с иными системами.[1] The present invention relates to systems and methods for managing alerts that provide efficient and fast identification of events and data changes in databases, digital files, documents, etc. The present invention can be used in corporate information systems to organize interaction with other systems.
Уровень техникиState of the art
[2] Корпоративные информационные системы обычно работают во взаимодействии с иными системами. Для обеспечения согласованности между ними необходима координация, что, в свою очередь, требует, чтобы каждая из систем реагировала на внешние события. В связи с этим, практически в любой корпоративной информационной системе используются компоненты, управляемые событиями.[2] Corporate information systems usually work in conjunction with other systems. To ensure consistency between them, coordination is necessary, which, in turn, requires that each of the systems respond to external events. In this regard, almost any corporate information system uses event-driven components.
[3] События можно разделить на 2 класса: явно инициируемые именованные события, в т.ч. параметризованные, и события, связанные с изменением данных. В рамках настоящего изобретения рассматривается вариант событий, порождаемых изменениями данных.[3] Events can be divided into 2 classes: explicitly triggered named events, incl. parameterized, and events related to data change. Within the framework of the present invention, a variant of events generated by data changes is considered.
[4] Изменения данных могут быть как атомарными, когда обрабатывается событие изменения одной записи конкретного типа, так и комплексными, когда событие инициируется только в случае комплексного изменения определенного набора взаимосвязанных данных. В большинстве информационных систем присутствует функциональность обработки событий создания, изменения и удаления единичной записи, например, триггеры в системах управления базами данных. Однако, многие бизнес-события сложно описываются подобными изменениями. Например, изменение данных другими пользователями и системами влечет необходимость обновления части интерфейса пользователя, однако интерфейс обычно выстроен иерархически и наблюдать нужно не за фиксированным объектом, а за тем объектом, который является «текущим», т. е. является результатом цепочки ссылок от корневого объекта. [4] Data changes can be both atomic, when the change event of one record of a specific type is processed, and complex, when the event is triggered only in the case of a complex change of a certain set of interrelated data. In most information systems, there is the functionality of processing events for creating, changing and deleting a single record, for example, triggers in database management systems. However, many business events are difficult to describe by such changes. For example, changing data by other users and systems entails the need to update part of the user interface, however, the interface is usually built hierarchically and you need to monitor not a fixed object, but the object that is “current”, i.e., is the result of a chain of links from the root object .
[5] Для мониторинга только части событий, связанных с изменением фиксированных объектов, подобный подход, т.е. отслеживание цепочки ссылок от корневого объекта, приводит к сложному многоуровневому коду, который к тому же требуется аккуратно изменять при внесении изменений в интерфейс пользователя.[5] To monitor only a part of the events associated with the change of fixed objects, a similar approach, i.e. tracing the chain of references from the root object results in complex multi-level code, which also needs to be carefully modified when changes are made to the user interface.
[6] Известно решение, описываемое в патенте US9292587B2 (опубл. 22.03.2016; МПК: G06F 17/30). В нем представлены системы и способы для предоставления удаленному приложению уведомлений об изменениях, внесенных в таблицу базы данных. Система и способы управляют уведомлением об изменении таблицы в базе данных, уведомляя приложение, сконфигурированное для получения уведомлений об изменениях, внесенных в таблицу базы данных. Менеджер базы данных, выполняющийся на устройстве, может принимать запрос на регистрацию приложения, которое будет уведомлено при изменении первой таблицы из множества таблиц в базе данных. Менеджер базы данных может установить таблицу уведомлений, содержащую поля первой таблицы и одно или несколько дополнительных полей для управления уведомлением. Менеджер базы данных может установить триггер для первой таблицы, чтобы вызвать процедуру триггера для копирования измененной строки первой таблицы в таблицу уведомлений. Менеджер базы данных может создать правило для таблицы уведомлений, чтобы уведомлять зарегистрированные приложения, когда в таблицу уведомлений вставляется новая строка. Первым недостатком аналога при этом является то, что в нем производится мониторинг всей совокупности изменений в базе данных, что замедляет работу системы. Второй недостаток заключает в том, что в аналоге оповещение происходит по поводу каждого изменения в таблице базы данных. [6] The solution described in the patent US9292587B2 (publ. 22.03.2016; IPC: G06F 17/30) is known. It provides systems and methods for providing notifications to a remote application about changes made to a database table. The system and methods manage notification of changes to a table in a database by notifying an application configured to receive notifications of changes made to a database table. The database manager running on the device may receive a registration request for an application that will be notified when the first table of the plurality of tables in the database is changed. The database manager may set up a notification table containing the fields of the first table and one or more additional fields to manage the notification. The database manager can set a trigger on the first table to call the trigger procedure to copy the modified row of the first table to the notification table. The database manager can create a notification table rule to notify registered applications when a new row is inserted in the notification table. The first disadvantage of the analog is that it monitors the entire set of changes in the database, which slows down the system. The second drawback is that in the analog, an alert occurs for every change in the database table.
[7] В изобретении по патенту US7836031B2 (опубл. 16.11.2010; МПК: G06F 7/00; G06F 17/00) описываются системы и способы использования механизма на основе триггера для обнаружения изменений в таблице базы данных, предоставления уведомления при изменении таблицы базы данных и регистрации для получения уведомления. Системы и способы используют таблицу «слушателей» для хранения информации, связанной с зарегистрированными таблицами базы данных. После изменения таблицы базы данных механизм триггера, связанный с изменением базы данных, облегчает поиск в таблице «слушателей» параметра, связанного с измененной таблицей базы данных. Если измененная таблица базы данных зарегистрирована, информация из таблицы «слушателей» предоставляется службе доставки, которая передает сообщение, указывающее на изменение зарегистрированной таблицы базы данных. После получения сообщения служба времени выполнения уведомлений может направить уведомление клиенту(-ам), зарегистрированному(-ым) для получения уведомления. Одно из отличий аналога от настоящего изобретения заключается в том, что в аналоге предусмотрен этап регистрации таблицы для последующего получения уведомлений о ее изменении. В настоящем изобретении этот этап не требуется, т.к. предполагается, что изменения таблиц/файлов/документов изначально мониторят. Другим отличием является то, что в аналоге для внесения изменений в таблицу требуется запросить разрешение на внесение изменений в таблицу. В настоящем изобретении изначально определен список лиц, имеющих доступ к внесению изменений в таблицу/файл/документ, а также управляющий пользователь, которому будут приходить уведомления о внесении изменений. Первым недостатком аналога при этом является то, что в нем производится мониторинг всей совокупности изменений в базе данных, что требует дополнительных вычислительных мощностей сервера, а также создает излишние оповещения управляющего пользователя. Второй недостаток заключает в том, что в аналоге оповещение происходит по поводу каждого изменения в таблице базы данных, что также создает излишние оповещения[7] US7836031B2 (published Nov. 16, 2010; IPC: G06F 7/00; G06F 17/00) describes systems and methods for using a trigger-based mechanism to detect changes in a database table, provide notification when a database table changes data and registration for notification. Systems and methods use a listener table to store information associated with registered database tables. After a database table change, the database change trigger mechanism makes it easy to find the listener table for the parameter associated with the changed database table. If the modified database table is registered, information from the listener table is provided to the delivery service, which sends a message indicating that the registered database table has changed. Upon receipt of the message, the notification runtime service may send a notification to the client(s) registered to receive the notification. One of the differences of the analog from the present invention is that the analog provides for the stage of registering a table for subsequent receipt of notifications about its change. In the present invention, this step is not required, because it is supposed that changes of tables/files/documents are initially monitored. Another difference is that in the counterpart, to make changes to a table, you need to request permission to make changes to the table. The present invention initially defines a list of persons who have access to make changes to the table/file/document, as well as a control user who will receive change notifications. The first disadvantage of the analogue is that it monitors the entire set of changes in the database, which requires additional computing power of the server, and also creates unnecessary notifications for the control user. The second drawback is that in the analog, an alert occurs for every change in the database table, which also creates unnecessary alerts.
[8] Также известно изобретение по патенту US6617969B2 (опубл. 09.09.2003; МПК: G08B 23/00), в котором описываются способы и устройство для отправки сообщения уведомления в соответствии с набором предпочтений уведомления. Уведомляющее сообщение отправляется при обнаружении события или удовлетворении условия в отношении обнаруженного события. Набор предпочтений уведомлений может указывать желаемый носитель уведомления, через который должно быть отправлено сообщение уведомления, адресата уведомления, которому должно быть отправлено сообщение уведомления, и/или предпочтение времени уведомления, указывающее дату и/или время, в течение которых уведомление должно быть отправлено (или получено). Первым недостатком аналога при этом является то, что в нем производится мониторинг всей совокупности изменений в базе данных, что требует дополнительных вычислительных мощностей сервера, а также формирует оповещения управляющего пользователя обо всех изменениях. Второй недостаток заключает в том, что в аналоге оповещение происходит по поводу каждого изменения в таблице базы данных, что также создает излишние оповещения в системе. [8] Also known is the invention according to the patent US6617969B2 (publ. 09/09/2003; IPC: G08B 23/00), which describes methods and apparatus for sending a notification message in accordance with a set of notification preferences. A notification message is sent when an event is detected or a condition is met for the detected event. The set of notification preferences may indicate the desired notification medium through which the notification message is to be sent, the notification destination to which the notification message is to be sent, and/or the notification time preference indicating the date and/or time during which the notification is to be sent (or received). The first disadvantage of the analogue is that it monitors the entire set of changes in the database, which requires additional computing power of the server, and also generates notifications for the managing user about all changes. The second drawback is that in the analog, an alert occurs for every change in the database table, which also creates unnecessary alerts in the system.
[9] В изобретении по патенту US9591059B2 (опубл. 07.03.2017; МПК: H04L 29/08; G06F 17/30) описывается устройство для уведомления об изменении файла, включающее в себя модуль создания уведомления, который создает на первом локальном узле сообщение с уведомлением об изменении файла в ответ на создание, удаление и/или изменение клиентом элемента файловой системы, адресованного через путь к файлу. Первый локальный узел уведомляет связанные локальные клиентские процессы, представляющие клиентов, подключенных к первому локальному узлу и помеченных для получения информации об изменении файла. Устройство включает в себя модуль идентификации узла, который проверяет глобальный узел на наличие вторых локальных узлов, помеченных для получения информации об изменении файла для пути к файлу, и модуль распространения уведомлений, который в ответ отправляет сообщение уведомления об изменении файла от первого локального узла вторым локальным узлам. до получения идентификации вторых локальных узлов. Второй локальный узел уведомляет связанные локальные клиентские процессы, представляющие клиентов, подключенных ко второму локальному узлу и помеченных для получения информации об изменении пути к файлу. Первым недостатком аналога при этом является то, что в нем производится мониторинг всей совокупности изменений в базе данных, тогда так в настоящем изобретении производится мониторинг определенных записей в файлах, причем список проверяемых записей формируется автоматически на основе выражения. Это позволяет значительно уменьшить вычислительные мощности сервера, а также не оповещать управляющего пользователя обо всех изменениях. Второй недостаток заключает в том, что в аналоге для получения оповещения необходимо отправить запрос на получение оповещения. В настоящем изобретении сервер принимает решение о том, какие оповещения и в каком виде присылать управляющему пользователю. Это позволяет оповещать управляющего пользователя только о существенных изменениях, а не обо всех. Главным отличием настоящего изобретения от аналога является то, что аналог предназначен только для мониторинга изменений в файлах системы NAS, а также для отправления уведомлений об этих изменениях. (NAS (англ. Network Attached Storage) — сервер хранения данных на файловом уровне). В настоящем изобретении могут мониторить изменения в любых видах файлов/документов/таблиц, в том числе таблиц баз данных. [9] The invention according to the patent US9591059B2 (publ. 03/07/2017; IPC: H04L 29/08; G06F 17/30) describes a device for notifying a file change, including a notification creation module that creates a message on the first local node with a file change notification in response to a client creating, deleting, and/or modifying a file system element addressed via a file path. The first local node notifies the associated local client processes representing the clients connected to the first local node and flagged for file change information. The device includes a node identification module that checks the global node for second local nodes marked for file change information for a file path, and a notification distribution module that in response sends a file change notification message from the first local node to the second local nodes. nodes. before obtaining the identification of the second local nodes. The second local node notifies the associated local client processes representing the clients connected to the second local node and flagged for information about the file path change. The first disadvantage of the analogue is that it monitors the entire set of changes in the database, while in this way the present invention monitors certain records in files, and the list of checked records is generated automatically based on the expression. This allows you to significantly reduce the computing power of the server, and also not notify the managing user of all changes. The second drawback is that in the analog, to receive an alert, you must send a request to receive an alert. In the present invention, the server decides which notifications and in what form to send to the managing user. This allows the managing user to be notified only of significant changes, rather than all of them. The main difference of the present invention from the analog is that the analog is intended only for monitoring changes in the files of the NAS system, as well as for sending notifications about these changes. (NAS (English Network Attached Storage) - data storage server at the file level). The present invention can monitor changes in any kind of files/documents/tables, including database tables.
[10] В заявке на изобретение US20140195476A1 (опубл. 10.07.2014; МПК: G06F 17/30) описывается реализуемый на компьютере способ генерации уведомления об обновлении базы данных в памяти, включающий: обнаружение события базы данных в памяти, которое вставляет, удаляет или изменяет первую запись в базе данных в памяти; выполнение первого триггера базы данных, который соответствует обнаруженному событию базы данных в памяти; идентификацию первого определения бизнес-события, которое отображается на выполненный первый триггер базы данных; и создание первого уведомления, которое соответствует идентифицированному первому определению бизнес-события, первое уведомление, сгенерированное для первого подписчика на идентифицированное первое определение бизнес-события. Первым недостатком аналога при этом является то, что в нем производится мониторинг всей совокупности изменений в базе данных, тогда так в настоящем изобретении производится мониторинг определенных записей в файлах, причем список проверяемых записей формируется автоматически на основе выражения. Это позволяет значительно уменьшить вычислительные мощности сервера, а также не оповещать управляющего пользователя обо всех изменениях. Второй недостаток заключает в том, что в аналоге оповещение происходит по поводу каждого изменения в таблице базы данных. В настоящем изобретении сервер принимает решение о том, какие оповещения и в каком виде присылать управляющему пользователю. Это позволяет оповещать управляющего пользователя только о существенных изменениях, а не обо всех.[10] US20140195476A1 (published 07/10/2014; IPC: G06F 17/30) describes a computer-implemented method for generating an in-memory database update notification, including: detecting an in-memory database event that inserts, deletes, or changes the first entry in the in-memory database; executing a first database trigger that corresponds to the detected database event in memory; identifying a first business event definition that maps to the executed first database trigger; and creating a first notification that matches the identified first business event definition, a first notification generated for a first subscriber to the identified first business event definition. The first disadvantage of the analogue is that it monitors the entire set of changes in the database, while in this way the present invention monitors certain records in files, and the list of checked records is generated automatically based on the expression. This allows you to significantly reduce the computing power of the server, and also not notify the managing user of all changes. The second drawback is that in the analog, an alert occurs for every change in the database table. In the present invention, the server decides which notifications and in what form to send to the managing user. This allows the managing user to be notified only of significant changes, rather than all of them.
Сущность изобретенияThe essence of the invention
[11] Задачей заявляемого изобретения является создание и разработка системы и способа управления оповещениями, обеспечивающих эффективную и быструю идентификацию событий и изменений данных, а также создание быстрых оповещений на их основе. [11] The objective of the claimed invention is to create and develop a system and method for managing alerts that provide efficient and fast identification of events and data changes, as well as the creation of quick alerts based on them.
[12] Технический результат, на достижение которого направлено заявляемое изобретение, заключается в обеспечении эффективности управления оповещениями, а также скорости отправки оповещений системе. Технический результат достигается в том числе, но не ограничиваясь, благодаря:[12] The technical result, to which the claimed invention is directed, is to ensure the efficiency of notification management, as well as the speed of sending notifications to the system. The technical result is achieved including, but not limited to, due to:
• описанию события мониторинга в виде выражения на языке выражений;• description of the monitoring event as an expression in the expression language;
• мониторингу определенных объектов в базе данных, а не всех объектов;• monitoring certain objects in the database, not all objects;
• осуществлению мониторинга только по мере появления изменений в объектах;• monitoring only as changes appear in objects;
• принятие управляющим сервером решения о том, какие оповещения и в каком виде присылать управляющему пользователю.• making a decision by the control server about what notifications and in what form to send to the control user.
[13] Более полно технический результат достигается благодаря системе управления оповещениями, включающей по крайней мере одно пользовательское устройство с интерфейсом, по крайней мере одну базу данных и сервер, подключенные друг к другу. При этом сервер включает по крайней мере один источник объектов, компонент оповещения, компонент расчета выражений и компонент сохранения. Компонент оповещения сконфигурирован с возможностью создания оповещений и включает сервис оповещений, анализатор объектов выражения оповещения, исполнитель оповещений. При этом сервис оповещений, анализатор объектов выражения оповещения и исполнитель оповещений взаимодействую друг с другом последовательно. Компонент расчета выражений сконфигурирован с возможностью мониторинга изменений объектов и включает по крайней мере один инициатор выражения, исполнитель выражения и список объектов для мониторинга. При этом список объектов для мониторинга взаимодействует с исполнителем оповещения, а по крайней мере один инициатор выражения взаимодействует с по крайней мере одним источником объектов и с исполнителем выражения. Компонент сохранения сконфигурирован с возможностью сохранения изменений в базе данных и включает модуль кэширования объектов и модуль сохранения объектов. При этом модуль кэширования объектов взаимодействует с исполнителем выражения и с модулем сохранения объектов, а модуль сохранения объектов взаимодействует с по крайней мере одной базой данных.[13] A more complete technical result is achieved thanks to an alert management system that includes at least one user device with an interface, at least one database and a server connected to each other. In this case, the server includes at least one object source, a notification component, an expression evaluation component, and a storage component. The alert component is configured to generate alerts and includes an alert service, an alert expression object parser, and an alert executor. At the same time, the alert service, the alert expression object parser, and the alert executor interact with each other sequentially. The expression evaluation component is configured to monitor object changes and includes at least one expression initiator, expression executor, and a list of objects to monitor. In this case, the list of objects to be monitored interacts with the notification executor, and at least one expression initiator interacts with at least one source of objects and with the expression executor. The persistence component is configured to persist changes to a database and includes an object caching module and an object persistence module. In this case, the object caching module interacts with the expression executor and with the object persistence module, and the object persistence module interacts with at least one database.
[14] При этом по крайней мере одно пользовательское устройство необходимо для внесения изменений в объекты базы данных и/или для получения оповещений об изменениях. Интерфейс необходим пользовательскому устройству для информирования пользователя пользовательского устройства о происходящем. По крайней мере одна база данных необходима для организации доступа севера и пользовательского устройства к объектам базы данных, а сервер необходим для оповещения пользователя пользовательского устройства об изменениях в базе данных и сохранения изменений в базе данных. При этом по крайней мере один источник объектов необходим для организации доступа сервера к базе данных. Компонент оповещения необходим для создания оповещений. При этом сервис оповещений необходим для непосредственного создания оповещений на основе внесенных изменений и определения типа оповещения, анализатор объектов выражения оповещения необходим для необходим для расчета оповещения и формирования списка используемых объектов. Исполнитель оповещения необходим для выполнения пользовательского программного кода, который должен выполниться при срабатывании оповещения. При этом сервис оповещений, анализатор объектов выражения оповещения и исполнитель оповещения должны последовательно взаимодействовать друг с другом для создания оповещения. Компонент расчета выражений необходим для мониторинга изменений объектов. То, что компонент расчета выражений включает по крайней мере один инициатор выражения, необходим для генерации выражения, который определяет изменение объекта. Исполнитель выражения необходим для вычисления результата выражения, а список объектов для мониторинга необходим для определения того, изменение каких объектов необходимо мониторить для создания оповещения. То, что список объектов для мониторинга взаимодействует с исполнителем оповещения, а по крайней мере один инициатор выражения взаимодействует с по крайней мере одним источником объектов и с исполнителем выражения, необходимо для непосредственного мониторинга изменений объектов. Компонент сохранения необходим для сохранения изменений в базе данных. Модуль кэширования, при этом, необходим для организации быстрого доступа к объектам, а модуль сохранения объектов необходим для записи в базу данных, выполнения необходимых проверок и передачи событий в разные сервисы, в том числе в оповещения. То, что при этом модуль кэширования объектов взаимодействует с исполнителем выражения и с модулем сохранения объектов, а модуль сохранения объектов взаимодействует с по крайней мере одной базой данных, необходимо для непосредственной организации возможности сохранения изменений объектов в базе данных. [14] At the same time, at least one user device is needed to make changes to database objects and/or to receive notifications about changes. The interface is needed by the user device to inform the user of the user device about what is happening. At least one database is needed to organize access of the server and the user device to the database objects, and the server is needed to notify the user of the user device about changes in the database and save the changes to the database. At the same time, at least one source of objects is required to organize server access to the database. The alert component is required to create alerts. At the same time, the alert service is needed to directly create alerts based on the changes made and determine the type of alert, the alert expression object analyzer is needed to calculate the alert and generate a list of used objects. An alert executor is required to execute custom code that must be executed when an alert is fired. However, the alert service, the alert expression object parser, and the alert executor must interact sequentially with each other to create an alert. The expression evaluation component is required to monitor object changes. The fact that the expression evaluation component includes at least one expression initiator is necessary for the generation of an expression that specifies an object change. The executor of the expression is needed to evaluate the result of the expression, and the list of objects to monitor is needed to determine which objects need to be monitored for changes in order to generate an alert. The fact that the list of objects to monitor interacts with the notification executor, and at least one expression initiator interacts with at least one object source and the expression executor, is necessary to directly monitor object changes. The save component is required to save changes to the database. The caching module, at the same time, is necessary for organizing quick access to objects, and the object saving module is necessary for writing to the database, performing the necessary checks and transmitting events to various services, including notifications. The fact that the object caching module interacts with the expression executor and the object persistence module, and the object persistence module interacts with at least one database, is necessary for the direct organization of the ability to save changes to objects in the database.
[15] По крайней мере одна база данных при этом может быть размещена на сервере и/или являться внешней базой данных в зависимости от конкретного применения настоящей системы.[15] At least one database may be hosted on the server and/or be an external database, depending on the specific application of the present system.
[16] В качестве по крайней мере одного инициатора выражения могут использовать прикладной код.[16] Application code may be used as at least one initiator of the expression.
[17] Также в системе управления оповещения могут быть организованы дополнительные варианты взаимодействия ее компонент и элементов, которые будут обеспечивать выполнения дополнительного технического результата. Например, для проверки того, сработало ли оповещение, или для обновления списка объектов для мониторинга.[17] Also, in the notification control system, additional options for the interaction of its components and elements can be organized, which will ensure the implementation of an additional technical result. For example, to check if an alert has worked, or to update the list of objects to monitor.
[18] Также технический результат достигается способом управления оповещениями, по которому сначала изменяют объект из базы данных, а затем создают событие оповещения в виде выражения. При этом, на этапе изменения объекта из базы данных: изменяют объект при помощи пользовательского устройства; генерируют выражение, определяющее изменение объекта; вычисляют результат выражения; хранят объекты, используемые выражением; и сохраняют изменения объекта в источнике объектов при помощи модуля сохранения объектов. На этапе создания оповещения: определяют тип оповещения при помощи сервиса оповещений; рассчитывают выражение оповещения для определенного типа оповещений; формируют список изменившихся объектов, используемых при расчете выражения оповещения; исполняют оповещение; обновляют список объектов в списке объектов для мониторинга на основании рассчитанного выражения оповещения; и сохраняют изменения объекта в базе данных. [18] Also, the technical result is achieved by a notification management method, according to which the object from the database is first changed, and then the notification event is created in the form of an expression. At the same time, at the stage of changing the object from the database: changing the object using the user device; generate an expression that defines the change of the object; calculate the result of the expression; store the objects used by the expression; and saving changes to the object in the object source using the object persistence module. At the stage of creating an alert: determine the type of alert using the alert service; calculate the alert expression for the specific alert type; forming a list of changed objects used in the calculation of the notification expression; execute notification; updating the list of objects in the list of objects to be monitored based on the calculated alert expression; and save changes to the object in the database.
[19] При этом этап изменения объекта при помощи пользовательского устройства необходим для внесения изменения, на основе которого будет создано оповещение. Этап генерации выражения и вычисления результата выражения необходимы для изменения значения объектов, на основе которого будет производится расчет оповещения, а также для связи выражения с другими объектами, участвующими в расчете. Хранение объектов, используемых выражением, и сохранения изменения объекта в источнике объектов необходимы для создания списка объектов, связанных с оповещением. Этап определения типа оповещения необходим для определения того, быстрое это оповещение или нет, для последующего принятия решения о создании оповещения. Расчет выражения оповещения для определенного типа оповещений необходим для проверки, изменился ли результат выражения оповещения. Формирование списка изменившихся объектов необходим для сравнения его со списком объектов для мониторинга. Исполнение оповещения необходимо для непосредственного вывода оповещения на интерфейс пользовательского устройства. Обновление списка объектов в списке объектов для мониторинга на основании рассчитанного выражения необходим для последующего осуществления мониторинга объектами, в результате изменения которых может измениться значение выражения оповещения. Сохранение изменений объектов необходим для того, чтобы сохранить изменения, внесенные в объект пользователем, в базе данных.[19] In this case, the stage of changing the object using the user device is necessary to make a change, on the basis of which an alert will be created. The stage of generating the expression and calculating the result of the expression is necessary to change the value of the objects on the basis of which the alert will be calculated, as well as to link the expression with other objects involved in the calculation. Storing the objects used by the expression and saving the change to the object in the object source is necessary to create a list of objects associated with the alert. The step of determining the type of alert is necessary to determine if the alert is fast or not, in order to then decide whether to create an alert. Calculation of the alert expression for a specific alert type is required to check if the result of the alert expression has changed. Formation of the list of changed objects is necessary to compare it with the list of objects for monitoring. Execution of the notification is necessary for the direct output of the notification to the interface of the user device. Updating the list of objects in the list of objects to be monitored based on the calculated expression is necessary for subsequent monitoring by objects, as a result of which changes the value of the notification expression may change. Saving changes to objects is necessary in order to save the changes made to the object by the user in the database.
[20] На этапе исполнения оповещения при помощи исполнителя оповещения дополнительно могут исполнять программный код, включающийся в оповещение. Это может быть нужно в случае, если оповещение включает дополнительный программный код, позволяющий реализовывать сложные сценарии реакции на оповещение. [20] At the notification execution stage, the notification executor can additionally execute the program code included in the notification. This may be necessary if the alert includes additional code that allows you to implement complex scenarios for reacting to the alert.
[21] После этапа исполнения оповещения могут дополнительно проверять, было ли исполнено оповещение. Это могут реализовывать посредством передачи объектов из модуля сохранения объектов в список объектов для мониторинга, проверки наличия этого объекта в списке объектов для мониторинга и передачи оповещения в исполнитель оповещений. При этом, если оповещение по изменению этого объекта было исполнено, то могут передавать объект в сервис оповещений и визуализировать оповещение в пользовательском интерфейсе.[21] After the step of executing the alerts, it may further check whether the alert has been executed. This can be done by passing objects from the object saver to the list of objects to monitor, checking if the object is in the list of objects to monitor, and sending an alert to the alert executor. At the same time, if the notification on the change of this object has been executed, then they can pass the object to the notification service and visualize the notification in the user interface.
[22] После этапа исполнения оповещения также могут обновлять список объектов для мониторинга. Это могут делать посредством передачи объектов из модуля сохранения объектов в список объектов для мониторинга, передачи объекта анализатору объектов выражения оповещения и проверки того, изменился ли список объектов оповещения. В случае если список объектов изменился, то могут передавать новый список в список объектов для мониторинга и обновлять объект в списке объектов для мониторинга. [22] After the execution phase, alerts can also update the list of objects to be monitored. This can be done by passing objects from the object saver to the list of objects to monitor, passing the object to the object parser of the alert expression, and checking if the list of alert objects has changed. If the list of objects has changed, then they can transfer the new list to the list of objects for monitoring and update the object in the list of objects for monitoring.
[23] При этом этапы проверки того, было ли исполнено оповещение, и обновления списка объектов для мониторинга могут производить параллельно для дополнительного ускорения процесса.[23] At the same time, the steps of checking whether the notification has been executed and updating the list of objects for monitoring can be performed in parallel to further speed up the process.
Описание чертежейDescription of drawings
[24] На Фиг. 1 представлен схематичный вид системы управления оповещениями согласно настоящему изобретению.[24] FIG. 1 is a schematic view of an alert management system according to the present invention.
[25] На Фиг. 2 представлен схематичный вид системы управления оповещениями с дополнительной возможностью проверки исполнения оповещения согласно настоящему изобретению.[25] FIG. 2 is a schematic view of an alert management system, with the additional capability of verifying the execution of an alert, in accordance with the present invention.
[26] На Фиг. 3 представлен схематичный вид системы управления оповещениями с дополнительной возможностью обновления списка объектов для мониторинга согласно настоящему изобретению.[26] FIG. 3 is a schematic view of an alert management system with the additional ability to update the list of objects to be monitored in accordance with the present invention.
[27] На Фиг. 4 представлен схематичный вид системы управления оповещениями со всеми дополнительными возможностями согласно настоящему изобретению.[27] FIG. 4 is a schematic view of an alert management system with all the additional features of the present invention.
[28] На Фиг. 5 представлена блок-схема, иллюстрируются способ управления оповещениями, согласно настоящему изобретению.[28] FIG. 5 is a block diagram illustrating the notification management method according to the present invention.
[29] На Фиг. 6 представлена блок-схема, иллюстрирующая дополнительные этапы способа управления оповещениями, позволяющие реализовать проверку исполнения оповещения, согласно настоящему изобретению.[29] FIG. 6 is a flow diagram illustrating the additional steps of the notification management method for implementing notification execution verification in accordance with the present invention.
[30] На Фиг. 7 представлена блок-схема, иллюстрирующая дополнительные этапы способа управления оповещениями, позволяющие реализовать обновления списка объектов для мониторинга, согласно настоящему изобретению.[30] FIG. 7 is a flow diagram illustrating the additional steps of the alert management method for implementing updates to the list of objects to monitor in accordance with the present invention.
[31] На Фиг. 8 представлена блок-схема, иллюстрирующая все дополнительные этапы способа управления оповещениями, согласно настоящему изобретению.[31] FIG. 8 is a flowchart illustrating all additional steps of the notification management method according to the present invention.
Подробное описаниеDetailed description
[32] В приведенном ниже подробном описании реализации изобретения приведены многочисленные детали реализации, призванные обеспечить отчетливое понимание настоящего изобретения. Однако, квалифицированному в предметной области специалисту очевидно, каким образом можно использовать настоящее изобретение, как с данными деталями реализации, так и без них. В других случаях, хорошо известные методы, процедуры и компоненты не описаны подробно, чтобы не затруднять излишнее понимание особенностей настоящего изобретения.[32] In the following detailed description of the implementation of the invention, numerous implementation details are provided to provide a clear understanding of the present invention. However, it will be obvious to one skilled in the art how the present invention can be used, both with and without these implementation details. In other cases, well-known methods, procedures and components are not described in detail so as not to obscure the features of the present invention.
[33] Кроме того, из приведенного изложения ясно, что изобретение не ограничивается приведенной реализацией. Многочисленные возможные модификации, изменения, вариации и замены, сохраняющие суть и форму настоящего изобретения, очевидны для квалифицированных в предметной области специалистов.[33] In addition, from the foregoing it is clear that the invention is not limited to the above implementation. Numerous possible modifications, alterations, variations, and substitutions that retain the spirit and form of the present invention will be apparent to those skilled in the art.
[34] На Фиг. 1 схематично представлена система управления оповещениями, сконфигурированная с возможностью изменения объектов и создания оповещений, согласно настоящему изобретению. Система включает по крайней мере одно пользовательское устройство 1 с интерфейсом 110, сервер 2 и по крайней мере одну базу данных 3. Сервер 2, в свою очередь, включает по крайней мере один источник объектов 210, компонент оповещения 220, компонент расчета выражений 230 и компонент сохранения 240. Компонент оповещения 220 включает сервис оповещений 221, анализатор объектов выражения оповещения 222 и исполнитель оповещения 223. Компонент расчета выражений 230 включает инициатор выражения 231, исполнитель выражения 232 и список объектов для мониторинга 233. А компонент сохранения включает модуль кэширования объектов 241 и модуль сохранения объектов 242. При этом база данных 3 взаимодействует с источником объектов 210, который, в свою очередь, взаимодействует с интерфейсом 110. При помощи интерфейса 110 возможно изменять объекты из по крайней мере одного источника объектов 210. Триггер о произошедшем изменении при помощи интерфейса 110 посылают во взаимодействующий с ним сервис оповещений 221, который взаимодействует с анализатором выражения объектов оповещения 222. Анализатор объектов выражения оповещения 222 взаимодействует с исполнителем оповещения 223, а исполнитель оповещения 223 – со списком объектов для мониторинга 230. По крайней мере один источник объектов 210 взаимодействует с инициатором выражения 231. Инициатор выражения 231 взаимодействует с исполнителем выражения 232, а исполнитель выражения 232 – с модулем кэширования объектов 241, который в свою очередь, взаимодействует с модулем сохранения объектов 242. Модуль сохранения объектов 242 взаимодействует с по крайней мере одной базой данных 3, что замыкает цепочку взаимодействия элементов системы управления оповещениями. Данная конфигурация системы позволяет изменять объекты из базы данных 3 и создавать оповещения, основанные на внесенных изменениях. [34] FIG. 1 is a schematic representation of an alert management system configured to modify objects and generate alerts in accordance with the present invention. The system includes at least one
[35] По крайней мере одно пользовательское устройство 1 может являться любой электронной вычислительной машиной (ЭВМ), сконфигурированной с возможностью выхода в Интернет и включающей память и процессор. Например, это может быть настольная ЭВМ такая, как персональный компьютер (ПК), домашний компьютер, моноблок, Plug PC (Plug Personal Computer), игровой компьютер. Также это может быть интернет-устройством, например, нетбуком, интернет-планшетом, планшетным нетбуков, неттопом. Также пользовательской устройство 1 может являться малой и/или мобильной ЭВМ, например, мобильным интернет-устройством, карманным ПК, ноутбуком, смартфоном и др. [35] At least one
[36] Интерфейс 110 пользовательского устройства 1 представляет собой границу между двумя функциональными объектами (пользовательским устройством 1 и сервером 2), требования к которой определяются стандартом; совокупность средств, методов и правил взаимодействия (управления, контроля и т. д.) между элементами системы. При этом, интерфейс 1 может использоваться как элемент пользовательского устройства 1, например, дисплей, набор кнопок и переключателей для настройки плюс правила управления ими, относящиеся к человека-машинному интерфейсу. Также могут использоваться клавиатура, мышь и пр. устройства ввода, являющиеся элементами интерфейса «человек — компьютер». Также оба вида интерфейсов могут использоваться в сочетании друг с другом.[36] The
[37] Сервер 2 является одним из аппаратного обеспечения систему управления оповещениями. Он 2 может представлять собой выделенный или специализированный компьютер для выполнения сервисного программного обеспечения. Серверное (сервисное) программное обеспечение – это программный компонент вычислительной системы, выполняющий сервисные (обслуживающие) функции по запросу клиента, предоставляя ему доступ к определённым ресурсам или услугам.[37]
[38] Сервер 2 в рамках настоящего изобретения включает по крайней мере один источник объектов 210. Он 210 используется для связи объектов из базы данных 3 с сервером 2 и пользовательским устройством 1. Цифровой объект — объект, состоящий из структурированной последовательности байтов, имеющий название, уникальный идентификатор и атрибуты, описывающие его свойства. В рамках настоящего изобретения под цифровым объектом понимается любой документ, файл, таблица или какие-либо их компоненты, размещенные в цифровой среде. В предпочтительном варианте под объектом понимается элемент из базы данных 3.[38] The
[39] Компонент оповещений 220 предназначен для непосредственного создания оповещений. То, что он 220 включает сервис оповещений 221, позволяет определять тип оповещения. Оповещение – это автоматическое создание события при изменении значения выражения на языке выражений в результате изменения одного из объектов, участвующих в расчете значения выражения. Они делятся на два типа: быстрые и стандартные. Быстрые оповещения – это оповещения, для обработки которых не требуется циклический пересчет выражения оповещения. Для стандартных оповещений требуется регулярный пересчет. Стандартное оповещение вычисляется при работе процессов приложения через определённые промежутки времени. Объекты будут обновляться при пересчёте основного выражения оповещения формы, или дополнительного оповещения (если оно задано). Например, основное выражение для атрибута Атрибут1 может быть задано как Кредит.Клиент, а дополнительное как Кредит.Клиент.Возраст. В этом случае, при изменении значения возраста клиента, все элементы формы, зависящие от атрибута Атрибут1 будут обновлены. Идентификатор представляет собой «координаты» объекта в базе данных 3.[39] The
[40] Чтобы оповещение было быстрым, необходимо, чтобы выражение оповещения удовлетворяло следующему списку требований: в нем должны использоваться только функции, поддерживающиеся в быстрых оповещениях и в нем должны получать значения атрибутов контекстного типа. При этом атрибуты должны быть неколлекционными, и, в случае атрибутов формы, хранимыми. Допускается получение значения цепочки хранимых атрибутов, например, оповещение Клиент.Договор.Статус, получающая значение хранимого атрибута формы Клиент (ссылка на тип Клиент) будет быстрой.[40] For an alert to be fast, the alert expression must satisfy the following list of requirements: it must use only the functions supported in fast alerts, and it must take attribute values of the context type. At the same time, the attributes must be non-collectible, and, in the case of form attributes, stored. It is possible to receive the value of a chain of stored attributes, for example, the alert Client.Contract.Status, which receives the value of the stored attribute of the form Client (reference to type Client) will be fast.
[41] Выражение представляет собой текст на языке выражений, который может быть рассчитан (исполнен). При этом в процессе расчета могут использоваться и изменяться значения атрибутов объектов. Оповещения, в свою очередь, являются сущностью, которая содержит в себе выражение и предназначено для уведомления создателя оповещения о том, что значение этого выражения изменилось. Такие выражения так именуются в тексте «выражения оповещения». Все прочие выражения, которые отправляются на исполнение прочими компонентами системы и генерируют изменения объектов именуются как «выражение».[41] An expression is text in an expression language that can be calculated (executed). At the same time, the values of object attributes can be used and changed in the calculation process. Alerts, in turn, are an entity that contains an expression and is intended to notify the creator of the alert that the value of this expression has changed. Such expressions are referred to in the text as "alert expressions". All other expressions that are sent for execution by other components of the system and generate changes to objects are referred to as an "expression".
[42] Анализатор объектов выражения оповещения 222 при создании нового экземпляра оповещения рекурсивно обрабатывает выражение, как при расчете его значения, но кроме непосредственно расчета формирует список объектов, которые были использованы при расчете выражения. Эти объекты попадают в список объектов для мониторинга 233. [42] The alert
[43] Исполнитель оповещения 223 является исполнительным адаптером, предназначенным для исполнения самого оповещения. Также он 223 может содержать пользовательский программный код, который должен выполниться при срабатывании оповещения. Результатом срабатывания оповещения может быть как обновление некоторых частей пользовательского интерфейса 110, которые явно помечены, как зависящие от оповещения, так и исполнение произвольного программного кода, что позволяет реализовывать сложные сценарии реакции на оповещение.[43] The
[44] При этом последовательное взаимодействие сервиса оповещений 221, анализатора объектов выражения оповещения 222 и исполнителя оповещения 223 позволяет создавать оповещение, определять его тип, связанные с оповещением объекты и их идентификаторы, а также непосредственно исполнять оповещение.[44] At the same time, the sequential interaction of the
[45] Компонент расчета выражений 230 представляет собой слой проверки изменений объектов. При любом изменении объектов каким-либо способом — через интерфейс пользователя или автоматизированными обработчиками данных — все изменяемые или удаляемые объекты проверяются на то, включены ли они в список объектов для мониторинга 233. Он включает по крайней мере один инициатор выражений 231, исполнитель выражений 232 и список объектов для мониторинга 233.[45] The
[46] Инициатор выражений 231 предназначен для генерации выражений, соответствующего изменению объектов. Исполнитель выражений 232 представляет собой вычислитель выражения оповещения, который проверяет, изменился ли результат выражения оповещения, а также формирует новый список объектов, которые участвовали в расчете выражения оповещения. Список объектов для мониторинга 233, в свою очередь, хранит идентификаторы объектов, которые необходимо проверять при изменении, а также карту соответствия объекта и списка оповещений, которые от него зависят. [46] Expression Initiator231 is designed to generate expressions corresponding to changing objects. Expression Executor232represents the alert expression evaluator, which checks whether the result of the alert expression has changed, and also generates a new list of objects that participated in the calculation of the alert expression. List of objects for monitoring233, in turn, stores the identifiers of the objects that need to be checked when changing, as well as a mapping of the object and the list of alerts that depend on it.
[47] При этом исполнитель оповещений 223 взаимодействует со списком объектов для мониторинга 233 для проверки того, включен ли объект, по которому должно быть исполнено оповещение, в список объектов для мониторинга 233. А инициатор выражений 232 взаимодействует с по крайней мере одним источником объектов 231 для того, чтобы детектировать изменения объектов для последующего создания события оповещения, связанного с объектом, а с исполнителем выражения 232 – для передачи ему выражения с целью последующего вычисления значения выражения. [47] At the same time, the
[48] Компонент сохранения 240 при этом предназначен для сохранения изменений объектов из базы данных 3. Модуль кэширования объектов 241 может осуществлять временное хранение изменений. В сфере вычислительной обработки данных кэш – это высокоскоростной уровень хранения, на котором требуемый набор данных, как правило, временного характера. Доступ к данным на этом уровне осуществляется значительно быстрее, чем к основному месту их хранения. С помощью кэширования становится возможным эффективное повторное использование ранее полученных или вычисленных данных.[48] The
[49] При этом изменения объектов также может осуществляться модулем сохранения объектов 242, подключенному к по крайней мере одной базе данных 3. Он 242 записывает в базу данных 3, выполняя необходимые проверки и передачу событий в разные сервисы, в том числе в оповещения. [49] At the same time, object changes can also be carried out by the
[50] Система управления оповещениями, показанная на Фиг. 1, работает следующим образом. Сначала осуществляют изменения объекта при помощи пользовательского устройства 1. Изменение, как триггерное событие, посылается в инициатор выражений 231, который генерирует выражение, определяющее изменение объекта. Затем сгенерированное выражение посылают в исполнитель выражений 232, при помощи которого, в свою очередь, вычисляют результат выражения. После этого объекты, которые были использованы в ходе вычисления выражения, посылают в модуль кэширования объектов 241, в котором производят временное хранение объектов с изменениями, а затем их передают в модуль сохранения объектов 242, который, в свою очередь, сохраняет измененные объекты в источнике объектов 210. Одновременно с изменением объекта также производится создание события оповещения об этом изменении. При помощи сервиса оповещений 221 определяют тип оповещения, как это было описано выше. Для определенного типа оповещений, а именно для быстрых оповещений, далее рассчитывают выражение при помощи анализатора объектов выражения оповещения 222. На этом этапе формируют список объектов, которые были использованы при расчете выражения оповещения также при помощи анализатора объектов выражения оповещения 222. Список состоит из изменившихся объектов, использованных при расчете выражения оповещения. После этого исполняют оповещения при помощи исполнителя оповещения 223. Исполнитель оповещения 223, помимо самого оповещения, также может исполнить программный код, который может быть включен в исполнитель оповещения 223. После этого сохраняют изменения объекта при помощи модуля сохранения объектов 242 в базе данных 3.[50] The alert management system shown in FIG. 1 works as follows. First, changes are made to the object using the
[51] На Фиг. 2 изображен схематичный вид системы управления оповещениями с дополнительной возможностью проверки исполнения оповещения согласно настоящему изобретению. Возможность проверки исполнения оповещений является дополнительным техническим результатам в рамках настоящего изобретения, который может быть достигнут посредством добавления дополнительных вариантов взаимодействия элементов системы управления оповещениями, показанных на Фиг. 2. При этом для достижения одновременного дополнительного и основного технических результатов вышеописанные и нижеописанные взаимодействия должны использоваться в сочетании. [51] In FIG. 2 is a schematic view of an alert management system, with the additional capability of verifying alert execution, in accordance with the present invention. The ability to check the execution of alerts is an additional technical result in the framework of the present invention, which can be achieved by adding additional interaction options for the elements of the alert management system shown in FIG. 2. In this case, in order to achieve simultaneous additional and main technical results, the above and below described interactions must be used in combination.
[52] Модуль сохранения объектов 242 может дополнительно взаимодействовать со списком объектов для мониторинга 233. Это может быть нужно для того, что передавать объекты, сохраненные в базе данных 3 модулем сохранения объектов 242, в список объектов для мониторинга 233. При помощи списка объектов для мониторинга 233 при этом проверяют наличие этого объекта в списке 233. [52] The
[53] Список объектов для мониторинга 233, в свою очередь, может взаимодействовать с исполнителем оповещения 223. Таким образом, список объектов для мониторинга 233 передает исполнителю оповещения 223 информацию о том, присутствует ли этот объект в списке 233, а также сам объект. Он 223 проверяет, было ли исполнено оповещение по изменению этого объекта. [53] The list of objects to be monitored 233 , in turn, can interact with the
[54] Исполнитель оповещений 223 может дополнительно взаимодействовать с сервисом оповещений 221, а сервис оповещений 221 взаимодействует с интерфейсом 110. В таком случае, если оповещения по изменению объекта было исполнено, передают объект от исполнителя оповещений 223 в сервис оповещений 221, а затем в интерфейс 110, в котором визуализируют оповещение при помощи сервиса оповещений 221. [54] The
[55] Сама визуализация оповещения может подразумевать под собой изменение визуального воплощения объектов, т.е. само внесенное изменение, а также некоторое всплывающее окно с оповещением об изменении. Эти варианты визуализации оповещения могут использоваться как по отдельности, так и в сочетании. При этом, если в исполнителе оповещений 223 содержится дополнительный пользовательский программный код, могут проводить визуализацию оповещения различными сложными сценариями. Например, оповещения может включать функциональные элементы такие, как кнопки, поля ввода и др. Таким образом, будут реализованы различные способы реакции пользователя на оповещения. Например, он может отменить изменение, принять его, отправить запрос на проверку корректности внесенных изменений и др. [55] The very visualization of an alert may imply a change in the visual embodiment of objects, i.e. the change itself, as well as some pop-up notification of the change. These alert visualization options can be used individually or in combination. At the same time, if the
[56] Часть системы управления оповещениями, показанная на Фиг. 2, работает следующим образом. После этапа исполнения оповещения исполнителем оповещений 223 проверяют, исполнено ли оповещение. При этом передают объекты из модуля сохранения объектов 242 в список объектов для мониторинга 233. При помощи списка объектов для мониторинга 233 проверяют наличие этого объекта в списке 233 и передают информацию о наличии/отсутствии объекта в списке, а также сам объект (точнее, его идентификатор) в исполнитель оповещений 223. Если оповещение по изменению этого объекта было исполнено, то передают объект в сервис оповещений 221, а затем визуализируют оповещение в пользовательском интерфейсе 110 при помощи сервиса оповещений 221. [56] The portion of the alert management system shown in FIG. 2 works as follows. After the step of executing the alert by the
[57] Система управления оповещениями, показанная на Фиг. 1, в сочетании с дополнительными взаимодействиями, показанными на Фиг. 2, работает следующим образом. Сначала осуществляют изменения объекта при помощи пользовательского устройства 1. Изменение, как триггерное событие, посылается в инициатор выражений 231, который генерирует выражение, определяющее изменение объекта. Затем сгенерированное выражение посылают в исполнитель выражений 232, при помощи которого, в свою очередь, вычисляют результат выражения. После этого объекты, которые были использованы в ходе вычисления выражения, посылают в модуль кэширования объектов 241, в котором производят временное хранение объектов с изменениями, а затем их передают в модуль сохранения объектов 242, который, в свою очередь, сохраняет измененные объекты в источнике объектов 210. Одновременно с изменением объекта также производится создание события оповещения об этом изменении в ссылки на оповещение. При помощи сервиса оповещений 221 определяют тип оповещения, как это было описано выше. Для определенного типа оповещений, а именно для быстрых оповещений, далее рассчитывают выражение при помощи анализатора объектов выражения оповещения 222. На этом этапе формируют список объектов, которые были использованы при расчете выражения оповещения также при помощи анализатора объектов выражения оповещения 222. Список состоит из изменившихся объектов, использованных при расчете выражения оповещения. После этого исполняют оповещения при помощи исполнителя оповещения 223. Исполнитель оповещения 223, помимо самого оповещения, также может исполнить программный код, который может быть включен в исполнитель оповещения 223. После этого сохраняют изменения объекта при помощи модуля сохранения объектов 242 в базе данных 3. После этапа исполнения оповещения исполнителем оповещений 223 также проверяют, исполнено ли оповещение. При этом передают объекты из модуля сохранения объектов 242 в список объектов для мониторинга 233. При помощи списка объектов для мониторинга 233 проверяют наличие этого объекта в списке 233 и передают информацию о наличии/отсутствии объекта в списке, а также сам объект (точнее, его идентификатор) в исполнитель оповещений 223. Если оповещение по изменению этого объекта было исполнено, то передают объект в сервис оповещений 221, а затем визуализируют оповещение в пользовательском интерфейсе 110 при помощи сервиса оповещений 221. [57] The alert management system shown in FIG. 1 in combination with additional interactions shown in FIG. 2 works as follows. First, changes are made to the object using the
[58] На Фиг. 3 изображен схематичный вид системы управления оповещениями с дополнительной возможностью обновления списка объектов для мониторинга 233 согласно настоящему изобретению. Возможность обновления списка объектов для мониторинга 233 является дополнительным техническим результатам в рамках настоящего изобретения, который может быть достигнут посредством добавления дополнительных вариантов взаимодействия элементов системы управления оповещениями, показанных на Фиг. 3. При этом для достижения одновременного дополнительного и основного технических результатов варианты взаимодействия, показанные на Фиг. 1, и нижеописанные взаимодействия должны использоваться в сочетании. [58] FIG. 3 is a schematic view of an alert management system with the additional ability to update the list of objects to be monitored 233 in accordance with the present invention. The ability to update the list of objects for monitoring 233 is an additional technical result in the framework of the present invention, which can be achieved by adding additional interaction options for the elements of the alert management system shown in FIG. 3. At the same time, in order to achieve simultaneous additional and main technical results, the interaction options shown in FIG. 1 and the interactions described below should be used in combination.
[59] Как показано на Фиг. 3, модуль сохранения объектов 242 может взаимодействовать со списком объектов для мониторинга 233. Это может быть необходимо для проверки того, содержатся ли сохраненные объекты в списке 233. [59] As shown in FIG. 3, the
[60] Список объектов для мониторинга 233 может дополнительно взаимодействовать с анализатором объектов выражения оповещения 222 двусторонне. Это может быть необходимо для проверки того, изменился ли список объектов выражения оповещения. [60] The list of objects to monitor 233 may further interact with the object parser of the
[61] Часть системы управления оповещениями, показанная на Фиг. 3, работает следующим образом. После этапа исполнения оповещения исполнителем оповещений 223 обновляют список объектов для мониторинга 233. Для этого сначала передают объекты из модуля сохранения объектов 242 в список объектов для мониторинга 233. В нем 233 производится проверка того, содержатся ли сохраненные объекты в списке 233. После этого объект передают анализатору объектов выражения оповещения 222. При помощи анализатора 222 проверяют, изменился ли список объектов выражения оповещения. Если список объектов выражения оповещения изменился, то передают новый список в список объектов для мониторинга 233 и обновляют список 233 новым списком.[61] The portion of the alert management system shown in FIG. 3 works as follows. After the alert execution step, the
[62] Система управления оповещениями, показанная на Фиг. 1, в сочетании с дополнительными взаимодействиями, показанными на Фиг. 3, работает следующим образом. Сначала осуществляют изменения объекта при помощи пользовательского устройства 1. Изменение, как триггерное событие, посылается в инициатор выражений 231, который генерирует выражение, определяющее изменение объекта. Затем сгенерированное выражение посылают в исполнитель выражений 232, при помощи которого, в свою очередь, вычисляют результат выражения. После этого объекты, которые были использованы в ходе вычисления выражения, посылают в модуль кэширования объектов 241, в котором производят временное хранение объектов с изменениями, а затем их передают в модуль сохранения объектов 242, который, в свою очередь, сохраняет измененные объекты в источнике объектов 210. Одновременно с изменением объекта также производится создание события оповещения об этом изменении в виде ссылки на оповещение. При помощи сервиса оповещений 221 определяют тип оповещения, как это было описано выше. Для определенного типа оповещений, а именно для быстрых оповещений, далее рассчитывают выражение оповещения при помощи анализатора объектов выражения оповещения 222. На этом этапе формируют список объектов, которые были использованы при расчете оповещения также при помощи анализатора объектов выражения оповещения 222. Список состоит из изменившихся объектов, использованных при расчете выражения оповещения. После этого исполняют оповещения при помощи исполнителя оповещения 223. Исполнитель оповещения 223, помимо самого оповещения, также может исполнить программный код, который может быть включен в исполнитель оповещения 223. После этого сохраняют изменения объекта при помощи модуля сохранения объектов 242 в базе данных 3. После этапа исполнения оповещения исполнителем оповещений 223 также обновляют список объектов для мониторинга 233 и параллельно проверяют, было ли исполнено оповещение. Для обновления списка объектов для мониторинга 233 сначала передают объекты из модуля сохранения объектов 242 в список объектов для мониторинга 233. В нем 233 производится проверка того, содержатся ли сохраненные объекты в списке 233. После этого объект передают анализатору объектов выражения оповещения 222. При помощи анализатора 222 проверяют, изменился ли список объектов выражения оповещения. Если список объектов выражения оповещения изменился, то передают новый список в список объектов для мониторинга 233 и обновляют список 233 новым списком. Проверка исполнения оповещения при этом производится следующим образом. Передают объекты из модуля сохранения объектов 242 в список объектов для мониторинга 233. При помощи списка объектов для мониторинга 233 проверяют наличие этого объекта в списке 233 и передают информацию о наличии/отсутствии объекта в списке, а также сам объект (точнее, его идентификатор) в исполнитель оповещений 223. Если оповещение по изменению этого объекта было исполнено, то передают объект в сервис оповещений 221, а затем визуализируют оповещение в пользовательском интерфейсе 110 при помощи сервиса оповещений 221. [62] The alert management system shown in FIG. 1 in combination with additional interactions shown in FIG. 3 works as follows. First, changes are made to the object using the
[63] При этом варианты взаимодействия элементов системы управления оповещениями, показанные на Фиг. 1, Фиг. 2 и Фиг. 3, могут использоваться в сочетании, как это показано на Фиг. 4. Сначала осуществляют изменения объекта при помощи пользовательского устройства 1. Изменение, как триггерное событие, посылается в инициатор выражения 231, который генерирует выражение, определяющее изменение объекта. Затем сгенерированное выражение посылают в исполнитель выражений 232, при помощи которого, в свою очередь, вычисляют результат выражения. После этого объекты, которые были использованы в ходе вычисления выражения, посылают в модуль кэширования объектов 241, в котором производят временное хранение объектов с изменениями, а затем их передают в модуль сохранения объектов 242, который, в свою очередь, сохраняет измененные объекты в источнике объектов 210. Одновременно с изменением объекта также производится создание события оповещения об этом изменении в виде ссылки на оповещение. При помощи сервиса оповещений 221 определяют тип оповещения, как это было описано выше. Для определенного типа оповещений, а именно для быстрых оповещений, далее рассчитывают выражение оповещения при помощи анализатора объектов выражения оповещения 222. На этом этапе формируют список объектов, которые были использованы при расчете выражения оповещения также при помощи анализатора объектов выражения оповещения 222. Список состоит из изменившихся объектов, использованных при расчете выражения оповещения. После этого исполняют оповещение при помощи исполнителя оповещения 223. Исполнитель оповещения 223, помимо самого оповещения, также может исполнить программный код, который может быть включен в исполнитель оповещения 223. После этого сохраняют изменения объекта при помощи модуля сохранения объектов 242 в базе данных 3. После этапа исполнения оповещения исполнителем оповещений 223 также обновляют список объектов для мониторинга 233. Для этого сначала передают объекты из модуля сохранения объектов 242 в список объектов для мониторинга 233. В нем 233 производится проверка того, содержатся ли сохраненные объекты в списке 233. После этого объект передают анализатору объектов выражения оповещения 222. При помощи анализатора 222 проверяют, изменился ли список объектов выражения оповещения. Если список объектов оповещения изменился, то передают новый список в список объектов для мониторинга 233 и обновляют список 233 новым списком.[63] At the same time, the interaction options for the elements of the alert management system shown in FIG. 1, Fig. 2 and FIG. 3 can be used in combination as shown in FIG. 4. First, changes are made to the object using the
[64] База данных 3, являющаяся частью системы управления оповещениями, может быть как размещена на сервере 2, так и являться внешней базой данных. При этом могут также использоваться внешние базы данных и базы данных, размещенные на сервере в сочетании. Их может быть любое количество, в зависимости от конкретного воплощения системы и нужд. [64] The
[65] В качестве по крайней мере одного инициатора выражения 231 может использоваться прикладной код (формы). Также могут использоваться процессы и веб-сервисы. [65] As at least one initiator of
[66] Интерфейс 110 пользовательского устройства 1 может быть реализован любым человекочитаемым способом, т.е. в виде любого человеко-машинного интерфейса. Например, с помощью интерфейса командной строки. Интерфейс командной строки – это интерфейс пользователя, реализованный с помощью набирания пользователем текста команд и чтения текста ответов. Также может использоваться жестовый интерфейс, позволяющий пользователю взаимодействовать с ЭВМ (отдавать ей команды) при помощи жестов. В этом случае, также стоит предусмотреть включение в пользовательское устройство 1 камеры и/или веб-камеры, способной распознавать движения человека. Также возможна реализация голосового интерфейса, при помощи которого команды отдаются голосом. В этом случае, к пользовательскому устройству 1 должен быть подключен также микрофон. Наиболее предпочтительным вариантом является использование графического интерфейса пользователя. Он реализуется посредством формирования графических изображений и манипулирования ими.[66] The
[67] На Фиг. 5 изображена блок-схема, иллюстрирующая способ управления оповещениями, согласно которому работает система управления оповещениями, показанная на Фиг. 1. Сначала осуществляют изменения объекта при помощи пользовательского устройства 1. Изменение, как триггерное событие, посылается в инициатор выражения 231, который генерирует выражение, определяющее изменение объекта. Затем сгенерированное выражение посылают в исполнитель выражений 232, при помощи которого, в свою очередь, вычисляют результат выражения. После этого объекты, которые были использованы в ходе вычисления выражения, посылают в модуль кэширования объектов 241, в котором производят временное хранение объектов с изменениями, а затем их передают в модуль сохранения объектов 242, который, в свою очередь, сохраняет измененные объекты в источнике объектов 210. Одновременно с изменением объекта также производится создание события оповещения об этом изменении в виде ссылки на оповещение. При помощи сервиса оповещений 221 определяют тип оповещения, как это было описано выше. Для определенного типа оповещений, а именно для быстрых оповещений, далее рассчитывают выражение оповещения при помощи анализатора объектов выражения оповещения 222. На этом этапе формируют список объектов, которые были использованы при расчете выражения оповещения также при помощи анализатора объектов выражения оповещения 222. Список состоит из изменившихся объектов, использованных при расчете выражения оповещения. После этого исполняют оповещения при помощи исполнителя оповещения 223. Исполнитель оповещения 223, помимо самого оповещения, также может исполнить программный код, который может быть включен в исполнитель оповещения 223. После этого сохраняют изменения объекта при помощи модуля сохранения объектов 242 в базе данных 3.[67] FIG. 5 is a block diagram illustrating the notification management method according to which the notification management system shown in FIG. 1. First, changes are made to the object using the
[68] Этап изменения объекта при помощи пользовательского устройства 1 может подразумевать изменение его визуального воплощения, изменение данных, содержащихся в объекте и др. Это может производится посредством дополнительных устройств ввода, например, посредством компьютерной мыши, клавиатуры и других устройств ввода, например, микрофона. [68] The step of modifying an object using the
[69] Этап генерации идентификатора подразумевает анализ «координаты» объекта в базе данных 3. «Координата» – это идентификатор объекта. Идентификатор, как «координата» объекта, при этом также задает идентификатор оповещения. [69] The ID generation step involves parsing the "coordinate" of the object in the
[70] На этапе вычисления результата выражения оповещения, выражение, по сути, «распаковывают», определяя, какие объекты задействованы в расчете конкретного выражения. Например, выражение Клиент.Договор.Статус включает объекты: Статус, доступный по выражению Клиент.Договор.Статус, Договор, доступный по выражению Клиент.Договор, и Клиент, доступный по выражению Клиент. Для определения всей цепочки использованных объектов исполнитель выражений 232 рекурсивно вычисляет выражение, формируя при этом список использованных объектов. Список использованных объектов отправляют в модуль кэширования объектов 241 для возможности временного быстрого доступа к ним, а также сохраняют их в источнике объектов 210 для последующего создания оповещения. [70] At the stage of evaluating the result of the alert expression, the expression is essentially "unpacked", determining which objects are involved in the calculation of a particular expression. For example, the expression Client.Agreement.Status includes the following objects: Status accessible by the expression Client.Agreement.Status, Agreement accessible by the expression Client.Agreement, and Client accessible by the expression Client. To determine the entire chain of used objects, the
[71] Определения типа оповещения подразумевает определение того, является оповещение быстрым или стандартным, на основании того, используются ли в нем только функции, поддерживающиеся в быстрых оповещениях, и на основании получения значения атрибутов контекстного типа, как это было описано ранее. При этом оповещения исполняют только для быстрых оповещений. В случае, если оповещение стандартное, то на этапе определения типа оповещения алгоритм завершает свою работу.[71] Alert type definitions involve determining whether an alert is a quick alert or a standard alert based on whether it uses only the features supported in quick alerts, and based on getting the value of the context type attributes as previously described. In this case, notifications are executed only for fast notifications. If the notification is standard, then at the stage of determining the type of notification, the algorithm completes its work.
[72] Расчет выражения оповещения анализатором объектов выражения оповещения 222 при создании нового экземпляра оповещения подразумевает рекурсивную обработку выражения, как при расчете его значения, но кроме непосредственно расчета формирует список объектов, которые были использованы при расчете выражения. Эти объекты попадают в список объектов для мониторинга 233. [72] Calculation of the alert expression by the alert
[73] На Фиг. 6 изображена блок-схема, иллюстрирующая дополнительные этапы способа управления оповещениями, обеспечивающие дополнительный технический результат, заключающийся в возможности проверке того, было ли исполнено оповещение. Согласно нему, после этапа исполнения оповещения исполнителем оповещений 223 проверяют, исполнено ли оповещение. При этом передают объекты из модуля сохранения объектов 242 в список объектов для мониторинга 233. При помощи списка объектов для мониторинга 233 проверяют наличие этого объекта в списке 233 и передают информацию о наличии/отсутствии объекта в списке, а также сам объект (точнее, его идентификатор) в исполнитель оповещений 223. Если событие оповещения по изменению этого объекта было исполнено, то передают объект в сервис оповещений 221, а затем визуализируют оповещение в пользовательском интерфейсе 110 при помощи сервиса оповещений 221. [73] FIG. 6 is a flow diagram illustrating additional steps of the notification management method, providing an additional technical result of being able to check whether the notification has been executed. According to it, after the step of executing the notification by the
[74] Также могут достигать и другого дополнительного технического результата посредством добавления этапов, показанных на Фиг. 7. После этапа исполнения оповещения исполнителем оповещений 223 обновляют список объектов для мониторинга 233. Для этого сначала передают объекты из модуля сохранения объектов 242 в список объектов для мониторинга 233. В нем 233 производится проверка того, содержатся ли сохраненные объекты в списке 233. После этого объект передают анализатору объектов выражения оповещения 222. При помощи анализатора 222 проверяют, изменился ли список объектов выражения оповещения. Если список объектов выражения оповещения изменился, то передают новый список в список объектов для мониторинга 233 и обновляют список 233 новым списком. Это позволяет обновлять список объектов для мониторинга 233, благодаря чему системе добавляется также бльшая автоматизированность. [74] Another additional technical result can also be achieved by adding the steps shown in FIG. 7. After the alert execution step, the
[75] Также в любом из вариантов воплощения способа управления оповещениями могут дополнительно на этапе исполнения оповещения при помощи исполнителя оповещения 223 дополнительно исполняют программный код, включающийся в оповещение и/или в исполнительный адаптер, представляющий собой исполнитель оповещения 223. Как уже было описано ранее, это может позволить реализовывать сложные сценарии реакции на оповещение.[75] Also, in any of the embodiments of the notification management method, additionally, at the stage of executing the notification, using the
[76] Также дополнительные этапы, показанные на Фиг. 6 и Фиг. 7 и описанные выше, и основные этапы, показанные на Фиг. 5, могут использоваться в сочетании, образуя способ управления оповещениями, показанный на Фиг. 8. В этом случае, сначала осуществляют изменения объекта при помощи пользовательского устройства 1. Изменение, как триггерное событие, посылается в инициатор выражения 231, который генерирует выражение, определяющее изменение объекта. Затем сгенерированное выражение посылают в исполнитель выражений 232, при помощи которого, в свою очередь, вычисляют результат выражения. После этого объекты, которые были использованы в ходе вычисления выражения, посылают в модуль кэширования объектов 241, в котором производят временное хранение объектов с изменениями, а затем их передают в модуль сохранения объектов 242, который, в свою очередь, сохраняет измененные объекты в источнике объектов 210. Одновременно с изменением объекта также производится создание событии оповещения об этом изменении. При помощи сервиса оповещений 221 определяют тип оповещения, как это было описано выше. Для определенного типа оповещений, а именно для быстрых оповещений, далее рассчитывают выражение оповещения при помощи анализатора объектов выражения оповещения 222. На этом этапе формируют список объектов, которые были использованы при расчете выражения также при помощи анализатора объектов выражения оповещения 222. Список состоит из изменившихся объектов, использованных при расчете выражения оповещения. После этого исполняют оповещения при помощи исполнителя оповещения 223. Исполнитель оповещения 223, помимо самого оповещения, также может исполнить программный код, который может быть включен в исполнитель оповещения 223. После этого сохраняют изменения объекта при помощи модуля сохранения объектов 242 в базе данных 3. После этапа исполнения оповещения исполнителем оповещений 223 также обновляют список объектов для мониторинга 233. Для этого сначала передают объекты из модуля сохранения объектов 242 в список объектов для мониторинга 233. В нем 233 производится проверка того, содержатся ли сохраненные объекты в списке 233. После этого объект передают анализатору объектов выражения оповещения 222. При помощи анализатора 222 проверяют, изменился ли список объектов выражения оповещения. Если список объектов оповещения изменился, то передают новый список в список объектов для мониторинга 233 и обновляют список 233 новым списком. На этапе исполнения оповещения также исполняют программный код, включающийся в оповещение и/или в исполнитель оповещения 223.[76] Also, the additional steps shown in FIG. 6 and FIG. 7 and those described above and the main steps shown in FIG. 5 may be used in combination to form the alert management method shown in FIG. 8. In this case, changes to the object are first carried out using the
[77] В настоящих материалах заявки представлено предпочтительное раскрытие осуществления заявленного технического решения, которое не должно использоваться как ограничивающее иные, частные воплощения его реализации, которые не выходят за рамки запрашиваемого объема правовой охраны и являются очевидными для специалистов в соответствующей области техники.[77] The present application materials provide a preferred disclosure of the implementation of the claimed technical solution, which should not be used as limiting other, private embodiments of its implementation, which do not go beyond the requested scope of legal protection and are obvious to specialists in the relevant field of technology.
Claims (52)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
PCT/RU2021/000631 WO2023121504A1 (en) | 2021-12-24 | 2021-12-30 | System and method for managing notifications |
Publications (1)
Publication Number | Publication Date |
---|---|
RU2783782C1 true RU2783782C1 (en) | 2022-11-17 |
Family
ID=
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
RU2530340C2 (en) * | 2009-06-23 | 2014-10-10 | Бейджинг Согоу Текнолоджи Девелопмент Ко., Лтд. | Update notification method and system |
RU2707708C2 (en) * | 2015-04-03 | 2019-11-28 | Общество с ограниченной ответственностью "Колловэар" | System and method of searching data in database of graphs |
WO2019231645A1 (en) * | 2018-05-29 | 2019-12-05 | Microsoft Technology Licensing, Llc | Change notifications for object storage |
US10860414B1 (en) * | 2020-01-31 | 2020-12-08 | Qumulo, Inc. | Change notification in distributed file systems |
US20210390095A1 (en) * | 2019-04-16 | 2021-12-16 | Snowflake Inc. | Notifying modifications to external tables in database systems |
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
RU2530340C2 (en) * | 2009-06-23 | 2014-10-10 | Бейджинг Согоу Текнолоджи Девелопмент Ко., Лтд. | Update notification method and system |
RU2707708C2 (en) * | 2015-04-03 | 2019-11-28 | Общество с ограниченной ответственностью "Колловэар" | System and method of searching data in database of graphs |
WO2019231645A1 (en) * | 2018-05-29 | 2019-12-05 | Microsoft Technology Licensing, Llc | Change notifications for object storage |
US20210390095A1 (en) * | 2019-04-16 | 2021-12-16 | Snowflake Inc. | Notifying modifications to external tables in database systems |
US10860414B1 (en) * | 2020-01-31 | 2020-12-08 | Qumulo, Inc. | Change notification in distributed file systems |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN113377850B (en) | Big data technology platform of cognitive Internet of things | |
US20170372442A1 (en) | Healthcare workflow system | |
TWI453666B (en) | Method and computer-readable storage medium for using collaborative development information in a team environment | |
US11720825B2 (en) | Framework for multi-tenant data science experiments at-scale | |
US10366359B2 (en) | Automatic extraction and completion of tasks associated with communications | |
US20190286500A1 (en) | Systems and method for event parsing | |
US20160292305A1 (en) | System, method, and program for storing and analysing a data graph | |
US11614924B1 (en) | Systems, methods, user interfaces, and development environments for a data manager | |
US11301245B2 (en) | Detecting bias in artificial intelligence software by analysis of source code contributions | |
EP3062245A1 (en) | Dynamic modular ontology | |
Troya et al. | Specification and simulation of queuing network models using domain-specific languages | |
RU2783782C1 (en) | System and method for managing notifications | |
CN115543428A (en) | Simulated data generation method and device based on strategy template | |
WO2023121504A1 (en) | System and method for managing notifications | |
EP4030280A1 (en) | Seamless lifecycle stability for extensible software features | |
CN114995728A (en) | Rule configuration method and device, electronic equipment and storage medium | |
Putro et al. | Collaboration of Progressive Web App (PWA) And Firebase Cloud Messaging (FCM) for Optimal Performance Mailing Software | |
CN116775030B (en) | Method and device for creating security baseline | |
US11321093B1 (en) | Multilayered generation and processing of computer instructions | |
US11836496B2 (en) | Multilayered generation and processing of computer instructions | |
US20230333882A1 (en) | Systems and methods for creating workflows by chaining microapps in a workspace platform | |
US12124427B2 (en) | Consolidating change requests in data hierarchies | |
US20230010906A1 (en) | System event analysis and data management | |
JP7391740B2 (en) | Impact identification support device and impact identification support method | |
US20240176769A1 (en) | Consolidating change requests in data hierarchies |