A system and method for immediate and delayed real-time communication activities using availability data from and communications through an external instant messaging system, that operates to obtain aggregated user online presence information through its own client software, through interception of client-server communications between an external instant messaging client and server, and through other available interfaces to user account information on such external instant messaging systems. The system operates to gather user online presence information in part by intercepting communications between an instant messaging client and the Internet. The aggregate presence data, as well as other information describing the availability of a user, is used to intelligently route real-time communications, such as instant messages and phone calls. The disclosed system further implements a technique for waiting for changes in a user's availability status, and for performing actions on a user's behalf in response to such changes in availability status.
|
0. 31. A non-transitory computer-readable medium having stored thereon computer executable instructions that, in response to execution by a computing device, perform operations comprising:
intercepting input and output data from at least one network socket data stream associated with a software process executing on a processor of said computing device,
determining that said intercepted input and output data does not contain on-line presence information regarding a user,
injecting a request message into said at least one network socket data stream to request on-line presence information regarding said user from said software process, and receiving said on-line presence information in response to said request message; and
transmitting said on-line presence information regarding said user to an external real-time messaging server via a network based on at least one of said intercepting or receiving of said on-line presence information.
0. 22. A method of supporting real-time communication activities, comprising the steps of:
intercepting, via a first software process executing on a first processor of a first computer, input and output data from at least one network socket data stream associated with a second software process executing on a second processor of said first computer,
determining, via said first software process executing on said first processor of said first computer, that said intercepted input and output data does not contain on-line presence information regarding a user;
injecting, via said first software process executing on said first processor of said first computer, a request message into said at least one network socket data stream associated with said second software process to request on-line presence information regarding said user from said second software process, and receiving said on-line presence information regarding said user in response to said request message;
transmitting, via said first software process executing on said first processor of said first computer, said on-line presence information regarding said user to an external real-time messaging server based on at least one of said intercepting or receiving of said on-line presence information.
19. A method of supporting real-time communication activities, comprising the steps of:
in a first obtaining step, obtaining on-line presence information from an external instant messaging system regarding at least one user, wherein said first obtaining step includes intercepting, within a client system, input and output data from at least one network socket data stream associated with an instant messaging client software process executing on said client system, wherein said input and output data comprise data communicated between said client software process and a remote instant messaging server;
determining whether said intercepted input and output data contain said on-line presence information;
in the event said intercepted input and output data contain said on-line presence information, extracting said on-line presence information from said input and output data;
in a second obtaining step, in the event said intercepted input and output data does not contain said on-line presence information, injecting a request message into said at least one network socket data stream associated with said software process to request said on-line presence information from said external instant messaging system, and receiving said on-line presence information in response to said request message; and
performing, external to said instant messaging client and said instant messaging server, a predetermined function responsive to said on-line presence information obtained in one of said first and second obtaining steps.
0. 25. A method of supporting real-time communication activities, comprising the steps of:
in a first obtaining step, obtaining on-line presence information from an external instant messaging system regarding a user, wherein said first obtaining step includes intercepting, within a client system, input and output data from at least one network socket data stream associated with an instant messaging client software process executing on said client system, wherein said input and output data comprise data communicated between said client software process and a remote instant messaging server;
determining whether said intercepted input and output data contain said on-line presence information;
in the event said intercepted input and output data contain said on-line presence information, extracting said on-line presence information from said input and output data;
in a second obtaining step, in the event said intercepted input and output data does not contain said on-line presence information, injecting a request message into said at least one network socket data stream associated with said software process to request said on-line presence information from said external instant messaging system, and receiving said on-line presence information in response to said request message; and
transmitting, based on at least one of said first obtaining step or said second obtaining step, said on-line presence information obtained in one of said first and second obtaining steps to a messaging server external to said instant messaging client and said instant messaging server.
0. 28. A system for supporting real-time communication activities, comprising: at least one processor; and
a computer program storage memory communicably coupled with said at least one processor, said computer storage memory including at least one computer program executable on said at least one processor, said computer program including:
first program code, executable by said at least one processor, for obtaining on-line presence information regarding a user from an external instant messaging system, wherein said first program code for obtaining includes program code for intercepting input and output data from at least one network socket data stream associated with a second software process,
second program code, executable by said at least one processor, for determining whether said intercepted input and output data contain said on-line presence information regarding said user;
third program code, executable by said at least one processor, for obtaining online presence information, including program code for, in the event said intercepted input and output data does not contain said on-line presence information regarding said user, injecting a request message into said at least one network socket data stream associated with said software process to request said on-line presence information from said external instant messaging system, and receiving said on-line presence information regarding said user in response to said request message; and
fourth program code, executable by said at least one processor, for transmitting said on-line presence information obtained from said external instant messaging system to an external messaging server in response to said execution, on said at least one processor, of one of said first and third program code for obtaining on-line presence information regarding said user.
1. A method of supporting real-time communication activities, comprising the steps of:
in a first obtaining step, obtaining on-line presence information from an external instant messaging system regarding at least one user, wherein said first obtaining step includes intercepting input and output data from at least one network socket data stream associated with a software process,
said software process being associated with said external instant messaging system and identifying on-line presence information regarding said at least one user within said input and output data associated with said software process, wherein said software process associated with said external instant messaging system comprises a client software process associated with said external instant messaging system, and wherein said input and output data associated with said software process comprise data communicated between said client software process associated with said external instant messaging system and a server associated with said external instant messaging system;
determining whether said intercepted input and output data contain said on-line presence information;
in a second obtaining step, in the event said intercepted input and output data does not contain said on-line presence information, injecting a request message into said at least one network socket data stream associated with said software process to request said on-line presence information from said external instant messaging system, and receiving said on-line presence information in response to said request message;
determining an availability status of said at least one user responsive to said on-line presence information obtained from said external instant messaging system in one of said first and second obtaining steps; and
establishing a real-time communication activity including said at least one user responsive to said availability status of said at least one user.
18. A system for supporting real-time communication activities, comprising:
at least one processor; and
a computer program storage memory communicably coupled with said at least one processor, said computer storage memory including at least one computer program executable on said at least one processor, said computer program including:
first program code for obtaining on-line presence information from an external instant messaging system regarding at least one user, wherein said first program code for obtaining includes program code for intercepting input and output data from at least one network socket data stream associated with a software process,
said software process being associated with said external instant messaging system and identifying on-line presence information regarding said at least one user within said input and output data associated with said software process, wherein said software process associated with said external instant messaging system comprises a client software process associated with said external instant messaging system, and wherein said input and output data associated with said software process comprise data communicated between said client software process associated with said external instant messaging system and a server associated with said external instant messaging system;
program code for determining whether said intercepted input and output data contain said on-line presence information;
second program code for obtaining on-line presence information, including program code for, in the event said intercepted input and output data does not contain said on-line presence information, injecting a request message into said at least one network socket data stream associated with said software process to request said on-line presence information from said external instant messaging system, and receiving said on-line presence information in response to said request message;
program code for determining an availability status of said at least one user responsive to said on-line presence information obtained from said external instant messaging system in response to the execution, on said at least one processor, of one of said first and second program code for obtaining on-line presence information; and
program code for establishing a real-time communication activity including said at least one user responsive to said availability status of said at least one user.
2. The method of
determining that said software process has begun execution; and
determining that said software process is associated with said external instant messaging system.
3. The method of
4. The method of
5. The method of
6. The method of
7. The method of
8. The method of
9. The method of
10. The method of
11. The method of
12. The method of
13. The method of
14. The method of
15. The method of
16. The method of
determining that at least one necessary participant for said real-time communication activity is not available; and
generating a script to be executed in response to receipt of an event notification indicating that said at least one participant becomes available.
17. The method of
parsing said input and output data intercepted from said at least one network socket data stream for said on-line presence information describing the online presence state of said at least one user.
20. The method of
21. The method of
0. 23. The method of claim 22, further comprising:
receiving an instant message from said external real-time messaging server including a selectable link operable to connect said user associated with said second software process to a real-time communication activity; and
injecting said instant message into said at least one network socket data stream.
0. 24. The method of claim 22, further comprising:
determining, via said first software process, that said second software process has begun execution; and
determining, via said first software process, that said second software process is associated with an instant messaging system.
0. 26. The method of claim 25, further comprising:
receiving an instant message from said external real-time messaging server including a selectable link operable to connect said user associated with said second software process to a real-time communication activity; and
injecting said instant message into said at least one network socket data stream.
0. 27. The method of claim 25, further comprising:
determining that said instant messaging client software process has begun execution; and determining that said instant messaging client software process is associated with said external instant messaging system.
0. 29. The system of claim 28, said computer program further comprising:
fifth program code, executable by said at least one processor, for receiving an instant message from said external messaging server including a selectable link operable to connect said user associated with said computer program to a real-time communication activity; and injecting said instant message into said at least one network socket data stream.
0. 30. The system of claim 28, further comprising:
sixth program code, executable by said at least one processor, for determining that said second software process has begun execution, and for determining that said second software process is associated with said external instant messaging system.
0. 32. The computer-readable medium of claim 31, further comprising computer executable instructions that, in response to execution by a computing device, perform operations comprising:
receiving an instant message from said external real-time messaging server including a selectable link operable to connect said user associated with said software process to a real-time communication activity; and
injecting said instant message into said at least one network socket data stream.
0. 33. The computer-readable medium of claim 31, further comprising computer executable instructions that, in response to execution by a computing device, perform operations comprising:
determining that said second software process has begun execution and determining that said second software process is associated with an external instant messaging system.
|
This application is a Continuation in Part of prior application Ser. No. 10/367,640, entitled “System and Method for Immediate and Delayed Real-Time Communication Activities using Availability Data from and Communications through an External Instant Messaging System”, of Charles J. Digate et al., filed Feb. 14, 2003.
Not Applicable
The present invention relates generally to real-time communication activities, and, more specifically, to a system and method for providing immediate and delayed real-time communication activities based on user availability, as determined from and/or in cooperation with one or more external instant messaging systems.
As it is generally known, and despite all previous attempts to fully automate business processes, there remains a large class of problems that require human expertise and action, often through some form of real-time interaction. Since relevant information to solve a given problem is often stored in the minds of specific individuals, successful problem solving often entails identifying that person whose expertise enables them to deal with the problem, and initiating contact with that person via a real-time communication technique, such as through instant messaging software, the telephone system, and/or online or face-to-face meetings. This process may require effectively choosing among multiple people and multiple means of contacting those people. For a programmed computer system to assist in this process, it must have some way of assessing whether a given person is currently reachable by one of a number of appropriate communication channels, and whether the person is currently available for the desired action.
In existing instant messaging systems, one increasingly important mechanism for assessing a person's current, on-line presence is the state of that person's instant messaging account. Public instant messaging services such as AOL®, MSN®, and Yahoo® are known to maintain information on their users, such as whether they are currently logged in, and whether they have been typing at their keyboard recently. Such existing systems further allow a user to explicitly set presence states to indicate that they are away from the computer or do not wish to be disturbed.
While industry groups are working to establish standards for interoperability among instant messaging systems, existing public systems currently do not support such a standard. Accordingly, it may be difficult to obtain presence information through existing instant messaging systems. This problem is exacerbated by the fact that some existing systems present different information to different users (e.g. one user may specify that his or her online presence is only to be shared with specified users).
Existing systems have further shortcomings in the area of real-time communications. These shortcomings include the lack of a simple, data-driven mechanism for users to effectively specify how a desired real-time communication should be provided. Existing systems fail to provide a mechanism by which a user can conveniently and comprehensively define contact information, as well as delegated stand-ins for that user, where such stand-ins may be considered as alternative contacts, or automatically contacted in the event that the user is determined to be currently unavailable. Additionally, existing systems do not provide a mechanism for organizations to configure a real-time communication system to meet more sophisticated, business specific requirements.
Accordingly, it would be desirable to have a system that provides a simple, data-driven mechanism for users to control how various real-time communication operations are provided, such as by indicating or providing contact information and names of delegated stand-ins through a graphical user interface. Such a system should also provide a mechanism for organizations to define complex rules that fit their specific business processes.
Additionally, it would be desirable to have a system that includes support for communication requests that span extended time periods. For example, the system should support an operation in which a sender issues a request that a real-time communication take place when a chosen recipient becomes available, and in which the system waits for the availability of the recipient for hours, days, or weeks. Moreover, the system should be able to efficiently support this service for large numbers of users, by efficiently providing a way for information about real-time communication requests to be stored and retrieved, and also avoid the use of a separate process running in a server system for each such request.
In accordance with the present invention, there is disclosed a system and method for supporting immediate and delayed real-time communication activities using availability data from and communications through one or more external instant messaging systems. The disclosed system operates to obtain aggregated user online presence information through its own client software, through interception of client-server communications between an external instant messaging client and server, and through other available interfaces to user account information on such external instant messaging systems. As described herein, availability data or status of a user reflects what is generally referred to as the online presence of that user.
In one embodiment, the disclosed system operates to detect a client software process of an external instant messaging system, and then to obtain user online presence information in part by intercepting communications between the external instant messaging client and the Internet. Further in this embodiment, the disclosed system may operate to introduce one or more messages into the information flow between the external instant messaging client and the internet, and/or perform other operations provided through the external instant messaging system. The disclosed system may then operate using aggregated user presence data, as well as other information describing the availability of one or more users, to intelligently route real-time communications, such as instant messages and phone calls. The disclosed system further implements a technique for waiting for changes in a user's availability status, and for performing actions on a user's behalf in response to such changes in availability status.
Thus there is disclosed herein a system and method that provides a simple, data-driven mechanism for users to specify how various real-time communication operations are provided. The disclosed system enables users to indicate or provide contact information and names of delegated stand-ins through a graphical user interface, and provides a mechanism for organizations to define complex rules that fit their specific business processes. The disclosed system further supports requests for communication operations that are not immediately deliverable, due to the unavailability of certain participant users. Such requests may span multiple days. For example, the disclosed system supports operations in which a sender issues a request that a telephone conversation take place when a chosen recipient becomes available, and in which the system waits for the availability of the recipient for hours, days, or weeks. Moreover, the disclosed system efficiently supports this service for large numbers of users, by efficiently providing a way for the information about real-time communication requests to be stored and retrieved, without the use of a separate process running in a server system for each such request. Advantageously, the disclosed system provides effective access to features and information of external instant messaging systems, such as presence information, contact lists such as buddy lists, and/or messaging services.
By intercepting communications between a client and server of an external instant messaging system, the disclosed system operates without requiring costly modification, duplication, or replacement of the client software of the external instant messaging system. As the disclosed system runs on the client, it does not require the use of an intermediate “proxy” server with the associated costs, latency, and necessity of configuring the client to communicate with the proxy. Moreover, the disclosed system leverages the existing authentication provided in the communications between the client and server of the external messaging system. Since the client software of the external instant messaging system obtains presence information from the external instant messaging system that may be based on the identity of the user of the client system, the intercepted presence information obtained by the disclosed system is correct for that user.
While the disclosed system is described herein with reference to various embodiments and examples of operation in which convening a meeting is used as an example of a real-time activity or action, the real-time activities or actions provided by or in connection with the disclosed system are not limited to meetings between users, and may additionally or alternatively include chat sessions, shared whiteboards, remote presentations, audio conferences, video conferences, and/or any combination of these or other forms of communication between users.
Other features, aspects and advantages of the presently disclosed system and method will be apparent from the detailed description of the invention that follows.
The invention will be more fully understood by reference to the following detailed description of the invention in conjunction with the drawings, of which:
This application is a Continuation in Part of prior application Ser. No. 10/367,640, entitled “System and Method for Immediate and Delayed Real-Time Communication Activities using Availability Data from and Communications through an External Instant Messaging System”, of Charles J. Digate et al., filed Feb. 14, 2003.
As shown in
Each of the server systems 14, 15 and 18, as well as the client systems 12a, 12b and 12c, may be embodied as separate computer systems, each including one or more processors, together with program code memory and one or more secondary program code storage devices, a number of input/output interface devices, and operating system and application program software, as configured for a given operational environment. The communication server 18 includes Web server software including an HTTP (HyperText Transport Protocol) server that manages Web page requests received over the network 20, and that delivers HTML (HyperText Mark-up Language) documents (Web pages) in response. A separate server system including Web server software, coupled to the communication server 18, may alternatively be used for this purpose. The enhanced client systems A 12a and B 12b include client software operable to perform functions associated with the disclosed system in cooperation with the real-time messaging server 14. The non-enhanced client system 12c does not include specialized client software associated with the real-time messaging server 14. Instead, messages and content used to take advantage of features of the disclosed system may be loaded and processed as needed by other software on the non-enhanced client system 12c. The embodiment of the disclosed system shown in
While in the illustrative embodiment of
The communication server 18 in the embodiment of
During operation of the disclosed system, as shown in the embodiment of
The disclosed system provides a number of features relating to the use of groups. First, the disclosed system permits group definitions to be shared among users. Also, temporary membership in a group may be enabled, for example to grant temporary access to data and/or specific functions associated with the group. Further, with regard to determining an appropriate stand-in, the disclosed system may operate to provide data mining for relevant skills assessment, e.g. by identifying one or more user(s) who recently published something on a given topic, or that responded to a message on the topic.
The ephemeral condition data cache 38 includes presence indications for users. Such presence indications reflect the instantaneous availability of system users. Such instantaneous availability information may, for example, be obtained through a subscription model, in which the software on the real-time messaging server subscribes to notifications from specific client systems indicating events relating to the online status of certain users. Such notifications might include event messages indicating when a user logs on or off a client system. Accordingly, the ephemeral condition data cache 38 is used to store information describing previous events. Additionally, users that are registered with the disclosed system, referred to as “subscribing users”, may store information, for example in the persistent database 15, that control how their presence information is provided as availability status to other users. For example, an availability filter may be configured by a user such that the online presence of that user is made known to all users, to some other users, or to no other users. Such availability filtering may be based on the definition of a VIP (“Very Important Person”) list for a user. The user entries in a VIP list store information defining how the availability of that user is made available or visible to other users. Such selective availability may be defined on a user-by-user basis, and/or on a group or global basis, and may further be defined to reflect current conditions or other factors, such as time of day, specific dates, or functional associations. Accordingly, a user may configure his or her VIP list to allow a group of other users to be aware of his or her availability only at certain times of day, and/or on certain days. Additionally, a user may specify how availability is filtered based on activities, topics, or functions. For example, a user may configure his or her account such that a group of other users can only see that user as available only for meetings regarding certain predefined topics.
The persistent database 15 includes configuration data maintained by the disclosed system reflecting user preferences and group definitions. In an embodiment in which users that are “subscribers” may define account information, the database 15 maintains account data for such subscriber users. Subscriber data may include, for example, stand-in definitions, availability filters, and/or contact lists of other subscriber users as well as non-subscriber users. The rules 32 define the actions 40 that are performed in response to the event notifications 36, ephemeral condition data cache 38, and data stored in the persistent database. The rules 32 are processed by the rules engine 30, which may be embodied in any appropriate programming language for a given implementation.
The actions 40 performed by the rules engine 30 may, for example, include actions facilitating any specific kind of real time group activity. Such real time group activities may include the convening of an online meeting or teleconference, sending email or an instant message to one or more users, routing a document, and/or other actions. The actions 40 may be simple or complex, and potentially include multi-stage actions that are performed in several distinct steps, depending on the receipt of several separate event notifications and the state of conditions stored in the ephemeral condition data cache over time.
Additionally, the disclosed system may allow for the members of the meeting group to be defined by designation of a predetermined group or lifeline. Such a predetermined group or lifeline definition may be configured by the user, or made available to specific users, or to all users on a system-wide basis. For example, in a deployment of the disclosed system by a given company, a predefined group might be defined to include the members of a senior management team for the company. Moreover, an individual user within the company may set up or configure his or her own account to include one or more named groups of users that are relevant to that user's day to day activities, such as a “project team” group including all members of that user's current project team.
At step 51, the disclosed system determines the initial members of the participant group. In the case where the request defined at step 50 includes designation of a lifeline, at step 51 the disclosed system applies the selection attribute(s) associated with the lifeline to the lifeline, and determines which specific member of lifeline is to be considered one of the members of the participant group for the request. The determination of which member of the lifeline is to be added to the participant list is potentially further responsive to current availability status of the lifeline members, depending on presence information, attributes of the request, and/or user defined availability filters.
At step 52, the disclosed system determines whether each individual within the participant group is available. The availability of each participant group member may be determined based on user defined availability filtering, and depend on the attributes associated with the request, such as who called a meeting, a meeting topic, and/or whether a participant group member is defined as a necessary attendee for a meeting. The availability of each participant group member is further determined in response to the online presence of each meeting group member, as stored in the real time messaging server.
At step 54, for any participant group members that were determined to be unavailable, the disclosed system operates to determine whether there are any acceptable stand-ins available. For example, if a given participant group member has defined a stand-in to be provided for any meeting called when that meeting group member is unavailable, and that participant group member is in fact unavailable, then the system determines whether the stand-in is currently available. Again, the availability of any stand-in may be determined using the stand-in's availability filter, and depend both on the stand-in's online presence, and/or attributes associated with the request generated at step 50. In some cases, the disclosed system may act to automatically determine alternative participant group members or stand-ins. Alternatively, the requesting user may be given the option of approving any stand-ins before they are substituted into the participant group for the requested action. Additionally, the requesting user may be given the option to designate participant group members as being non-essential to allow a meeting to convene if there is no acceptable stand-in available.
At step 56, the disclosed system substitutes any available, appropriate stand-ins into the participant group. The appropriateness of any potential stand-in identified by the system may be determined by presenting the potential stand-in to the original user that initiated the request. For example, if the caller of the meeting finds the proposed stand-in acceptable, the caller may indicate the appropriateness of the stand-in to the system through the user interface. At step 56 the real time group action is commenced if there are sufficient participant group members available. For example, in the case of a request for a meeting, if there are sufficient members of the requested meeting group available, and all the necessary members of the meeting group are available, including any stand-ins determined at step 56, the disclosed system operates to convene the requested meeting at step 58.
The rules engine 100 is shown interfacing to a data source layer 132 through a number of object definitions 130. The object definitions 130 provide a predetermined interface to data sources such as ephemeral data, events, and one or more persistent databases contained in the data source layer 132. In addition to a relational database provided with the system for storing its own information, the data source layer 132 may also include external sources of data such as a corporate directory.
The rules engine 100 further operates to receive and process presence information and requests 116 from the instant messaging (IM) abstraction 96. The presence information received from the IM abstraction reflects the online status of one or more users with respect to one or more client systems. The requests received from the IM abstraction consist of requests for real time group activities, such as requests to convene meetings and/or send messages between users. As a result of processing the presence information and requests 116 received from the IM abstraction 96, the rules engine 100 issues the actions 114 back through the IM abstraction 96. For example, actions may include any real time group action, such as the convening of an online meeting or teleconference, and/or the passing of messages between users.
The client abstraction 96 is shown including a communication server 98 for communicating with a non-enhanced client system 12c. An enhanced client system 12b, is further shown in
Thus, in the case where a user may be using or associated with client software of the disclosed system, and/or client software of one or more external instant messaging systems, presence information from one or more of those clients associated with or being used by that user may be aggregated prior to application of any user configured availability filtering. Moreover, presence information may reflect use of the disclosed system or external instant messaging client software through various communication mediums, including PDAs (Personal Digital Assistants) and/or telephones, as well as client software running on client computer systems.
In addition, the disclosed system may operate to use all facilities of such “external” instant messaging systems through which user presence or other information may be obtained. For example, the disclosed system may operate to send a meeting invitation to a user through an external instant messaging system. Such an invitation would include a pointer, such as a URL, to a resource such as a Web page on the real-time messaging server. When the receiving user clicks on the URL, they are able to begin participating in the real-time action, in this case an online meeting. The online meeting may be provided as content provided through the Web page indicated by the URL. Such invitations may be sent by the disclosed system to users, including users on non-enhanced client systems, as part of the process for convening an online meeting. In one embodiment, the invitation instant message is transmitted from an enhanced client system to a non-enhanced client system, by operation of the client software of the ,disclosed system introducing the instant message invitation into the communications between the external instant messaging client software, shown as instant messaging client 120 in
The conditions 174 may reflect the receipt of previous event notifications. For example, the conditions 174 may reflect automatically generated or user defined presence information, as well as the availability of various specific devices and/or resources that may be needed to perform an action. The conditions 174 may further reflect data stored in the disclosed system that indicates the contact preferences of a user, or the identity of a participant in a request, where that user might be designated by personal identifier, lifeline membership, location, and/or group membership. The actions 176 performed by the rules engine may include various types of communication activities, such as different types of notifications, including instant messages, e-mail and/or short message service (SMS) messages. The actions 176 performed by the disclosed system further may include convening of an online or other type of meeting, scheduling of a meeting in the future, initiating a call or conference call, routing a message between users, broadcasting a message to some or all users, contacting a stand-in for delegation purposes within a group or as part of a request, leaving a message for user, transferring a thread of control to user, and/or retracting some previously performed action.
Based on the user presence information gathered by the disclosed system, a request for real-time communications can be intelligently routed. For example, in the case where a user (referred to for purposes of explanation as the sender) needs to reach someone to ask a question, the disclosed system enables the convenient performance of the following three operations:
1. Identify a candidate recipient. This may entail looking up an expert on a topic, or a user that is assigned as the “programmer of the day”, for example based on information stored in the database.
2. Select a method to contact that person, such as by sending an instant message to one or more accounts, sending a Short Message to their mobile telephone, or calling them on the telephone at the office or at home.
3. If the desired person is not available, selecting a person who the first identified recipient may have designated as a stand-in to receive communications when they are not available.
The steps above may need to be applied recursively, as part of trying alternative methods to reach a stand-in, such as calling the stand-in of a stand-in.
Those skilled in the art will recognize that the disclosed system may provide a simple, data-driven mechanism for users to specify how the above steps should be performed, such as by filling in a form in a graphical user interface with contact information and names of stand-ins. Moreover, the disclosed system provides a mechanism for organizations to define rules and operations that fit their own specific business processes.
Additionally, the disclosed system supports operations that span multiple days. For example, a sender may issue a request that a conversation take place when a specified recipient becomes available, in which the request indicates that the system should continue to wait for that recipient's availability for hours, days, or weeks. Since the system provides this service to a potentially large number of users, it provides an efficient way for the information about such requests to be stored and retrieved, since it is impractical to keep a process running in a server for each such request.
Example—Meet As Soon As Present (ASAP)
An example of a useful facility that may be provided by the disclosed system is a method of scheduling a meeting when all of the participants are available, referred to here as Meet ASAP. For example, in the case where a sender, A, wants to convene a meeting of three people, himself, B, and C. A selects B and C from his list of contacts and presses a Meet button within the graphical user interface. The system checks the presence of B and C and determines that B is online but C is not, and that a stand-in for C is available. It then gives A three choices:
The disclosed system monitors user presence through multiple instant messaging systems in two ways:
Step 1. When client software for the disclosed system (the “disclosed client”) is installed on a sender's computer, it sets up a process, referred to for purposes of explanation as proc—1, that runs automatically when the operating system, for example Microsoft Windows®, is started. Proc—1 registers with the operating system to receive an event notification whenever a top-level window is created, which is one example of an event that may indicate that a process is starting up on the sender's computer. Alternatively, or in addition, Proc—1 may register to receive other event notifications that may also be indicative of a process starting up. Proc—1 sets up one or more software handlers for these events, such that code belonging to the disclosed client will be run in the new process, referred to for purposes of explanation as proc—2. The software handler code checks to see if proc—2 is part of an external instant messaging system of interest. If so, the software handler code then installs hooks to intercept input and output (I/O) on network sockets associated with proc—2. The intercepted socket I/O is directed to software supplied by the disclosed client and executed in proc—2. The disclosed client software examines the intercepted socket I/O to identify information of predetermined interest, such as presence information being sent from the external instant messaging system. Such intercepted information of predetermined interest is sent from proc—2 to proc—1 which, in turn, sends it to the disclosed real-time messaging server, which monitors and/or maintains such information for use in step 2 below. Alternatively, or in addition, the disclosed client software may operate to inject new requests into the socket I/O stream of proc—2 to request operations of the external instant messaging service, such as requesting the presence state of users indicated by a user's contact list or sending an instant message to another user through the external instant messaging service.
For example, the disclosed system may send an instant message to a user through an external instant messaging service. Such a message may, for example, consist of an HTML document that is an invitation to an online meeting, and where the receiver of the invitation may participate in the online meeting by clicking on a link to the online meeting contained in the invitation. Such a message might be sent only in the case where the person the invitation is being sent to is determined to be currently on-line, for example as determined through presence information intercepted from the external instant messaging system. The disclosed system may also operate to obtain contact lists (sometimes referred to as “buddy lists”) from one or more external instant messaging systems through any suitable mechanism and/or interface provided by such external instant messaging systems.
Step 2. When a sender requests a meeting, the client software for the disclosed system executes a set of rules to decide what to do. Such rules may be hard-coded in an appropriate programming language, such as C#, or alternatively users may be permitted to define their own rules. The rules behave as described above, looking through contact information, presence, and stand-ins to bring users together for a real-time action such as a meeting. The sender can control the operation of the system by modifying information stored by the system, e.g. selecting a new delegate or changing the contact information.
Step 3. Since a request can take days or weeks to process, the disclosed real-time messaging server stores information in a dictionary that resides in the relational database. When an event notification is received, such as a change in a user's presence or a pre-defined time for the expiration of a request, the disclosed real-time messaging server determines if there are any requests that depend on that event and retrieves the relevant information to process the event from the dictionary.
While various specific embodiments may be used, in one exemplary embodiment, two server-side processes may be used. One is the rules engine, which executes rules consisting of scripts. These rules/scripts are nearly stateless, but can use one or more associated dictionary data structures within the database containing the persistent state that a given script uses. Scripts may be stored in the database when they are inactive, along with their dictionary and meta-information about the script. A second server-side process that may be provided is a visibility server. The visibility server itself includes two elements: a raw presence server that keeps track of each user's actual online state, and a subscription service that keeps track of users that are paying attention to other users. The subscription service operates on the raw presence data and processes it to determine which users can see the presence information of which other users according to the rules processed by the rules engine. Accordingly, when a meeting request is received by the rules engine, and the meeting cannot be immediately held because of the unavailability of one or more participants, the rules engine creates a script to enable the convening of that meeting, and indicates to the visibility server that it is looking for all of the required participants for the meeting. The rules engine then goes to “sleep” with regard to that request. Whenever one of the attendees changes presence state, the visibility server sends a message to the engine, which checks whether all the required attendees are now present. If so, it executes the script, which sends a message to the user saying that the meeting may now be convened. If not, it just ignores the state change. Thus, the request from the rules engine to the visibility server consists of a script setting a bit of metadata, indicating to “wake me up when the following people are all present”. This metadata persists along with the sleeping script in the database. As a result, if anything should happen to the visibility server (which resides mainly in memory), the desired subscriptions can be recreated from the metadata of the sleeping scripts in the database.
Example—Routing & Approval
The disclosed availability and rules-based mechanism that allows the effective delivery of real-time actions among users, such as the convening of meetings, can also be used for other real-time actions. For example, the disclosed aggregated presence information and availability filtering, together with real-time communication, can be used to route documents for revision and approval in a timely and efficient manner. As with a meeting request, a document routing form, for example filled out through a GUI on a client system, and provided to the rules engine as an event notification, can contain a list of users that are needed to review an electronic document. In the disclosed system, the routing of the document among the users in the review list may be determined in response to the presence-based availability of specific users in the list. For example, the disclosed system may operate by temporarily skipping users in the review list that are not currently available to process the document, and instead routing the document to one or more users in the review list that are determined to be currently available for the review. Additionally, if a user has been routed the document to be reviewed, and fails to route it within a predetermined time limit, the disclosed system may operate to forward to the document to another user for review that is determined to be currently available.
The disclosed system may be embodied to provide a user interface, for example through a GUI, through which a person that has reviewed a document, may expressly forward the document to a next person on the review list. The disclosed system may indicate a next person on the review list to forward the document to based on a determination that a user on the list that was previously skipped is now available. Alternatively, the disclosed system may provide an interface allowing the current reviewer to specify that the document is to be routed back to one of the previous reviewers, or even directly back to the original author. In addition, the disclosed system may be embodied such that, if a user on the review list is not currently available, the document may be routed to his or her specified stand-in user.
Example—Sequential Scheduling
The disclosed system may further be embodied to effectively support sequential meeting scheduling. In general, meeting scheduling systems attempt to display people's free time, allow the meeting requester to propose a time, and then send out invitations which can be either accepted or refused. Using the disclosed system, meeting invitations, such as email or other electronic data messages, may be sent out to one user at a time, in a similar manner to that described above for document routing. Accordingly, the meeting invitation is sent to users based on their current presence-based and user configured availability. The meeting invitee user list may also optionally be processed by transmitting an invitation to users on the list based on an ordering in which those users considered or designated as the most senior, and/or that are considered or designated as the most difficult to schedule, are contacted first, with each user specifying a range of available times, and wherein a list of possible meeting times contained in the invitation becomes narrower as the invitation routing proceeds. Alternatively, the meeting invitation can be simultaneously broadcast to all users on the list with the list of times becoming narrower as users respond, potentially giving people an incentive to respond quickly.
Example—External Events
In addition to processing requests for real-time actions such as meetings, and/or event notifications reflecting presence status or changes, the disclosed system may be embodied to process notifications of other types of events from various external systems. For example, such an external event processed by the disclosed system may reflect a specified change in a database, such as a customer exceeding a credit limit, or an alert generated by any external program, such as a customer relationship management system indicating that a customer entered a complaint. Availability filtering by the disclosed system may reflect the receipt of such notifications of external events.
While the disclosed system is described herein with reference to various embodiments and examples of operation in which convening a meeting is used as an example of a real-time activity or action, the real-time activities or actions provided by or in connection with the disclosed system are not limited to meetings between users, and may additionally or alternatively include chat sessions, shared whiteboards, remote presentations, audio conferences, video conferences, and/or any combination of these or other forms of communication between users. For example, any specific type of internal or external collaboration and conferencing software, having some combination of functionalities such as those provided in Microsoft® NetMeeting™, which includes point-to-point telephony and videophone capability over the Internet as well as multipoint whiteboard and application sharing, may be used to partially or completely provide the real-time activities and/or actions described herein.
Those skilled in the art should readily appreciate that the programs defining the functions of the present invention can be delivered to a computer in many forms; including, but not limited to: (a) information permanently stored on non-writable storage media (e.g. read only memory devices within a computer such as ROM or CD-ROM disks readable by a computer I/O attachment); (b) information alterably stored on writable storage media (e.g. floppy disks and hard drives); or (c) information conveyed to a computer through communication media for example using baseband signaling or broadband signaling techniques, including carrier wave signaling techniques, such as over computer or telephone networks via a modem. In addition, while the invention may be embodied in computer software, the functions necessary to implement the invention may alternatively be embodied in part or in whole using hardware components such as Application Specific Integrated Circuits or other hardware, or some combination of hardware components and software.
While the invention is described through the above exemplary embodiments, it will be understood by those of ordinary skill in the art that modification to and variation of the illustrated embodiments may be made without departing from the inventive concepts herein disclosed. Therefore, while the preferred embodiments are described in connection with various illustrative data structures, one skilled in the art will recognize that the system may be embodied using a variety of specific data structures. Accordingly, the invention should not be viewed as limited except by the scope and spirit of the appended claims.
Digate, Charles J., Herot, Christopher F., Ketudat, Tonytip, Kopikis, Alexis M., Teven, Daniel J.
Patent | Priority | Assignee | Title |
10110727, | Jan 20 2012 | GOOGLE LLC | Systems and methods for event stream management |
10111057, | Dec 01 2004 | GOOGLE LLC | Prohibiting mobile forwarding |
10289982, | Jun 14 2011 | GENESYS CLOUD SERVICES, INC | Context aware interaction |
9992021, | Mar 14 2013 | goTenna, Inc. | System and method for private and point-to-point communication between computing devices |
Patent | Priority | Assignee | Title |
5283856, | Oct 04 1991 | Banyan Systems Incorporated | Event-driven rule-based messaging system |
5742905, | Sep 19 1994 | ACCESS CO , LTD | Personal communications internetworking |
6449344, | Oct 06 1996 | Microsoft Technology Licensing, LLC | Communication system |
6549937, | Jul 21 1999 | Microsoft Technology Licensing, LLC | System and method for multi-protocol communication in a computer network |
6678719, | Dec 20 1999 | COMCAST MO GROUP, INC | Virtual workplace intercommunication tool |
6691162, | Sep 21 1999 | Microsoft Technology Licensing, LLC | Monitoring users of a computer network |
6714965, | Jul 03 1998 | Fujitsu Limited | Group contacting system, and recording medium for storing computer instructions for executing operations of the contact system |
6721410, | Aug 10 1999 | RPX CLEARINGHOUSE LLC | Recursive identification of individuals for casual collaborative conferencing |
6772229, | Nov 13 2000 | SAMPO IP LLC | Centrifugal communication and collaboration method |
6912564, | May 04 2000 | Meta Platforms, Inc | System for instant messaging the sender and recipients of an e-mail message |
6915336, | Jun 05 1998 | Oracle OTC Subsidiary LLC | Real time internet communication system |
7184524, | Feb 14 2003 | THINKLOGIX, LLC | Rules based real-time communication system |
7263545, | Feb 14 2003 | RATEZE REMOTE MGMT L L C | System and method for immediate and delayed real-time communication activities using availability data from and communications through an external instant messaging system |
7289623, | Jan 16 2001 | THRYV, INC | System and method for an online speaker patch-through |
20010032244, | |||
20020023134, | |||
20020071539, | |||
20020078153, | |||
20020083127, | |||
20020165000, | |||
20030014488, | |||
20030058844, | |||
20030083079, | |||
20030093474, | |||
20030105820, | |||
20030110228, | |||
20030191676, | |||
20030229670, | |||
20030231647, | |||
20040015610, | |||
20040039779, | |||
20040161080, | |||
20040162878, | |||
20050044159, | |||
EP1545087, | |||
WO2004074985, | |||
WO2006060744, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Jun 02 2008 | ZINGDOM COMMUNICATIONS, INC | Devereux Research AB LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 023404 | /0001 | |
Aug 28 2009 | Devereux Research AB LLC | (assignment on the face of the patent) | / | |||
Aug 28 2015 | Devereux Research AB LLC | RATEZE REMOTE MGMT L L C | MERGER SEE DOCUMENT FOR DETAILS | 037131 | /0942 |
Date | Maintenance Fee Events |
Dec 31 2014 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Jan 16 2019 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
May 29 2015 | 4 years fee payment window open |
Nov 29 2015 | 6 months grace period start (w surcharge) |
May 29 2016 | patent expiry (for year 4) |
May 29 2018 | 2 years to revive unintentionally abandoned end. (for year 4) |
May 29 2019 | 8 years fee payment window open |
Nov 29 2019 | 6 months grace period start (w surcharge) |
May 29 2020 | patent expiry (for year 8) |
May 29 2022 | 2 years to revive unintentionally abandoned end. (for year 8) |
May 29 2023 | 12 years fee payment window open |
Nov 29 2023 | 6 months grace period start (w surcharge) |
May 29 2024 | patent expiry (for year 12) |
May 29 2026 | 2 years to revive unintentionally abandoned end. (for year 12) |