System And Method For Harmonizing Changes In User Activities, Device Capabilities And Presence Information
A method and system utilizes presence information for a device. The method and system comprise receiving a communication indicating a change to a user activity from a first device operated by a user. The existing presence status of the user to the presence status associated with the user activity for the user of a second device is automatically changed in response to the received change to the user activity. The second device is informed of the changing of the existing presence status for the second device to automatically alter a capability of the second device based on the changing of the existing presence status and based on a stored indication from the user on how the capability is to be altered.
The present application is a continuation of U.S. patent application Ser. No. 10/903,576 filed on Jul. 30, 2004 and assigned to the assignee of the present application. The present application is also related to co-pending U.S. patent application Ser. No. 10/960,365 entitled “System and Method for Utilizing Contact Information, Presence Information and Device Activity” filed on Oct. 6, 2004, and assigned to the assignee of the present application. The present application is also related to co-pending U.S. patent application Ser. No. 10/900,558 entitled “System and Method for Providing and Utilizing Presence Information” filed on Jul. 28, 2004 and assigned to the assignee of the present application.
BACKGROUNDThe subject matter disclosed herein relates to instant messaging services and more particularly to providing and utilizing presence information on a client, particularly a multiple user device.
Instant messaging services provide a well known mechanism for allowing computer users to communicate online for example by sending a message or chatting with another user. Such services are typically provided by AOL, MSN, Yahoo, and other similar service providers. Certain data associated with a user of such instant messaging services is known as presence information. Presence information typically consists of one or more presence tuples, which represent the status, an optional activity address, and other information relating to the user. The status of the user can simply be open or closed, when the computer system will or will not accept instant messages for the user. Other examples of the status of the user can include “online”, “away from my desk”, “stepped out”, or “on the phone”. Based on the status of a user, other users may decide whether to initiate activities with the user. Contact information can include contact addresses such as email address, ftp addresses, or postal addresses. More information on instant messaging and presence information can be found in Request for Comment (RFC) 2778, RFC 2779, and Jabber Enhancement Proposal (JEP 0119).
As part of instant messaging services, a conventional friends list is often supported. Such a conventional friends list provides a user with presence information related to other entities (e.g. other users of the instant messaging service) who are associated with the user. More specifically, status information for the “friends” is provided in the friends list. For example, while a user is online, the conventional friends list is typically displayed in a window on the user's display. Using the friends list, a user can determine whether to send a message to an entity on the friends list. For example, if a particular friend's status is “busy” or “away from my desk,” the user may opt not to attempt to start a chat session with that particular friend.
Moreover, instant messaging allows limited association between the actions that a user is taking and the status of the user. More particularly, some conventional instant messaging applications that reside on the device have internet radios incorporated into the application. When a user plays the radio, the conventional instant messaging application notes that the internal radio is being used and alters the user's status, for example to “busy”. Similarly, some conventional instant messaging applications take note of activity on a keyboard for the device. The instant messaging application monitors the activity on the keyboard for the device on which the instant messaging application resides. If the keyboard is not used for a period of time the instant messaging application may change the user's status to “idle”.
Although conventional instant messaging services and conventional friends lists are useful, one of ordinary skill in the art will readily recognize that there are significant drawbacks to such conventional instant messaging services. In particular, there is no requirement that another instant messaging user respect the status of another user. For example, suppose a first user has a friends list including a second user. The second user's status is listed as “busy” or “away from my desk”. However, the first user may still attempt to communicate with the second user, for example by calling or initiating a chat session. The second user will still receive the call or the message indicating that the first user has initiated a communication. The second user may, therefore, still be distracted by the communication. Such distractions may be annoying or, in the case where the second user is engaged in an activity such as driving a car, even dangerous. Furthermore, a user may forget to change their status when engaging in an activity, including activities involving other devices. For example, a user may be on the phone, driving a car, or otherwise busy, but forget to change their status to “busy”. As a result, others having access to the user's status may not realize that the user is busy and attempt to contact the user. Again, the communication may prove to be distracting, annoying, and even dangerous. Thus, despite the use of presence information, there are drawbacks to conventional instant messaging services.
Accordingly, what is needed is a method and system for improving communications between instant messaging service users based upon the status information. The subject matter addresses such a need.
BRIEF SUMMARYThe subject matter described provides a method and system for utilizing presence information for a device. The method and system comprise receiving a communication indicating a change to a user activity from a first device operated by a user. The existing presence status of the user to the presence status associated with the user activity for the user of a second device is automatically changed in response to the received change to the user activity. The second device is informed of the changing of the existing presence status for the second device to automatically alter a capability of the second device based on the changing of the existing presence status and based on a stored indication from the user on how the capability is to be altered.
The method and system disclosed herein allows the status information to be updated based upon a change in the user's activities, or the capabilities of the device to be updated based upon a change in the status.
The following description is presented to enable one of ordinary skill in the art to make and use the subject matter disclosed herein and is provided in the context of a patent application and its requirements. Various modifications to the preferred embodiments and the generic principles and features described herein will be readily apparent to those skilled in the art. Thus, the claimed subject matter is not intended to be limited to the embodiments shown, but is to be accorded the widest scope consistent with the principles and features described herein.
The subject matter provides a method and system for utilizing presence information for a device. The method and system comprise detecting at least one of a status change in a status for the user and an activity change in an activity associated with a capability of the device. The detection of the activity change includes a second device communicating the activity change with a presence service. The method and system also comprise automatically altering the capability of the device if the change in the status is detected or automatically altering the status if the change in the activity is detected.
The claimed subject matter will be described in terms of a particular method having certain steps. However, one of ordinary skill in the art will readily recognize that a method in accordance with the subject matter can include other and/or additional steps not inconsistent with the subject matter. Similarly, the subject matter will be described in terms of particular devices, such as cellular or other telephones and digital cameras. However, one of ordinary skill in the art will readily recognize that the method and system in accordance with the teachings herein can include other and/or additional components not inconsistent with the claimed subject matter. The subject matter will also be described in terms of a single capability, a single activity, and a particular status. However, one of ordinary skill in the art will readily recognize that the method and system apply to multiple capabilities, multiple activities, and multiple statuses.
Thus, using the method 110, the capabilities of the device are updated in response to a change in the user's status. For example, a user may change their status to “on the phone.” Such a status change is detected in step 114. As a result, the capability of the device to receive instant messages, except those from a call participant, may be disabled in step 116. Similarly, a user may start their car, which is capable of updating the user's status to “not available.” When starting the car, the user also preferably identifies themself, in one embodiment by using a unique key. The status of the user is updated, for example by the car sending a message to the presence service (not depicted in
The user may optionally be allowed to specify particular statuses associated with certain activities, via step 152. Note that in some embodiments, some activities may not be associated with a particular status. In some embodiments, the user may specify the status associated with some activities, while default statuses are associated with other activities. In other embodiments, the user may not be allowed to specify the status associated with a particular activity. Instead, the status associated with certain activities may be determined by another entity, such as the presence service (not depicted in
A change in the activities being carried out by the user and/or the initiation of certain activities by the user are detected, via step 154. The detection performed in step 154 includes the change and/or initiation of activities includes a second device communicating the change and/or initiation with a presence service. In some embodiments, an initiation of certain activities can be considered to be a subset of a change in these activities and, therefore, need not be separately detected. Thus, the user is now engaged in particular, current activities. In a preferred embodiment, these activities are associated with communication capabilities of a device. The particular status, if any, associated with the particular activity is determined, via step 156. Step 156 thus may include sending a query to the presence service indicating the current activity and receiving the status associated with the activity if such information is stored by the presence service. Alternatively, the device on which the activity is performed or the device with which the status is associated may be used to determine the status associated with the activity. The status for the user is allowed to be updated based on the particular activity, via step 158. In one embodiment, step 158 includes sending a request to a presence service to update the status in the presence information for the user.
Thus, using the method 150, the user's status is automatically updated in response to the initiation of or changes in activities of the user. For example, the method 150 might be used to update the user's status for a personal computer. The user may initiate a call on their mobile phone. The initiation of the call is detected in step 154, including the phone sending a notification to the presence service that a call has been initiated or requesting a status update associated with the current activity. In one embodiment, the presence service notifies other device(s), such as the personal computer, of the initiation of the call. The status associated with the call, in this case “on the phone”, is determined in step 156. In one embodiment, the determination of the status associated with the activity may take place at the presence service or in the device. In the example above, the presence service might determine the status for the personal computer associated with the phone call or the personal computer may determine its status associated with the call. The device sends a request to the presence service to alter the user's status to “on the phone” in step 158. Thus, the personal computer may send a request to the presence service to have the user's status updated to “on the phone.” Similarly, a user may enter their car and start the car using a unique key identifying the user. The change in activities, driving a car, is detected in step 154. The car thus sends a message to the presence service that the user is driving the car. The status associated with driving a car, for example “not available”, is determined in step 156. The presence service is accessed to change the user's status to “not available” or another status for a device, such as a personal computer or cell phone. In another example, the user may change the mode of a camera, the second device described above, to capture mode. The camera detecting this change in step 154 determines the user's status associated with image capture activity is “busy” in step 156. The camera accesses the presence service and updates the user's status to “busy”. This status is communicated to another device, such as a cell phone. Alternatively, the camera accesses the presence service and communicates the change in activity. The presence service communicates the activity change to the cell phone, which ensures that the status is changed to “busy”. Moreover, the methods 110 and 150 may be combined. As a result, once the status is updated as described above, the capabilities of one or more of the device(s) associated with the user may be selectively enabled and/or disabled based upon the new status. Thus, the user's status, the user's activities, and the capabilities of the device(s) the user employs may be harmonized.
The service 210 interfaces with the presence data 330 and the directory data 335. The presence data 330 and directory data 335 may be implemented on the same or different databases. The presence data includes presence information, preferably in the form of presence tuples that are preferably indexed using the identity of the corresponding entity (or user). The directory data 335 includes information used in lookups.
In operation, the capability monitor 219, through communication with the presence user agent 217, watcher user agent 220, and the service 210 implements most of the methods 100, 110, and 150. In particular, the watcher user agent 220 can receive user presence information including a user identity for a user, and changes actually made to the user's status. The presence user agent 217 communicates with the user, provides an identification of the user to the service 210, and indicates to the service 210 that an activity related to a recipient is initiated by the user. The watcher user agent 220 receives from the service 210 the status of the user, particularly in response to a notification that the activities on the device have been initiated or changed. Further, the capabilities monitor operates as described above with respect to and depicted in
Thus, using the system 300, the user's activities, the capabilities of devices, and the presence information are harmonized. Further, the system 300 may be used to perform one or more of the methods 100, 110, and 150. Consequently, the benefits of the methods 100, 110, and 150 may be achieved.
A method and system for harmonizing presence information with device capabilities and user activities has been disclosed. The subject matter has been described in accordance with the embodiments shown, and one of ordinary skill in the art will readily recognize that there could be variations to the embodiments, and any variations would be within the spirit and scope of the subject matter. Software written according to the subject matter is to be stored in some form of computer-readable storage medium, such as memory, CD-ROM and the like, and executed by a processor. Accordingly, many modifications may be made by one of ordinary skill in the art without departing from the spirit and scope of the appended claims.
The methods described herein can be embodied in executable instructions stored in a computer-readable medium for use by or in connection with an instruction execution machine, system, apparatus, or device, such as a computer-based or processor-containing machine, system, apparatus, or device. As used here, a “computer-readable medium” can include one or more of any suitable media for storing the executable instructions of a computer program in one or more of an electronic, magnetic, optical, and electromagnetic form, such that the instruction execution machine, system, apparatus, or device can read (or fetch) the instructions from the computer readable medium and execute the instructions for carrying out the described methods. A non-exhaustive list of conventional exemplary computer readable medium includes: a portable computer diskette; a random access memory (RAM); a read only memory (ROM); an erasable programmable read only memory (EPROM or Flash memory); optical storage devices, including a portable compact disc (CD), a portable digital video disc (DVD), and the like.
Claims
1. A method for utilizing presence information with a device comprising:
- receiving, by a presence service, a communication indicating a change to a user activity from a first device operated by a user;
- automatically changing, by the presence service, an existing presence status of the user to the presence status associated with the user activity for the user of a second device in response to the received change to the user activity; and
- informing, by the presence service, the second device of the changing of the existing presence status for the second device to automatically alter a capability of the second device based on the changing of the existing presence status and based on an indication from the user on how the capability is to be altered.
2. The method of claim 1 wherein the presence service is located on the second device.
3. The method of claim 1 wherein the second device comprises a plurality of devices.
4. The method of claim 3 further comprising receiving a location of the user, wherein informing the second device of the changing of the existing presence status for the second device to automatically alter a capability of the second device based on the changing of the existing presence status and based on the indication from the user on how the capability is to be altered comprises informing devices in a vicinity of the location of the user of the changing of the existing presence status for each device in the vicinity of the location of the user to automatically alter a capability of the device based on the changing of the existing presence status and based on the indication from the user on how the capability is to be altered.
5. The method of claim 4 wherein informing devices in a vicinity of the location of the user of the changing of the existing presence status for each device in the vicinity of the location of the user to automatically alter a capability of the device based on the changing of the existing presence status and based on the indication from the user on how the capability is to be altered comprises informing devices in a vicinity of the location of the user of the changing of the existing presence status for each device in the vicinity of the location of the user to automatically alter a capability of the device based on the changing of the existing presence status and based on the indication from the user on how the capability is to be altered based on the location of the user.
6. The method of claim 1 wherein the first device has a plurality of capabilities and a portion of the plurality of capabilities is associated with a first presence status of the user for the first device, and wherein changing the presence status of the user for the first device includes changing an existing presence status of the user for the first device to the first presence status.
7. The method of claim 6 wherein when the existing presence status of the user for the first device is changed to the first presence status, at least one capability of the portion of the plurality of capabilities associated with the first presence status is enabled or disabled in the first device.
8. The method of claim 6 wherein the portion of the capabilities to be associated with the first presence status of the user is configurable by the user.
9. The method of claim 1 further comprising:
- receiving, by the presence service, an indication from the user on how the capability is to be altered; and
- storing the indication.
10. A method for utilizing presence information with at least one device having at least one capability, the method comprising:
- allowing a user to associate the at least one capability of the at least one device with a particular presence status of the user and a location of the user for the at least one device and associate the particular presence status to an activity specified by the user;
- allowing the user to provide an indication for the at least one capability of the at least one device, based on a location of the user, whether the at least one capability is to be enabled or disabled when an existing presence status of the user for the at least one device is the particular presence status;
- obtaining, by a first application, a present location of the user and a presence status and detecting that the presence status of the user for the at least one device is the particular presence status; and
- automatically altering, by a second application, based on the present location of the user, the at least one capability associated with the particular presence status of the at least one device according to the provided indication when the first application detects that the presence status of the user is the particular presence status.
11. The method of claim 10 wherein the at least one capability is different for at least two locations of the user.
12. The method of claim 10 wherein the at least one capability is different for at least two activities specified by the user.
13. The method of claim 10 wherein obtaining, by the first application, the presence status comprises obtaining, by the first application, the presence status from a presence service.
14. The method of claim 10 wherein automatically altering, by the second application, based on the present location of the user, each capability comprises automatically enabling or disabling, by the second application, based on the present location of the user, each capability of the at least one capability associated with the particular presence status of the at least one device according to the provided indication when the first application detects that the presence status of the user is the particular presence status.
15. The method of claim 10 wherein the at least one capability comprises a plurality of capabilities and a portion of the plurality of capabilities is associated with a first presence status of the user for the at least one device, and wherein automatically altering the at least one capability comprises automatically altering the portion of the plurality of capabilities when the existing presence status of user is the first presence status.
16. The method of claim 15 wherein automatically altering the portion of the plurality of capabilities associated with the first presence status comprises enabling or disabling each of the portion of the plurality of capabilities of the at least one device.
17. A computer-readable medium storing a computer program, executable by a machine, for utilizing presence information with a device, the computer program comprising executable instructions for:
- receiving, by a presence service, a communication indicating a change to a user activity from a first device operated by a user;
- automatically changing, by the presence service, an existing presence status of the user to the presence status associated with the user activity for the user of a second device in response to the received change to the user activity; and
- informing, by the presence service, the second device of the changing of the existing presence status for the second device to automatically alter a capability of the second device based on the changing of the existing presence status and based on an indication from the user on how the capability is to be altered.
18. The computer-readable medium of claim 17 wherein the presence service is located on the second device.
19. The computer-readable medium of claim 17 wherein the second device comprises a plurality of devices.
20. The computer-readable medium of claim 19 having further executable instructions for receiving a location of the user, wherein informing the second device of the changing of the existing presence status for the second device to automatically alter a capability of the second device based on the changing of the existing presence status and based on the indication from the user on how the capability is to be altered comprises informing devices in a vicinity of the location of the user of the changing of the existing presence status for each device in the vicinity of the location of the user to automatically alter a capability of the device based on the changing of the existing presence status and based on the indication from the user on how the capability is to be altered.
21. The computer-readable medium of claim 20 wherein informing devices in a vicinity of the location of the user of the changing of the existing presence status for each device in the vicinity of the location of the user to automatically alter a capability of the device based on the changing of the existing presence status and based on the indication from the user on how the capability is to be altered comprises informing devices in a vicinity of the location of the user of the changing of the existing presence status for each device in the vicinity of the location of the user to automatically alter a capability of the device based on the changing of the existing presence status and based on the indication from the user on how the capability is to be altered based on the location of the user.
22. The computer-readable medium of claim 17 wherein the first device has a plurality of capabilities and a portion of the plurality of capabilities is associated with a first presence status of the user for the first device, and wherein changing the presence status of the user for the first device includes changing an existing presence status of the user for the first device to the first presence status.
23. The computer-readable medium of claim 22 wherein when the existing presence status of the user for the first device is changed to the first presence status, at least one capability of the portion of the plurality of capabilities associated with the first presence status is enabled or disabled in the first device.
24. The computer-readable medium of claim 22 wherein the portion of the capabilities to be associated with the first presence status of the user is configurable by the user.
25. The computer-readable medium of claim 17 having further executable instructions for:
- receiving, by the presence service, an indication from the user on how the capability is to be altered; and
- storing the indication.
26. A method for utilizing presence information with at least one device having at least one capability, the method comprising:
- allowing a user to associate the at least one capability of the at least one device with a particular presence status of the user and a location of the user for the at least one device and associate the particular presence status to an activity specified by the user;
- allowing the user to provide an indication for the at least one capability of the at least one device whether the at least one capability is to be enabled or disabled when an existing presence status of the user for the at least one device is the particular presence status and the location of the user when the existing presence status of the user for the at least one device is the particular presence status;
- obtaining, by a first application, a present location of the user and a presence status and detecting that the presence status of the user for the at least one device is the particular presence status; and
- automatically altering, by a second application, based on the present location of the user, the at least one capability associated with the particular presence status of the at least one device according to the provided indication when the first application detects that the presence status of the user is the particular presence status.
27. The method of claim 26 wherein the at least one capability is different for at least two locations of the user.
28. The method of claim 26 wherein the at least one capability is different for at least two activities specified by the user.
29. The method of claim 26 wherein obtaining, by the first application, the presence status comprises obtaining, by the first application, the presence status from a presence service.
30. The method of claim 26 wherein automatically altering, by the second application, based on the present location of the user, each capability comprises automatically enabling or disabling, by the second application, based on the present location of the user, each capability of the at least one capability associated with the particular presence status of the at least one device according to the provided indication when the first application detects that the presence status of the user is the particular presence status.
31. The method of claim 26 wherein the at least one capability comprises a plurality of capabilities and a portion of the plurality of capabilities is associated with a first presence status of the user for the at least one device, and wherein automatically altering the at least one capability comprises automatically altering the portion of the plurality of capabilities when the existing presence status of user is the first presence status.
32. The method of claim 31 wherein automatically altering the portion of the plurality of capabilities associated with the first presence status comprises enabling or disabling each of the portion of the plurality of capabilities of the at least one device.
33. A system for allowing a device having at least one capability to utilize presence information, the system comprising:
- a processor for executing a presence user agent and a capability monitor;
- the presence user agent for communicating with a user and for communicating with a presence service on behalf of the user;
- the capability monitor for allowing a user to associate the at least one capability with a particular presence status of the user for the device and a location of the user, associate the particular presence status to an activity specified by the user, and to provide an indication for each capability of the at least one capability whether each capability is to be altered based on a present location of the user and in response to detecting by a watcher user agent that a presence status of the user for the device is the particular presence;
- the watcher user agent for obtaining presence information from the presence service including the presence status of the user; and
- wherein the capability monitor is further configured to automatically alter, based on the present location of the user, each capability of the at least one capability of the device according to the provided presence information when the watcher user agent detects that the presence status of the user is the particular presence status.
34. The system of claim 33 wherein the presence service is executed by the processor on the device.
35. The system of claim 33 further comprising:
- a lookup service, operatively coupled to the presence service, the lookup service configured to:
- receive from the presence service, information associated with the received indication of the user activity; and
- determine a presence tuple including presence information for the user from the information associated with the received indication of the user activity.
36. A computer-readable medium storing a computer program, executable by a machine, for utilizing presence information with at least one device having at least one capability, the computer program comprising executable instructions for:
- allowing a user to associate the at least one capability of the at least one device with a particular presence status of the user and a location of the user for the at least one device and associate the particular presence status to an activity specified by the user;
- allowing the user to provide an indication for the at least one capability of the at least one device whether the at least one capability is to be enabled or disabled when an existing presence status of the user for the at least one device is the particular presence status and the location of the user when the existing presence status of the user for the at least one device is the particular presence status;
- obtaining, by a first application, a present location of the user and a presence status and detecting that the presence status of the user for the at least one device is the particular presence status; and
- automatically altering, by a second application, based on the present location of the user, the at least one capability associated with the particular presence status of the at least one device according to the provided indication when the first application detects that the presence status of the user is the particular presence status.
37. The computer-readable medium of claim 36 wherein the at least one capability is different for at least two locations of the user.
38. The computer-readable medium of claim 36 wherein the at least one capability is different for at least two activities specified by the user.
39. The computer-readable medium of claim 36 wherein obtaining, by the first application, the presence status comprises obtaining, by the first application, the presence status from a presence service.
40. The computer-readable medium of claim 36 wherein automatically altering, by the second application, based on the present location of the user, each capability comprises automatically enabling or disabling, by the second application, based on the present location of the user, each capability of the at least one capability associated with the particular presence status of the at least one device according to the provided indication when the first application detects that the presence status of the user is the particular presence status.
41. The computer-readable medium of claim 36 wherein the at least one capability comprises a plurality of capabilities and a portion of the plurality of capabilities is associated with a first presence status of the user for the at least one device, and wherein automatically altering the at least one capability comprises automatically altering the portion of the plurality of capabilities when the existing presence status of user is the first presence status.
42. The computer-readable medium of claim 41 wherein automatically altering the portion of the plurality of capabilities associated with the first presence status comprises enabling or disabling each of the portion of the plurality of capabilities of the at least one device.
Type: Application
Filed: Jul 17, 2009
Publication Date: Nov 12, 2009
Inventor: Robert P. Morris (Raleigh, NC)
Application Number: 12/504,937
International Classification: G06F 15/173 (20060101);