The present invention relates to notification systems, and more specifically, to data notifications systems for health data.
Data reservoirs allow all forms of customer-specific data to coexist in a normalized, single storage repository and data processing engine. Data reservoirs are often used as a data source for multi-dimensional analytics programs. To access the data stored in data reservoirs, applications must continuously fetch the data from the data reservoir in batch operations, and update their own data stores accordingly. However, the continual batch loading of large data sets from the data reservoir is inefficient. Similarly, if the application has to poll the data reservoir for new updates, the poll interval affects the turnaround time to implement advanced solutions.
According to one embodiment, a method comprises receiving a request specifying to receive notifications for updates to data in a multi-tenant data store for a first group comprising a plurality of people, translating the request based on a set of mappings to reflect a physical representation of the data in the data store, generating a notification reflecting an update to data in the data store for a first person of the plurality of people, and storing the notification on a streaming platform for access by a first client application, wherein the notification comprises data describing a location of the updated data in the multi-tenant data store.
In another embodiment, a system comprises a processor and a memory storing instructions, which when executed by the processor, performs an operation comprising receiving a request specifying to receive notifications for updates to data in a multi-tenant data store for a first group comprising a plurality of people, translating the request based on a set of mappings to reflect a physical representation of the data in the data store, generating a notification reflecting an update to data in the data store for a first person of the plurality of people, and storing the notification on a streaming platform for access by a first client application, wherein the notification comprises data describing a location of the updated data in the multi-tenant data store.
In another embodiment, a computer-readable storage medium has computer-readable program code embodied therewith, the computer-readable program code executable by a processor to perform an operation comprising receiving a request specifying to receive notifications for updates to data in a multi-tenant data store for a first group comprising a plurality of people, translating the request based on a set of mappings to reflect a physical representation of the data in the data store, generating a notification reflecting an update to data in the data store for a first person of the plurality of people, and storing the notification on a streaming platform for access by a first client application, wherein the notification comprises data describing a location of the updated data in the multi-tenant data store.
Embodiments disclosed herein provide data notification systems for real-time health data. Generally, a user or application may specify an abstract request to monitor the data of a group of people, e.g., “all people between the ages of 20-39”. The data notification system may translate the abstract request to conform with a corresponding backend database that stores the health data for the people. Doing so allows the data notification system to be agnostic to any particular backend database, allows the backend database to be changed as needed, and does not require the backend database schema to be disclosed to clients.
Responsive to the request, the data notification system may further provision a “topic” for the requested group of people in a notification platform. When updates are made to the health data of one member of the group, the data notification system determines which topics should receive an indication of the update. The data notification system provides an indication of the update to each topic in the notification platform, which retains the information in order for each topic. A client application may then authenticate using a secure key, and receive the indication of the data updates from the notification platform. The client application may use the received information to generate a query to a location where the updated data is stored. The client application may then issue the query, and receive the updated data from the storage location.
When the data update 104 occurs, the data store 101 may be modified any number of times to reflect the data update 104. However, the client application 103 must be made aware of the data update 104. Advantageously, an indication of the data update 104 is provided to the notification service 102. The notification service 102 includes a streaming platform 105, which allows publishers to publish streams of records (e.g., data updates), and allows subscribers (e.g., the client application 103) to consume the streams of records. One example of a streaming platform is Kafka® by Apache®. The subscriber (e.g., a client application 103) may specify an abstract request to receive notifications for updates to the data store 101. The abstract request may specify a group of people to monitor, e.g., “female non-smokers between the ages of 40-50”. When data in the data store 101 is updated for the specified group of people, an indication of each update is stored in order (based on a respective timestamp) in a “topic” in the streaming platform 105 (e.g., a topic allocated to the requested female non-smokers between the ages of 40-50). The notification service 102 and/or the streaming platform 105 may then transmit an indication to the client application 103 that an update is available. The client application 103 may authenticate with the streaming platform 105 using a secure key. The streaming platform 105 may then transmit, for each notification, information that allows the client application 103 to build a query to access the updated data in the data store 101. For example, the information may include a tenant identifier, a table identifier, and a patient identifier. The client application 103 may then generate a query targeting the data store 101, which, when processed, returns the requested data to the client application 103.
The data persistence server 120 may also generate one or more topics 108 in the streaming platform 105 based on the request received from the management API 133 of the client application 103. An indication of each topic 108 is also stored in the subscription data 122. The indication of the topic 108 in the subscription data 122 may be associated with the key 107, an indication of any targeted tables in the data store 101, any conditions (e.g., people between the ages of 10 and 20), and any filtering rules (e.g., do not trigger a notification 116 until a “patient discharge” is stored in a specific location of the data store 101).
As shown, the streaming platform 106 includes one or more web servers 106, which communicate with other applications (e.g., the client application 103) using the hypertext transfer protocol (HTTP). The web servers 106 include one or more websocket servers 109, which provides a full-duplex communications channel between the streaming platform 105 and the client application 103. The websocket servers 109 allow the client application 103 to send messages to the streaming platform 105 and receive notifications from the streaming platform 105 without the streaming platform 105 having to poll the streaming platform 105 for a reply.
The web server 106 and/or the websocket server 109 may authenticate the client application 103 based on the corresponding key 107 (e.g., using transport layer security). Once authenticated, the websocket server 109 may determine, from the coordinator 114, which topics 108 the client application 103 is subscribed. The coordinator 114 generally manages the topics 108 and stores indications of which client applications 103 are subscribers to a given topic 108, which are stored by a plurality of compute nodes of a compute cluster 115. Furthermore, a given subscription may apply to different topics 108 (e.g., a topic 108 for males over 70 with heart disease, and a topic 108 for females over 75 with heart disease). Once the websocket server 109 authenticates the client application 103 and determines which topics 108 the client application 103 is subscribed to, the websocket server 109 pushes an indication of each corresponding notification 116 to the client application 103. As previously stated, the notification 116 includes information that allows the client application to generate a query to retrieve the data from the data store 101. For example, the notification 116 may specify the tenant ID, table ID, and patient (or person) ID. The client application 103 may then generate the query, which is transmitted to the query server 121. The query server 121 processes the query against the data store 101, and returns the data to the client application 103 via the data API 133. The client application 103 may then perform further processing on the received data, e.g., by updating healthcare data models based on the received data.
The notification component 113 is configured to generate notifications 116 based on updates to data generated by the processing pipeline 110. The notification component 113 may monitor the processing pipeline 110 for data that is modified, and/or the persistence layer 111 may provide an indication of data modification to the notification component 113. In response to data being updated, the notification component 113 receives the subscription data 122 from the data persistence server 120 to identify any topics 108 in the streaming platform 105 that should receive a notification 116 corresponding to the data update. Continuing with the previous example, the subscription data 122 may specify that a first client application 103 is subscribed to the general pulse topic 108, and a second client application 103 is subscribed to the topic 108 for pulse data of patients with heart disease. The notification component 113 may then generate the notification 116 for each topic 108, encrypt the notifications 116 based on the key 107 for each topic 108, and transmit the encrypted notifications 116 to the streaming platform 105, where the notifications 116 are stored in the topics 108. As previously stated, the notifications 116 are stored in the topics 108 in order based on the time of each data update, which may be specified as a timestamp in each notification 116. The streaming platform 105 then allows the client applications 103 to consume the notifications 116 as described above. If, for example, the client application 103 consumes 10 of 20 notifications 116, when the client application 103 sends a request to consume additional notifications 116, the websocket server 109 begins transmission of the 11th notification, and holds all notifications 116 until each notification 116 is consumed by the client application 103.
In at least one embodiment, the notification component 113 computes a score for one or more data updates before generating a notification 116. If the computed score exceeds a corresponding threshold, the notification component 113 generates the notification 116. For example, if a data update specifies that a patient has scheduled a same-day appointment with a physician, the notification component 113 may compute a score that does not exceed a threshold. However, once the visit is completed, the notification component 113 may compute a score that exceeds the threshold, and the notification 116 is generated. The score may be computed based on a function that considers predefined weights for each of a plurality of different events that may cause data updates (e.g., a first weight for scheduling an appointment, a second weight for attending the appointment, a third weight for a test performed during the appointment, etc.).
The client application 103 may invoke the data API 134 to receive the notifications 116 via the streaming platform 105. The data API 134 and the streaming platform 105 may implement TLS authentication using the key 107 of the client application 107. Once authenticated, the websocket server 109 transmits the notifications 116 to the client application 107. As previously stated, the notification component 113 generates notifications 116 that include enough information to allow a client application 103 to generate a query to access the data from the data store 101.
At block 330, described in greater detail with reference to
At block 430, the data persistence server 120 determines whether the request specifies one or more filtering rules. The filtering rules may specify conditions for generating notifications 116. For example, a filtering rule may specify to generate a notification 116 only when a specific type of message is received for a particular patient. As such, the notification component 113 may generate the notification 116 only when this type of message is received in the processing pipeline 110. Similarly, the filtering rules may specify notification timing (e.g., hold all notifications for delivery on an hourly, daily, or weekly basis). Further still, the filtering rules may specify thresholds for any scores generated by the notification component 113 in determining whether to generate a notification 116. At block 440, the data persistence server 120 stores each parameter associated with the subscription in the subscription data 122. At block 450, the streaming platform 105 generates one or more topics 108 for the subscription in the streaming platform 105. At block 460, the streaming platform 105 provides an indication (e.g., an identifier) of the topics 108 created at block 450 to the client application 103. Doing so allows the client application 103 to subsequently request notifications 116 for one, several, or all topics 108 that the client application 108 is subscribed to.
At block 540, the notification component 113 generates and transmits a notification 116 for each topic 108 identified at block 530. At block 550, the notifications 116 are received by the streaming platform 105 and stored in the associated topics 108. At block 560, the streaming platform 105 receives a request from the client application 103 to receive notifications 116 for the subscribed topics 108. The streaming platform 105 may authenticate the client application 103 using TLS authentication based on the security key 107 of the client application 103. At block 570, the websocket server 109 transmits notifications 108 for each subscribed topic 108 to the client application 103. As previously stated, the notifications 116 include enough information that allows the client application 103 to generate a query to access the data in the data store 101. At block 580, the client application 103 generates one or more queries specifying to access the data in the data store 101 based on the received notifications 116. The data persistence server 120 may authenticate the client application 103 using TLS authentication based on the security key 107 of the client application 103. At block 590, the query server 121 processes the queries and returns the data from the data store 101 to the client application 103.
The computer 602 generally includes a processor 604 which obtains instructions and data via a bus 620 from a memory 606 and/or a storage 608. The computer 602 may also include one or more network interface devices 618, input devices 622, and output devices 624 connected to the bus 620. The computer 602 is generally under the control of an operating system (not shown). Examples of operating systems include the UNIX operating system, versions of the Microsoft Windows operating system, and distributions of the Linux operating system. (UNIX is a registered trademark of The Open Group in the United States and other countries. Microsoft and Windows are trademarks of Microsoft Corporation in the United States, other countries, or both. Linux is a registered trademark of Linus Torvalds in the United States, other countries, or both.) More generally, any operating system supporting the functions disclosed herein may be used. The processor 604 is a programmable logic device that performs instruction, logic, and mathematical processing, and may be representative of one or more CPUs. The network interface device 618 may be any type of network communications device allowing the computer 602 to communicate with other computers via the network 630.
The storage 608 is representative of hard-disk drives, solid state drives, flash memory devices, optical media and the like. Generally, the storage 608 stores application programs and data for use by the computer 602. In addition, the memory 606 and the storage 608 may be considered to include memory physically located elsewhere; for example, on another computer coupled to the computer 602 via the bus 620.
The input device 622 may be any device for providing input to the computing system 602. For example, a keyboard and/or a mouse may be used. The input device 622 represents a wide variety of input devices, including keyboards, mice, controllers, and so on. Furthermore, the input device 622 may include a set of buttons, switches or other physical device mechanisms for controlling the computer 602. The output device 624 may include output devices such as monitors, touch screen displays, and so on.
As shown, the memory 606 contains the, streaming platform 105, processing pipeline 110, and the data persistence server 120, each described in greater detail above. As shown, the storage 608 contains the data reservoir 101, described in greater detail above. Generally, the system 100, including the computer 602, is configured to implement all systems, methods, and functionality described above with reference to
The descriptions of the various embodiments of the present invention have been presented for purposes of illustration, but are not intended to be exhaustive or limited to the embodiments disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the described embodiments. The terminology used herein was chosen to best explain the principles of the embodiments, the practical application or technical improvement over technologies found in the marketplace, or to enable others of ordinary skill in the art to understand the embodiments disclosed herein.
In the foregoing, reference is made to embodiments presented in this disclosure. However, the scope of the present disclosure is not limited to specific described embodiments. Instead, any combination of the recited features and elements, whether related to different embodiments or not, is contemplated to implement and practice contemplated embodiments. Furthermore, although embodiments disclosed herein may achieve advantages over other possible solutions or over the prior art, whether or not a particular advantage is achieved by a given embodiment is not limiting of the scope of the present disclosure. Thus, the recited aspects, features, embodiments and advantages are merely illustrative and are not considered elements or limitations of the appended claims except where explicitly recited in a claim(s). Likewise, reference to “the invention” shall not be construed as a generalization of any inventive subject matter disclosed herein and shall not be considered to be an element or limitation of the appended claims except where explicitly recited in a claim(s).
Aspects of the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, microcode, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.”
The present invention may be a system, a method, and/or a computer program product. The computer program product may include a computer readable storage medium (or media) having computer readable program instructions thereon for causing a processor to carry out aspects of the present invention.
The computer readable storage medium can be a tangible device that can retain and store instructions for use by an instruction execution device. The computer readable storage medium may be, for example, but is not limited to, an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any suitable combination of the foregoing. A non-exhaustive list of more specific examples of the computer readable storage medium includes the following: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), a static random access memory (SRAM), a portable compact disc read-only memory (CD-ROM), a digital versatile disk (DVD), a memory stick, a floppy disk, a mechanically encoded device such as punch-cards or raised structures in a groove having instructions recorded thereon, and any suitable combination of the foregoing. A computer readable storage medium, as used herein, is not to be construed as being transitory signals per se, such as radio waves or other freely propagating electromagnetic waves, electromagnetic waves propagating through a waveguide or other transmission media (e.g., light pulses passing through a fiber-optic cable), or electrical signals transmitted through a wire.
Computer readable program instructions described herein can be downloaded to respective computing/processing devices from a computer readable storage medium or to an external computer or external storage device via a network, for example, the Internet, a local area network, a wide area network and/or a wireless network. The network may comprise copper transmission cables, optical transmission fibers, wireless transmission, routers, firewalls, switches, gateway computers and/or edge servers. A network adapter card or network interface in each computing/processing device receives computer readable program instructions from the network and forwards the computer readable program instructions for storage in a computer readable storage medium within the respective computing/processing device.
Computer readable program instructions for carrying out operations of the present invention may be assembler instructions, instruction-set-architecture (ISA) instructions, machine instructions, machine dependent instructions, microcode, firmware instructions, state-setting data, or either source code or object code written in any combination of one or more programming languages, including an object oriented programming language such as Smalltalk, C++ or the like, and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The computer readable program instructions may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider). In some embodiments, electronic circuitry including, for example, programmable logic circuitry, field-programmable gate arrays (FPGA), or programmable logic arrays (PLA) may execute the computer readable program instructions by utilizing state information of the computer readable program instructions to personalize the electronic circuitry, in order to perform aspects of the present invention.
Aspects of the present invention are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems), and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer readable program instructions.
These computer readable program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer readable program instructions may also be stored in a computer readable storage medium that can direct a computer, a programmable data processing apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having instructions stored therein comprises an article of manufacture including instructions which implement aspects of the function/act specified in the flowchart and/or block diagram block or blocks.
The computer readable program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other device to cause a series of operational steps to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process, such that the instructions which execute on the computer, other programmable apparatus, or other device implement the functions/acts specified in the flowchart and/or block diagram block or blocks.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods, and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of instructions, which comprises one or more executable instructions for implementing the specified logical function(s). In some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts or carry out combinations of special purpose hardware and computer instructions.
Embodiments of the invention may be provided to end users through a cloud computing infrastructure. Cloud computing generally refers to the provision of scalable computing resources as a service over a network. More formally, cloud computing may be defined as a computing capability that provides an abstraction between the computing resource and its underlying technical architecture (e.g., servers, storage, networks), enabling convenient, on-demand network access to a shared pool of configurable computing resources that can be rapidly provisioned and released with minimal management effort or service provider interaction. Thus, cloud computing allows a user to access virtual computing resources (e.g., storage, data, applications, and even complete virtualized computing systems) in “the cloud,” without regard for the underlying physical systems (or locations of those systems) used to provide the computing resources.
Typically, cloud computing resources are provided to a user on a pay-per-use basis, where users are charged only for the computing resources actually used (e.g. an amount of storage space consumed by a user or a number of virtualized systems instantiated by the user). A user can access any of the resources that reside in the cloud at any time, and from anywhere across the Internet. In context of the present invention, a user may access applications or related data available in the cloud. For example, the notification component 113 could execute on a computing system in the cloud and generate notifications 116. In such a case, the streaming platform 105 may store the generated notifications 116 at a storage location in the cloud. Doing so allows a user to access this information from any computing system attached to a network connected to the cloud (e.g., the Internet).
While the foregoing is directed to embodiments of the present invention, other and further embodiments of the invention may be devised without departing from the basic scope thereof, and the scope thereof is determined by the claims that follow. cm What is claimed is: