The present invention relates generally to Presence Services. More particularly, the present invention relates to the communication of Presence information among a Presence Source, a Presence Server and a Watcher.
This section is intended to provide a background or context to the invention that is recited in the claims. The description herein may include concepts that could be pursued, but are not necessarily ones that have been previously conceived or pursued. Therefore, unless otherwise indicated herein, what is described in this section is not prior art to the description and claims in this application and is not admitted to be prior art by inclusion in this section.
A Presence Service is a network service which accepts, stores and distributes Presence information. Presence information typically comprises a status indicator that indicates the ability and willingness of a communication partner to communicate.
Presence Service can be linked with many other services or enablers. “Horizontal” Presence Services can be used as the launching pad for a different type of communication. Moreover, Horizontal Presence Services can be used to circulate personal and device-specific information to a selected set of authorized Watchers. (A Watcher or Presence information Watcher is an entity that requests Presence information about a Presentity (an entity described by Presence information) from a Presence Service.) However, all of these services can collectively cause a great deal of Presence traffic.
Due to the nature of Presence Services, a simple change in one's Presence information can cause a significant amount of traffic in a network. Additionally, the integration of location information within a Presence Service can be quite demanding in terms of traffic. For example, it is helpful to consider a situation where an entity uploads its location information whenever this information changes. In this situation, if the location of the entity is regularly changing, then a great deal of network traffic is generated.
In light of the traffic-related issues of the type discussed above in terms of Presence systems, there have been several efforts to optimize traffic flow as far as Presence information is concerned. However, it is still desirable to further reduce the amount of Presence-related traffic.
Various embodiments of the present invention provide an improved system and method for providing Presence notifications based upon a user's status. A Watcher is capable of specifying one or more conditions upon which Presence notifications are generated and sent to the Watcher. More particularly, in various embodiments, a Watcher can provide an indication of filtering criteria for incoming Presence information. A network agent can be used to filter unnecessary notifications before they reach the Watcher. As a consequence, Presence notifications can be sent or not sent to a Watcher at certain times based upon the Watcher's availability. In these various embodiments, a condition is provided by the Watcher to indicate whether Presence notifications should be suppressed depending upon particular Watcher Presence state values. These arrangements therefore serve to further optimize Presence traffic by not sending Presence information over a costly radio interface at times when the information simply would not be useful to the intended recipient of the information.
Various embodiments of the present invention are applicable for virtually any Presence solution, including Internet Messaging and Presence Services (IMPS) (defined by the Open Mobile Alliance (OMA)), Session Initiation Protocol (SIP) Instant Message and Presence Leveraging Extensions (SIMPLE) Presence (also defined by the OMA) and the Extensible Messaging and Presence Protocol (XMPP) (defined by the Internet Engineering Task Force (IETF)).
These and other advantages and features of the invention, together with the organization and manner of operation thereof, will become apparent from the following detailed description when taken in conjunction with the accompanying drawings, wherein like elements have like numerals throughout the several drawings described below.
Various embodiments of the present invention provide an improved system and method for providing Presence notifications based upon a user's status. A Watcher is capable of specifying one or more conditions upon which Presence notifications are generated and sent to the Watcher. More particularly, in various embodiments, a Watcher can provide an indication of filtering criteria for incoming Presence information. A network agent can be used to filter unnecessary notifications before they reach the Watcher. As a consequence, Presence notifications can be sent or not sent to a Watcher at certain times based upon the Watcher's availability. In these various embodiments, a condition is provided by the Watcher to indicate whether Presence notifications should be suppressed depending upon particular Watcher Presence state values. These arrangements therefore serve to further optimize Presence traffic by not sending Presence information over a costly radio interface at times when the information simply would not be useful to the intended recipient of the information.
Once subscribed, the notifications intended for the Watcher arrive regardless of the Watcher's own individual status. For example, a Watcher can subscribe for the Presence information of her friends for a period of a day. During this day, she may spend some time (e.g., a couple of hours) in a meeting at work. In the afternoon/evening, she may have an activity such as tennis for a couple of hours, and the Watcher may have other attention-occupying activities as well during the day. During these times, the Watcher is busy and (1) is not likely to be communicating with her friends and/or (2) is not likely to even be interested in the new status of her friends. Therefore, during these “busy” periods, the Watcher really does not care about the Presence information of her friends, as she is not even in a position to use the new Presence information when she is busy. However, in conventional arrangements, the Watcher's device continues to receive updates to her friends' Presence information during these busy periods. As a result, the Watcher may have to pay for the unnecessary updating of her friends' Presence information, causing a more unpleasant user experience. This in turn may adversely impact the Watcher's operator or service provider, as the user may not remain interested in the Presence service if she is forced to continue to pay for updates during periods where she has no use for the information. Although a Watcher could avoid reducing the amount of Presence information traffic during busy periods by turning off the Watcher's device, this is not an optimal solution to the problem, in part because the Watcher may want to keep the device turned on for various reasons.
As a manner of addressing the situation depicted above, various embodiments provide a mechanism for controlling notifications of the Presence information so that such notifications are sent only when they can be consumed by the Recipient. According to various embodiments, a Watcher can provide an indication of filtering criteria for incoming Presence information. A network agent can be used to filter unnecessary notifications before they reach the Watcher. As a consequence, Presence notifications can be sent or not sent to a Watcher at certain times based upon the Watcher's availability. These arrangements therefore serve to further optimize Presence traffic by not sending Presence information over a costly radio interface at times when the information simply would not be useful to the intended recipient of the information. In these embodiments, the Watcher does not receive any Presence updates when she is unavailable, even if there are any changes in the Presence information of any Presentities of interest. The presence information can instead be updated immediately upon the Watcher changing her state back to being available and/or willing to receive updates.
Many of the following show sample implementations of various embodiments of the present invention in a SIMPLE presence environment. However, one skilled in the art would understand that various embodiments of the present invention are applicable to other Presence solutions as well.
In certain embodiments of the invention, the scope of the event notification filtering framework is extended. In a conventional SIP/SIMPLE Presence system, a Watcher can indicate the filtering criteria of incoming Presence information. This ability is discussed, for example, in IETF's Request for Comments (RFC) 4660, entitled “Functional Description of Event Notification Filtering,” and 4661, entitled “An Extensible Markup Language (XML)-Based Format for Event Notification Filtering.” These documents can be found at www.ietf.org/rfc/rfc4660.txt?number=4660 and www.ietf.org/rfc/rfc4661.txt?number=4661, respectively. In the conventional event notification filtering arrangements, the filtering criteria are based solely on the Presence information of the Presentity.
In various embodiments, the scope of event notification filtering is extended to cover not only the Presence information of the Presentity, but also the Presence information of the Watcher. In this arrangement, Presence notifications are sent to the Watcher depending on the Presence information of the Watcher. More specifically, a particular Presence notification is only sent to the Watcher when the Watcher is available and/or willing to communicate. In this arrangement, a user (i.e., a Watcher in this case) can indicate in her Presence information subscription that she is not willing to receive any communication when she is busy (e.g., when in a meeting or involved in another activity). Therefore, in various embodiments the availability of the Watcher becomes a filtering criterion, in which case Presence information regarding the Watcher's friends is sent to the Watcher's device only when she is available and/or willing to communicate.
In particular embodiments, user “availability” and “willingness” of the Watcher to receive Presence information comprise two possible filtering criteria for receiving Presence information. However, these criteria may be modified and/or additional criteria could be used by the Watcher to decide if and when Presence information should be received, and corresponding values that stop and/or start incoming Presence notifications could be set by a user in various embodiments.
As mentioned previously, the existing event notification filter is described in terms of the XML schema in IETF RFC 4661, and the schema is extensible. In particular, Section 4 of IETF RFC 4661 describes how to extend the schema. Therefore, the event notification filtering discussed herein can be mapped to new XML elements and attributes, thereby extending the existing XML schema with the new necessary XML items in a compatible and consistent manner.
The existing XML schema currently includes a <trigger> element in order to indicate when content (i.e., a notification in a Presence situation) should be sent. More particularly, the element can indicate any change in the package (i.e., a Presence Document in this case) that should cause a new notification to be sent. Conventionally, this element has referred to the published Presence Document of the subscribed Presentity. In various embodiments described herein, however, the published Presence Document of the Watcher is also covered. In this context, the XML schema points to a different Presence Document. Other elements in the schema (e.g., <changed>, <from> and <to>) are used to indicate the desired modifications in the Watcher Presence Document which will cause a new notification to be transmitted. Pointing to a different Presence Document, namely the Presence Document of the Watcher, can be achieved with a uniform resource identifier (URI). For this reason, a new attribute “uri” can be defined for the <trigger> element, and the value of the attribute can comprise the URI for the Presence Document of the Watcher. It should be noted, however, that the “uri” attribute is but one example way to point to the Presence Document of a Watcher or other device, and one skilled in the art would readily understand that other systems may be used to point to a different Presence Document.
In many situations, a Watcher and a Presentity share the same Presence Server. In this situation, it is not difficult for the Presentity's Presence Server to locate the Watcher's Presence Document. In case of a resource list server (RLS) subscription, the notifications are aggregated locally. When the RLS and the Presence Server are combined in an implementation, the Presentity's Presence Server can also easily locate the Watcher's Presence Document, even if the subscription is performed via the RLS. In order to handle the case where the Watcher's Presence Document and the Presentity's Presence Document exist in different operator domains, the Watcher's Presence Server has to be contacted by the Presentity's Presence Server in order to determine the Watcher's Presence status.
In other embodiments of the present invention, a network agent is used to filter unnecessary notifications. Alternatively still, a “Watcher Agent” can be placed in the Watcher's home network to act on behalf of the Watcher. In these situations, all subscriptions and notifications that are initiated by the Watcher are transmitted via this agent (i.e., the agent is a Record-Routing SIP proxy). The agent also monitoring the Watcher's Presence status by subscribing to the Watcher's presence information. When the agent detects the Watcher's Presence status to be unavailable, it simply consumes the notifications that were targeted towards the Watcher. The agent then resumes sending the notifications when the Watcher once again becomes available.
The Watcher Agent can be implemented as an application server, which may act as a Record-Routing SIP proxy or an SIP User Agent. In various embodiments, the Watcher Agent is located in the Watcher's home network, where the Watcher's presence information is local knowledge. More particularly, the Watcher Agent may be part of the Watcher's Presence Server as a functional entity, in which case no extra subscription is needed for the Watcher's presence information. In the case where the Watcher and the Presentity share the same Presence Server, the entirety of the necessary processing becomes internal to the Presence Server.
The Watcher Agent acts on behalf of the Watcher. If the Watcher Agent is implemented in a standalone Application Server, it has to Record-Route SUBSCRIBE requests initiated by the Watcher and targeted to the Watcher's Presence Server. In the 3GPP IP Multimedia Subsystem (IMS) environment, this means that the initial filter criteria for the SUBSCRIBE request with the Event:Presence header field has to first point to this Application Server before reaching the Presence Server. The Record-Routing ensures that mid-dialog NOTIFY requests traverse the Watcher Agent based upon the conditions indicated by the Watcher upon which NOTIFY requests should be generated.
The Watcher Agent continuously monitors the Watcher's Presence information by subscribing to the Watcher's presence. When the Watcher Agent detects the Watcher's presence status to be “unavailable” or the like, the Watcher Agent terminates the notifications addressed to the Watcher. In an alternative embodiment, the Watcher Agent can retarget the NOTIFY requests to a storage server when the Watcher's Presence status is “unavailable” or the like. In this arrangement, the Watcher can later download the history of the Presence changes that occurred when the Watcher was unavailable. In either scenario, when the Watcher Agent detects that the Watcher's Presence status has been changed to “available” or the like, the Watcher Agent resumes sending the notifications to the Watcher by simply proxying the NOTIFY requests forward.
In either of the above scenarios, previously-standardized procedures can be used without having to implement any changes to the behavior of either the Watcher or Presence Server. Instead, the only modifications that are necessary involve adjusting the internal logic of the Watcher Agent so as to detect the Watcher's availability and willingness, as well as to act on the traversing NOTIFY requests accordingly.
Communication devices of the various embodiments discussed herein may communicate using various transmission technologies including, but not limited to, Code Division Multiple Access (CDMA), Global System for Mobile Communications (GSM), Universal Mobile Telecommunications System (UMTS), Time Division Multiple Access (TDMA), Frequency Division Multiple Access (FDMA), Transmission Control Protocol/Internet Protocol (TCP/IP), Short Messaging Service (SMS), Multimedia Messaging Service (MMS), e-mail, Instant Messaging Service (IMS), Bluetooth, IEEE 802. 11, etc. A communication device may communicate using various media including, but not limited to, radio, infrared, laser, cable connection, and the like.
The various embodiments described herein are described in the general context of method steps or processes, which may be implemented in one embodiment by a computer program product, embodied in a computer-readable medium, including computer-executable instructions, such as program code, executed by computers in networked environments. A computer-readable medium may include removable and non-removable storage devices including, but not limited to, Read Only Memory (ROM), Random Access Memory (RAM), compact discs (CDs), digital versatile discs (DVD), etc. Generally, program modules may include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types. Computer-executable instructions, associated data structures, and program modules represent examples of program code for executing steps of the methods disclosed herein. The particular sequence of such executable instructions or associated data structures represents examples of corresponding acts for implementing the functions described in such steps or processes.
Software and web implementations of various embodiments can be accomplished with standard programming techniques with rule-based logic and other logic to accomplish various database searching steps or processes, correlation steps or processes, comparison steps or processes and decision steps or processes. It should be noted that the words “component” and “module,” as used herein and in the following claims, is intended to encompass implementations using one or more lines of software code, and/or hardware implementations, and/or equipment for receiving manual inputs.
The foregoing description of embodiments has been presented for purposes of illustration and description. The foregoing description is not intended to be exhaustive or to limit embodiments of the present invention to the precise form disclosed, and modifications and variations are possible in light of the above teachings or may be acquired from practice of various embodiments. The embodiments discussed herein were chosen and described in order to explain the principles and the nature of various embodiments and its practical application to enable one skilled in the art to utilize the present invention in various embodiments and with various modifications as are suited to the particular use contemplated. The features of the embodiments described herein may be combined in all possible combinations of methods, apparatus, modules, systems, and computer program products.
This application claims priority from Provisional Application U.S. Application 60/980342, filed Oct. 16, 2007, incorporated herein by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
60980342 | Oct 2007 | US |