This invention relates generally to a business process automation system and method and more specifically to providing presence driven notification to a subscriber when a business process automation chain requires manual intervention.
Business Process Execution Language (BPEL) is a workflow description language that addresses the need to sequence a series of web service calls to create composite web services. BPEL allows the use of basic rules and data manipulation to support this and is effective at what it does. However, business processes commonly involve people. BPEL was designed for system-to-system interactions, not interactions that involve human beings. Accordingly, it doesn't define mechanisms focused on interacting with people.
In recognition of the fact that BPEL execution chains sometime need humans involved as part of their processing flows, standards activity has been focused on extensions such as BPEL4People and the Task Execution Language (TEL) to cover a broad range of scenarios that involves people within business processes. However, involving humans in these critical business processes poses some real issues with respect to how these tasks can be handled in real life scenarios. There exists a specific need for modifications to the current state of the art for better integration of humans into business process automation chains.
In one embodiment, there is a method for providing presence driven notification to a subscriber that human interaction is needed in a business automation process chain. In this embodiment, the method comprises monitoring for and receiving a notification communication from the BPEL infrastructure via a Web Services Gateway when an executing BPEL document reaches a stage for executing a service that needs human intervention, performing a presence lookup and location platform lookup, making a routing decision based on the lookups and transmitting a message to a messaging gateway framework that delivers the message to the subscriber, and generating the necessary charging records.
In a second embodiment, there is a computer system for providing presence driven notification to a subscriber that human interaction is needed in a business automation process chain. In this embodiment, the system comprises at least one processing unit and memory operably associated with the at least one processing unit. A notification tool is storable in memory and executable by the at least one processing unit. The notification tool comprises a monitoring component configured to monitor for and receive a notification communication from the BPEL infrastructure via a Web Services Gateway when an executing BPEL document reaches a stage for executing a service that needs human intervention, a lookup component configured to perform a presence lookup and location platform lookup, a routing component configured to make a routing decision based on the lookups and transmit a message to a messaging gateway framework that delivers the message to the subscriber, and a charging component configured to generate the necessary charging records.
In a third embodiment, there is a computer-readable medium storing computer instructions, which when executed, enables a computer system to provide notification to a subscriber that human interaction is needed in a business automation process chain, the computer instructions comprising: monitoring for and receiving a notification communication from the BPEL infrastructure via a Web Services Gateway when an executing BPEL document reaches a stage for executing a service that needs human intervention, performing a presence lookup and location platform lookup, making a routing decision based on the lookups and transmitting a message to a messaging gateway framework that delivers the message to the subscriber, and generating the necessary charging records.
In a fourth embodiment, there is a method for deploying a notification tool for use in a computer system that provides notification to a subscriber that human interaction is needed in a business automation process chain. In this embodiment, a computer infrastructure is provided and is operable to: monitor for and receive a notification communication from the BPEL infrastructure via a Web Services Gateway when an executing BPEL document reaches a stage for executing a service that needs human intervention, perform a presence lookup and location platform lookup, make a routing decision based on the lookups and transmit a message to a messaging gateway framework that delivers the message to the subscriber, and generate the necessary charging records.
The drawings are not necessarily to scale. The drawings are merely schematic representations, not intended to portray specific parameters of the invention. The drawings are intended to depict only typical embodiments of the invention, and therefore should not be considered as limiting the scope of the invention. In the drawings, like numbering represents like elements.
Embodiments of this invention are directed to providing presence driven notification to a subscriber when an execution flow requires manual intervention. In these embodiments, a notification tool provides this capability. Specifically, a BPEL document deployed inside a BPEL engine executes and a reaches a stage for executing a service that needs human intervention. The BPEL infrastructure sends a notification communication to the notification tool via a Web Services Gateway. The notification tool receives the notification communication and performs lookups to garner presence, location, and preference information relating to the subscriber. A routing decision is made based on the data received from the lookups and a message is sent to the subscriber. The subscriber performs the task and control is handed back to the BPEL execution chain.
Notification tool 122 also gathers subscriber location and preferences information via location platform 124. Location platform 124 serves as an application gateway in providing location-based services to determine subscriber location. Location platform 124 is also configured to read data from home subscriber server database (HSS DB) 127 via home subscriber server (HSS) 126 relating to subscriber preferences and privacy. Location platform 124 returns location and preferences information to notification tool 122.
Notification tool 122 makes a routing decision based on the information gathered and transmits a message using the selected route via message gateway framework (MGF) 132 to subscriber 134. In an exemplary embodiment, the subscriber role is filled by a person (or persons) capable of performing the task in order to hand back control to the BPEL execution chain. Subscriber 134 may or may not actually pay a fee for the notification service, but is considered a subscriber of the notification service for illustrative purposes. Notification tool 122 also transmits charging information to IP multimedia subsystem charging collector facility (IMS CCF) 130, described in more detail below.
Implementation 100 is intended to represent any type of system that may be implemented in deploying/realizing the teachings recited herein. In this particular example, implementation 100 represents an illustrative system for providing presence driven notification to a subscriber. The components shown in
HSS DB 127 houses subscriber preferences information. It may also include a list of subscriber devices and phone numbers. Subscriber preferences may include the device order to be used when attempting to deliver a message to subscriber. Subscriber may also list which device he prefers, depending on his location. For example, if he is away from home, he may specify to contact him via his cell phone or pager. Subscriber preferences may also include whether subscriber wishes to receive only a notification message or would like to receive task information along with notification.
Those skilled in the art will recognize that databases may contain additional information if desired. Databases may be consolidated into a single database or table, divided into multiple database or tables, or clustered into a database system spanning multiple physical and logical devices. Further, although the above information is shown in
Routing component 148 analyzes the information gathered relating to subscriber presence, preferences, and location. Based on the analysis, routing component 148 is configured to make a decision of the best route available to transmit a message to subscriber 134. After making the decision, routing component 148 transmits a message to subscriber 134 via MGF 132. MGF 132 is a software gateway that provides routing and message conversion services and is described in more detail below.
As shown in
The message may be sent using multimedia service center (MMSC) 160 via MM7. MM7 is the interface between MMSC and a value-added service provider. Another option is to send the message using Short Message Service Center (SMSC) 162 via short message peer-to-peer protocol (SMPP). SMPP is a telecommunications industry protocol for exchanging short message service (SMS) messages. Another option is to use a Wireless Application Protocol (WAP) Push 164 via PAP. A WAP Push is an SMS message which contains a link to a WAP page. When a compatible handset receives a WAP Push message, it allows the user to access that WAP content. Another option is to utilize Voice Mail Engine 166 via Signaling System 7 (SS7). SS7 is a set of telephone signaling protocols. Still another option is to use IM Gateway 168 via an Extensible Messaging and Presence Protocol (XMPP). XMPP is an open technology for real-time communication. Finally, another option is to use Direct Push 170 using SIP. Direct Push 170 provides a wireless email solution.
Subscriber 134 receives the notification message, performs the task, and control is handed back to the BPEL execution chain. Charging component 150 is configured to send charging information to IMS CCF 130. IMS is an architectural framework for delivering internet protocol (IP) multimedia services. IMS includes a definition of the interfaces an application service must use for charging. In the case of offline charging, applied for users who pay for their services periodically, all the SIP network entities involved in the session use the Diameter Rf (protocol) interface to send charging information to a CCF. The CCF is responsible for the IMS domain, carrying the charging information from network nodes to the rating and billing system (not shown).
In one implementation of the present invention, presence driven notification is depicted in
However, if there is an issue with the credit rating, manual intervention is required to determine how to proceed. In this example, subscriber 134, a loan specialist in charge of responding to such issues, is not at his desk and the company requires quick turnaround time in the loan process. Referring back to
Location component 144 does a location platform 124 lookup to ascertain subscriber location. The lookup finds that subscriber 134 is at his home. Presence component 146 does a presence lookup on presence server 128 to determine the channels of communication that are available. The presence lookup yields two important pieces of information: (1) his land line phone at his home is turned on and is not busy on a voice call and (2) his mobile phone is on but is on a data session.
Based on information gathered, routing component 148 determines the best option is to route the message to his home land line via MGF 132. The message is delivered to subscriber 134. Subscriber 134 receives the notification including task information and responds to the loan process issue and control is handed back to the BPEL execution chain.
In one embodiment, notification tool 122 includes charging component 150 that generates the necessary charging records using IMS CCF 130 (
In still another embodiment, the methodologies disclosed herein can be used within a computer system to provide presence driven notification to a subscriber. In this case, notification tool 122 can be provided, and one or more systems for performing the processes described in the invention can be obtained and deployed to a computer infrastructure. To this extent, the deployment can comprise one or more of (1) installing program code on a computing device, such as a computer system, from a computer-readable medium; (2) adding one or more computing devices to the infrastructure; and (3) incorporating and/or modifying one or more existing systems of the infrastructure to enable the infrastructure to perform the process actions of the invention.
The flowchart of
An implementation of notification tool 122 may be stored on or transmitted across some form of computer readable media. Computer readable media can be any available media that can be accessed by a computer. By way of example, and not limitation, computer readable media may comprise “computer storage media” and “communications media.”
“Computer storage media” include volatile and non-volatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules, or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by a computer.
“Communication media” typically embodies computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as carrier wave or other transport mechanism. Communication media also includes any information delivery media.
The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared, and other wireless media. Combinations of any of the above are also included within the scope of computer readable media.
In another embodiment, the invention provides a business method that performs the process of the invention on a subscription, advertising, and/or fee basis. That is, a service provider, such as a Solution Integrator, could offer to provide the functionality described herein. In this case, the service provider can create, maintain, support, etc., a notification mechanism, such as notification tool 122 (
In still another embodiment, the invention provides a computer-implemented method for performing the functionality described herein. In this case, a notification mechanism, such as notification tool 122 (
As used herein, it is understood that the terms “program code” and “computer program code” are synonymous and mean any expression, in any language, code or notation, of a set of instructions intended to cause a computing device having an information processing capability to perform a particular function either directly or after either or both of the following: (a) conversion to another language, code or notation; and/or (b) reproduction in a different material form. To this extent, program code can be embodied as one or more of: an application/software program, component software/a library of functions, an operating system, a basic device system/driver for a particular computing and/or device, and the like.
A data processing system suitable for storing and/or executing program code can be provided hereunder and can include at least one processor communicatively coupled, directly or indirectly, to memory elements through a system bus. The memory elements can include, but are not limited to, local memory employed during actual execution of the program code, bulk storage, and cache memories that provide temporary storage of at least some program code in order to reduce the number of times code must be retrieved from bulk storage during execution. Input/output or device devices (including, but not limited to, keyboards, displays, pointing devices, etc.) can be coupled to the system either directly or through intervening device controllers.
It is apparent that there has been provided with this invention an approach for providing presence driven notification to a subscriber. While the invention has been particularly shown and described in conjunction with a preferred embodiment thereof, it will be appreciated that variations and modifications will occur to those skilled in the art. Therefore, it is to be understood that the appended claims are intended to cover all such modifications and changes as fall within the true spirit of the invention.