A server system stores a hosted conversation having a special-purpose automated participant and a standard participant. The server system receives a request to modify the conversation from a first participant, determines a set of edits that update the conversation to an updated state in accordance with the request to modify the conversation; and sends, the set of edits to a second participant. When the first participant is a standard participant: the request includes an indication of preliminary edits; the conversation is updated in accordance with the preliminary edits; and the set of edits include concurrency-resolved edits. When the first participant is a special-purpose automated participant: the request includes an operation to be performed on the conversation; the operation is performed on the conversation at the server system; and the set of edits updates the conversation, in accordance with the operation.
|
1. A method, comprising:
at a server system having one or more processors and a memory storing one or more programs for execution by the one or more processors so as to perform the method:
storing a hosted conversation having a plurality of participants, the participants including one or more special-purpose automated participants that operate in accordance with instructions to perform one or more predefined operations in response to detecting predefined trigger criteria and one or more standard participants that respond dynamically to changes in the conversation;
receiving a request to modify the conversation from a first participant;
determining a set of edits that update the conversation in accordance with the request to modify the conversation; and
sending the set of edits to a second participant that update the conversation to an updated state;
wherein:
when the first participant is a standard participant: the request includes an indication of preliminary edits that were performed on the conversation by the first participant; determining the set of edits includes updating the conversation in accordance with the preliminary edits that were performed on the conversation by the first participant; and the set of edits include concurrency-resolved edits that transform the conversation to the updated state;
when the first participant is a special-purpose automated participant: the request includes a request to perform an operation on the conversation; determining the set of edits includes performing the operation on the conversation; and the set of edits include edits that update the conversation, in accordance with the operation, to the updated state; and
when the first participant is the special-purpose automated participant: the first participant is in communication with a third-party; the request to perform the operation on the conversation is a request to add third-party content to the conversation; and the set of edits that are sent to the second participant update the conversation by adding the third-party content to the conversation.
13. A non-transitory computer readable storage medium and one or more computer programs embedded therein, the one or more computer programs comprising instructions, which when executed by a computer system, cause the computer system to:
store a hosted conversation having a plurality of participants, the participants including one or more special-purpose automated participants that operate in accordance with instructions to perform one or more predefined operations in response to detecting predefined trigger criteria and one or more standard participants that respond dynamically to changes in the conversation;
receive a request to modify the conversation from a first participant;
determine a set of edits that update the conversation in accordance with the request to modify the conversation; and
send the set of edits to a second participant that update the conversation to an updated state;
wherein:
when the first participant is a standard participant: the request includes an indication of preliminary edits that were performed on the conversation by the first participant; determining the set of edits includes updating the conversation in accordance with the preliminary edits that were performed on the conversation by the first participant; and the set of edits include concurrency-resolved edits that transform the conversation to the updated state;
when the first participant is a special-purpose automated participant: the request includes a request to perform an operation on the conversation; determining the set of edits includes performing the operation on the conversation; and the set of edits includes include edits that update the conversation, in accordance with the operation, to the updated state; and
when the first participant is the special-purpose automated participant: the first participant is in communication with a third-party; the request to perform the operation on the conversation is a request to add third-party content to the conversation; and the set of edits that are sent to the second participant update the conversation by adding the third-party content to the conversation.
2. The method of
3. The method of
updating the conversation;
determining whether the updated conversation meets predefined notification criteria for the first participant; and
when the updated conversation meets the predefined notification criteria:
sending at least a predefined portion of the conversation to the first participant; and
receiving a response from the first participant corresponding to the predefined portion of the conversation.
4. The method of
when the first participant is the standard participant, the preliminary edits are edits performed on a client-side copy of the conversation; and
when the first participant is the special-purpose automated participant, the request to perform the operation is a request to perform an edit operation on a server-side, concurrency-resolved copy of the conversation.
5. The method of
after sending the set of edits to the second participant, receiving from the second participant a reply to the third-party webservice content; and
in response to the reply:
updating the conversation;
determining whether the updated conversation meets predefined notification criteria for the first participant; and
when the updated conversation meets the predefined notification criteria, sending at least a predefined portion of the conversation to the first participant.
6. The method of
the third-party webservice is a media sharing application;
the content from the third-party webservice is a comment on media from the media sharing application; and
the reply includes a response to the comment.
7. The method of
the first participant is the special-purpose automated participant; and
the request to perform the operation on the conversation includes a request to perform the operation using a first identifier that uniquely identifies a first user of a third-party webservice.
8. The method of
9. The method of
10. The method of
sending, to the first participant, a request for a profile associated with the first identifier;
receiving, in response to the request, information retrieved from the profile for the first user of the third-party webservice.
11. The method of
12. The method of
14. The non-transitory computer readable storage medium of
15. The non-transitory computer readable storage medium of
update the conversation;
determine whether the updated conversation meets predefined notification criteria for the first participant; and
when the updated conversation meets the predefined notification criteria:
send at least a predefined portion of the conversation to the first participant; and
receive a response from the first participant corresponding to the predefined portion of the conversation.
16. The non-transitory computer readable storage medium of
when the first participant is the standard participant, the preliminary edits are edits performed on a client-side copy of the conversation; and
when the first participant is the special-purpose automated participant, the request to perform the operation is a request to perform an edit operation on a server-side, concurrency-resolved copy of the conversation.
17. The non-transitory computer readable storage medium of
after sending the set of edits to the second participant, receive from the second participant a reply to the third-party webservice content; and
in response to the reply:
update the conversation;
determine whether the updated conversation meets predefined notification criteria for the first participant; and
when the updated conversation meets the predefined notification criteria, send at least a predefined portion of the conversation to the first participant.
18. The non-transitory computer readable storage medium of
the third-party webservice is a media sharing application;
the content from the third-party webservice is a comment on media from the media sharing application; and
the reply includes a response to the comment.
19. The non-transitory computer readable storage medium of
the first participant is the special-purpose automated participant; and
the request to perform the operation on the conversation includes a request to perform the operation using a first identifier that uniquely identifies a first user of a third-party webservice.
20. The non-transitory computer readable storage medium of
|
This application claims priority to U.S. Provisional Patent Application Nos. 61/345,991, filed May 18, 2010, and 61/475,616, filed Apr. 14, 2011, both entitled “Automated Participants for Hosted Conversations,” which are incorporated herein by reference in their entirety.
The disclosed embodiments relate generally to communication systems. More particularly, the disclosed embodiments relate to methods and systems, and user interfaces for enabling automated participants to participate in a communication system.
A variety of electronic communications systems, including electronic email (“email”) systems and instant messaging (IM) system are well known. In some conventional electronic communication systems computer implemented users are allowed to interact with human users. However, in such conventional electronic communication systems, computer implemented users have traditionally communicated with the human users using the same protocols or a subset of the same protocols as the human users use. Thus, these computer implemented users have substantially the same capabilities (or a subset of the capabilities) as the human users. Moreover, in conventional electronic communication systems, the computer implemented users have typically been passive users, which is to say that the computer implemented users respond to queries from human users or content provided by human users but do not typically initiate communications with the human users and do not incorporate any information from events that occur outside of the electronic communication system into communications with the human users. These limitations of conventional computer implemented users restrict the utility of computer implemented users in conventional electronic communication systems.
Therefore, it would be advantageous to provide a system and method for enabling automated participants to participate in conversations that enables the automated participants to actively participate in the conversation. In particular, in accordance with some of the disclosed embodiments, automated participants are enabled to participate in conversations based on events external to the conversation, and effectively integrate conversations in a conversation system with content generated at third-party webservices, thereby providing substantial added value to electronic communication systems. Thus, the problems with conventional electronic communication systems described above are reduced or eliminated by the systems and methods described below.
In accordance with some embodiments, a method is performed at a server system having one or more processors and memory storing one or more programs for execution by the one or more processors so as to perform the method. The method includes: storing a hosted conversation having a plurality of participants, the participants including one or more special-purpose automated participants and one or more standard participants; receiving a request to modify the conversation from a first participant; determining a set of edits that update the conversation in accordance with the request to modify the conversation; and sending the set of edits to a second participant that update the conversation to an updated state. When the first participant is a standard participant: the request includes an indication of preliminary edits that were performed on the conversation by the first participant; determining the set of edits includes updating the conversation in accordance with the preliminary edits that were performed on the conversation by the first participant; and the set of edits include concurrency-resolved edits that transform the conversation to the updated state. When the first participant is a special-purpose automated participant: the request includes a request to perform an operation on the conversation; determining the set of edits includes performing the operation on the conversation; and the set of edits includes edits that update the conversation, in accordance with the operation, to the updated state.
In accordance with some embodiments, a method is performed at a server system having one or more processors and memory storing one or more programs for execution by the one or more processors so as to perform the method. The method includes: registering as a special-purpose automated participant of a hosted conversation on a conversation server; identifying a change in content at a third-party webservice; and determining whether the change in content at the third-party webservice meets predefined conversation update criteria for the conversation. When the predefined conversation update criteria have been met, the method further includes: determining a set of one or more operations to update the conversation in accordance with the change in content at the third-party webservice; and sending the set of operations to the conversation server.
In accordance with some embodiments, a computer system (e.g., a client, conversation server, automated participant server, etc.) includes one or more processors, memory, and one or more programs; the one or more programs are stored in the memory and configured to be executed by the one or more processors and the one or more programs include instructions for performing the operations of the method described above. In accordance with some embodiments, a non-transitory computer readable storage medium has stored therein instructions which when executed by one or more processors, cause a computer system (e.g., a client, conversation server, automated participant server, etc.) to perform the operations of the methods described above.
Various embodiments of the invention are disclosed in the following Description of Embodiments herein, in conjunction with the following drawings in which like reference numerals refer to corresponding parts throughout the figures.
Methods, systems, user interfaces, and other aspects of the invention are described. Reference will be made to certain embodiments of the invention, examples of which are illustrated in the accompanying drawings. While the invention will be described in conjunction with the embodiments, it will be understood that it is not intended to limit the scope of the invention to these particular embodiments. On the contrary, the invention is intended to cover alternatives, modifications and equivalents that are within the spirit and scope of the invention. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.
Moreover, in the following description, numerous specific details are set forth to provide a thorough understanding of the present invention. However, it will be apparent to one of ordinary skill in the art that the invention can be practiced without these particular details. In other instances, methods, procedures, components, and networks that are well known to those of ordinary skill in the art are not described in detail to avoid obscuring relevant aspects of the disclosed embodiments.
Additionally, various other servers may be a part of the distributed computer system 100. In some embodiments, the distributed computer system 100 includes an automated participant server 118 that communicates with conversation server(s) 130 and clients 110 via communication network 120, so as to participate in conversations. In some embodiments, automated participant server 118 is a third-party server (e.g., a server which is owned, and/or operated by a party other than: the party that owns and/or operates conversation server 130 and the party that owns and/or operates client 110.) However, automated participant server 118 can also be a pseudo third-party server, which is owned and/or operated by the same party that owns and/or operates conversation server 130, but that is not integrated into the conversation system. For example, an operator of a conversation system could provide one or more automated participant servers that are available for third parties to host automated participant code so as to ensure that the code is readily available without substantively controlling the content of the automated participant code. It should be understood that in other embodiments, the content of the automated participant code is only constrained by a predefined set of guidelines (e.g., guidelines intended to prohibit malicious behavior) but is otherwise not controlled by the operator of the conversation system. In most implementations, however, automated participant server 118 is distinct from conversation server 130.
In some embodiments, distributed computer system 100 also includes a third-party webservice 121 that communicates with automated participant server(s) 118 and clients 110 via communication network 120. Users of the third-party webservice may indirectly participate in conversations hosted by conversation servers 130 via the automated participant server(s) 118 as described in greater detail below. In some embodiments, a third-party webservice 121 is hosted at a server system which is owned, and/or operated by a party other than: the party that owns and/or operates conversation server 130, the party that owns and/or operates client 110, and the party that owns and/or operates application server 118. However, third-party webservice 121 can also be hosted at a pseudo third-party server, which is owned and/or operated by the same party that owns and/or operates conversation server 130, but that is not integrated into the conversation system. Third-party webservices may include virtually any web-based service that includes user generated content (e.g., text, images, video, audio), such as one or more of: video sharing services (e.g., YouTube), blogging services (e.g., Blogger), social media services (e.g., Buzz, Facebook, Twitter, etc.), online retail services (e.g., Google Checkout, Amazon.com, eBay, etc.), or any other service that enables users to post comments, content or reviews.
In some embodiments, the distributed computer system 100 includes an application server 119 that communicates with conversation server(s) 130 and clients 110 via communication network 120, so as to provide code enabling embedded applications to be inserted into conversations. In some embodiments, application server 119 is a third-party server, which is owned, and/or operated by a party other than: the party that owns and/or operates conversation server 130 and the party that owns/operates client 110. However, application server 119 can also be a pseudo third-party server, which is owned and/or operated by the same party that owns and/or operates conversation server 130, but that is not integrated into the conversation system. For example, an operator of a conversation system could provide one or more servers that are available for third parties to host embedded application code so as to ensure that the code is readily available without substantively controlling the content of the embedded applications. It should be understood that in other embodiments, the content of the embedded applications is only constrained by a predefined set of guidelines (e.g., guidelines intended to prohibit malicious behavior) but is otherwise not controlled by the operator of the conversation system. In most implementations, however, application server 119 is distinct from conversation server 130.
A respective client (e.g., 110-A) executes a client application 114 that facilitates access from client 110 to a respective conversation server (e.g., 130-A). Client application 114 may include a graphical user interface. For example, client application 114 may be a web browser or other browser application, such as Firefox (trademark of Mozilla Foundation), Internet Explorer (trademark of Microsoft Corporation), Safari (trademark of Apple Inc.), or Chrome (trademark of Google Inc.).
While a conversation system (e.g., a hosted conversation system with a shared communication protocol that enables different conversation servers to communicate with each other and users who have communications accounts with one conversation server to interact with users who have communications accounts with another conversation server) may have a single conversation server 130, in other embodiments the conversation system may have multiple conversation servers 130. For example, multiple conversation servers 130-A and 130-Y may be hosted by different service providers, such as providers 116-A and 116-Y respectively. In some embodiments, the providers are internet service providers (ISPs) providing a conversation service. Alternately, some or all of the providers may be dedicated conversation providers. When conversation system includes multiple conversation servers 130, conversation servers 130 may be coupled together directly, or by a local area network (LAN), or via network 120.
Conversation server(s) 130 host conversations that include contributions from one or more of participants 112. More specifically, each conversation server 130 hosts conversations on behalf of a set of users. At least some of those users are subscribers of the conversation system and thus have user communications accounts. However, as described in more detail below, some of the conversation participants need not be subscribers of the conversation system. When new content is added to a conversation by any participant, or any other changes are made to a conversation by any participant, the updates are sent to all the conversation servers 130 that host conversations for the participants in the conversation. Those host servers, in turn, send the updates to clients 110 being used by participants in the conversation. The conversation updates may be sent relatively instantaneously (e.g., within a second or two) to clients 110 of active participants in the conversation. Optionally, clients 110 of passive participants who are online and logged into the conversation system, but who are not currently viewing the conversation or are not current participating in the conversation, receive information that the conversation has been updated, without receiving the updates to the conversation. In at least some embodiments, when the participant “opens” the conversation (selects it for viewing), the updated conversation is downloaded to the participant's client 110 from conversation server 130 that hosts conversations for that participant.
Attention is now directed towards
Non-subscriber clients (e.g., 110-C and 110-D in
Non-subscriber clients (e.g., 110-C and 110-D) access conversation server 130 in a manner that is distinct from the manner used by subscriber clients (e.g., 110-B) whose users are subscribers of the conversation system (e.g., via an automated participant server 118, as illustrated in
An example of a non-subscriber client 110-C is an email server 224, having email clients 222. Content from host conversations can be sent to one or more email clients 222 of one or more email servers 224. In particular, when the user of an email client 222 is added as a participant to a conversation, content of the conversation (and content subsequently added to the conversation) is transmitted to email client 222 by the conversation server (e.g., 130-B in
Another example of a non-subscriber client 110-D is a weblog (“blog”) server 226, having a weblog client 228. As described below, a hosted conversation can include a weblog 228 (also called a weblog client) as a participant in a hosted conversation, in which case content of the hosted conversation is published in the weblog. The published conversation is visible on weblog 228, which is hosted by weblog server 226. More specifically, when a weblog 228 is added as a participant to a conversation via an automated participant server 118-D, content of the conversation is transmitted from the conversation server 130-B that hosts the conversation to (also called “posted to”) weblog 228 via automated participant server 118-D. After weblog 228 is added as a participant, new content added to the conversation is also transmitted from conversation server 130-B to weblog 228 via automated participant server 118-D. A user (e.g., a user of another client 110,
Thus, weblog servers and email servers are examples of services which can interact with conversations as “automated participants,” also sometimes called “robots,” which communicate with conversation servers 130 in the conversation system via automated participant servers 118 (e.g., email servers 224 and weblog servers 226). As described above, these “automated participants” enable non-subscribing users to participate in a conversation without acquiring a user communications account for the conversation system. However, automated participants may also perform operations that are not directly tied to contributions of non-subscribing users, and interact with conversations in response to actions of other participants in the conversations and/or interact with conversations in response to external events. For example, services which interact with conversations as automated participants (e.g., via an automated participant server 118) may include: archival services, translation services, spell-check and/or grammar-check services, news or comment aggregation services, attachment modification services, that may be invoked to provide services to other participants (e.g., human participants) of a conversation.
In some implementations, automated participants (e.g., automated participants representing email clients 222 and weblog clients 228, etc.) can read but cannot provide content to a conversation, and thus are just observers. However, in some other implementations, authoring capabilities (the ability to provide content to a conversation) are provided to at least some automated participants (e.g., “email participants” that represent users of email clients and/or “weblog participants” that represent users of weblog clients, spell checking robots, etc.). In other words, in some implementations, at least a subset of the automated participants are treated by conversation servers 130 as full participants which have read/write/modify privileges that are substantially equal to the read/write/modify privileges of non-automated participants (e.g., human participants). It should be understood that the automated participants may interact with the conversation server using either: the same communication protocols as non-automated participants and operate as standard participants, or a special set of communication protocols that are provided specifically for special-purpose automated participants.
Automated participants with authoring capabilities may be used to provide structure for a conversation by generating structured content. Structured content can be broadly defined as content that is added, formatted or managed by an automated participant in accordance with a predefined set of logical instructions (e.g., a computer program stored in a computer readable storage medium). As one example of generating structured content, an automated participant may modify content (e.g., text, formatting, content contribution specific attachments etc.) added to a respective content contribution by non-automated participants. As another example of generating structured content, an automated participant may modify attachments of the conversation (e.g., converting image files attached to the conversation by a non-automated participant into a slideshow or displaying a video player application for displaying an attached video file). In yet another example of generating structured content, an automated participant determines relationships between numerical values in the conversation and generates a table, chart or graph and inserts the table, chart or graph into the conversation. Similarly, in some implementations, an automated participant adds new content contributions to a conversation that is structured (e.g., a table of contents or index for a conversation) without modifying content added to the conversation by a non-automated participant.
In some circumstances, a conversation will include both structured content (e.g., content that is automatically, without non-automated participant intervention, added, reformatted or otherwise managed by automated participants) and unstructured content (e.g., content added, reformatted or otherwise managed by non-automated participants). It should be understood that, as used herein, unstructured content refers to content that does not have structure generated by an automated participant. In other words, even when non-automated participants add content that is organized (e.g., charts, tables, outlines, etc.) this content is considered to be “unstructured content” because the structure is maintained by the non-automated participant(s) without intervention by automated participants. In some embodiments, a respective automated participant will only reformat content in certain portions of the conversation (e.g., structured content contributions/structured content units/structured blips), while other portions of the conversation (e.g., unstructured content contributions/unstructured content units/unstructured blips) are ignored by the respective automated participant and non-automated participants can add content to those portions of the conversation that will not be modified by the respective automated participant and thus will remain unstructured. It should be noted that even when one or more automated participants are ignoring one or more portions of a conversation, other automated participants may still modify the one or more ignored portions of the conversation (e.g., a spell-checker automated participant may check spelling of words in all content contributions of a conversation, even if a list-reformatting automated participant has been instructed to ignore one or more of the content contributions in the conversation).
In some implementations, a respective conversation includes both respective unstructured content added by a respective non-automated participant and respective structured content added by a respective automated participant where the respective structured content was generated by the respective automated participant based at least in part on additional unstructured content added by the respective non-automated participant. For example, a human participant has added a first content contribution describing a new product and a second content contribution including a development timeline for the new product, a product management automated participant converts the second content contribution including the development timeline by generating a “To Do” checklist based on the development timeline and replaces the development timeline with the “To Do” checklist, but leaves the first content contribution describing the new product without modifications. Thus, the exemplary conversation now includes both a modified second content contribution that includes structured content and an unmodified first content contribution that includes unstructured content. In another example, the product management automated participant generates and adds the “To Do” checklist to the conversation without replacing or otherwise modifying the development timeline in the second content contribution.
In some embodiments, a conversation server 130-B includes a front-end or conversation engine 246 for managing conversations and communications with clients 110. Conversation engine 246 manages communications between core components of the conversation server 130 and external components of the conversation system (e.g., other conversation servers 130, automated participant servers 118, application servers 119, etc.). In particular, in some embodiments, conversation engine 246 transmits requests/responses to and from update, access, search/query engine 260 and updates conversation database 262 (described in greater detail below with reference to
Front-end or conversation engine 246 utilizes (or, alternately includes) an update, access, search/query engine 260 to provide participant access to conversations, provide search functions in conversations, and provide search functions for server-specified searches (e.g., a search for conversations in a user's inbox or a search for a conversation associated with a particular webpage, as described in greater detail below with reference to method 1200). In some embodiments, one or more conversation indexes 264 are inverse indexes, mapping words, terms, tags, labels, participants to the conversations with which they are associated (e.g., the conversation that includes the respective word, term, tag, label, participant, etc.). The one or more conversation indexes 264 are used to find conversations in a conversation database 262 that match specified search queries. As content is added to conversations in conversation database 262 the one or more conversation indexes 264 are updated with that content so as to make the added content accessible by the execution of search queries. Conversation database 262 is described in more detail below with reference to
Optionally, conversation server 130 includes an SMTP gateway 242 for facilitating email communication with one or more email servers 224. Conversation server 130-B also typically includes other modules such as one or more auxiliary services (modules, applications or servers) 250 for managing services related to conversations. In some embodiments, auxiliary services 250 include spell checking 252, language translation or localization 256, and/or managing attachments 258 to conversations. In some embodiments, conversation server 130-B also includes online presence services 248, enabling users to know the online status of other users (e.g., other subscribers of the conversation system), as described in greater detail below with reference to
As described in more detail below with reference to
In the discussion below, a subscriber is a user for whom a conversation server 130 (e.g., any conversation server 130 in a set of conversation servers 130 that provide conversation services) maintains a user record or profile (see 402,
It should be understood that in the case where a conversation container includes a single conversation, all of the participants will have access to the content of the conversation. Thus, for simple conversation systems where side conversations are not necessary, conversation containers can be restricted to containing a single conversation. In other words, in some embodiments, conversation container records 302 can be combined with conversation records 310, because each conversation container record 302 includes at most a single conversation record 310.
Conversation database 262 includes a plurality of conversation container records 302-1 to 302-N, each containing the data for a conversation container (e.g., data associated with the conversation(s) from a conversation container). When a respective conversation container has only one conversation, the only information in the corresponding conversation container record 302 is for the single conversation, as represented by one conversation record 310. More generally, a conversation container record 302 includes one or more conversation records 310-1 to 310-R. Each conversation record 310 contains data for a respective conversation, including:
Conversation metadata 322 is metadata for the conversation corresponding to conversation record 310 and identified by conversation identifier 330. In some embodiments, conversation metadata 322 includes a conversation creation timestamp 331 (indicating the date and time the conversation was created), and a list of participants 332 (described in more detail below with reference to
When a conversation container contains more than one conversation, the participant list 332 for the primary conversation of the conversation container will typically include all the participants in all the conversations in the conversation container. However, in some embodiments, private conversations (i.e., conversations other than the primary conversation) in the conversation container can have additional participants that are not participants of the primary conversation. Thus, each of the private conversations in a conversation container will typically have a participant list 332 that includes at least one of the participants in the primary conversation of the same conversation container, and optionally includes one or more participants who are not participants in the primary conversation of the same conversation container.
In addition, when a conversation container contains more than one conversation, a parent ID/insertion position 333 is provided for each of the private conversations, but not for the primary conversation. Parent ID/insertion position 333 identifies the parent of the private conversation, as well as the position in the identified parent conversation at which content of the private conversation should be inserted when viewed by participants of the private conversation. Typically the parent of a private conversation is the primary conversation of the conversation container, but in some instances the parent of a private conversation can be another parent conversation that is higher up in the hierarchy (or graph) of conversations in the conversation container. When a participant of a private conversation views the conversation container that includes the private conversation, the content of both the parent conversation and the private conversation will be seen (assuming the participant is also a participant of the parent conversation). In the less common situation, in which a user is a participant of a private conversation, but is not a participant in the parent conversation, the user will see only the content of the conversation (or conversations) in the conversation container for which they are a participant.
In some embodiments, conversation log 324 records all changes to the conversation, including changes to the content of the conversation as well as to the set of participants and other characteristics of the conversation. Conversation log 324 is accessed when participants ask to see the state of the conversation, or a content unit of the conversation, at one or more points in time. For example, conversation log 324 can be used to reconstruct or review the sequence of edits made to a content unit of the conversation. This is sometimes called “playing back” or “playback” of the conversation. Playback of a conversation can be performed in a variety of ways, including time forward or time backward, and showing updates to just a portion of the conversation or to the entire conversation.
A respective content contribution 326 (also called a content unit, or “blip”) in a conversation can be a message, much like an email message or instant message. Other content contributions 326 in a conversation can be documents (e.g., a report, meeting agenda, etc.), pictures, presentations, audio files, video files, or virtually any other type of electronic document or content. In some embodiments, there are few if any distinctions between email messages and other types of content contributions to a conversation. In some embodiments, the data in a conversation record 310 for each content contribution 326 includes:
In some embodiments, content unit metadata 346 for a content unit 326 includes:
In some embodiments, metadata 346 for a content unit 326 also includes one or more of the following:
Typically, metadata 346 for a content unit 326 includes at least one value (e.g., position 350 or parent identifier 354) that identifies or represents the position of the content unit 326 in the conversation.
A conversation index 264 enables fast access to conversations in the conversation database 262 through searches of the index by update, access, search/query engine 260 (
Another optional flag in per-user conversation state 373 for a respective participant is a reminder flag 377-B. Per-user conversation state 373 also includes a corresponding timestamp indicating the date and time (or pair of timestamps to indicate a range of dates/times) at which to reminder the participant to pay attention to the conversation or a portion thereof, optionally a user ID identifying the user who initiated the reminder (in some embodiments, reminders can be sent by a user not only to themselves, but to other participant(s) in the conversation), and optionally a content range indicator for specifying a portion of the conversation that is the subject of the reminder.
Another optional flag in per-user conversation state 373 for a respective participant is a ping flag 377-C. A ping flag is included in per-user conversation state 373 when another participant has sent a ping (which is a form of notification, or instant message) to the participant (typically an online participant), or when the participant has sent a ping to another participant. The ping flag, when present, indicates to the client application that a ping notification (e.g., a pop-up box) is to be displayed.
Much of the information (e.g., conversation state 373) in each participant record 362 is private to that participant and is not shared with other participants of the conversation or other users in the conversation system. In some embodiments, the cursor position 379 of each participant who is actively editing a content unit or entering new text in a conversation is published to and visible to other participants of the conversation, unless a respective participant has elected to suppress publication of their cursor position, in which case that aspect of the participant's conversation state 373 is not considered to be private to the participant. When there are a plurality of active participants who are editing the same conversation, cursor position information for each of the active participants is transmitted to the clients of the active participants (via their hosting conversation servers). At the client of a respective participant, a plurality of cursor positions (corresponding to a plurality of different participants) are concurrently displayed when the cursor positions are sufficiently close to each other to enable concurrent display.
As described above, in some embodiments, for each respective conversation record 310, conversation server 130 maintains for each respective participant 362 a conversation state 373 of the respective conversation in regard to the respective participant. Conversation server 130 provides to the respective participant (e.g., to a client that is displaying the conversation to the participant) the state of the respective conversation in regard to the respective participant. In some embodiments, this includes providing to the participant (e.g., to the client being used by the participant) the read status of the content units of the respective conversation in regard to the participant (i.e., indicating which content units have already been read or viewed (in their current state) by the participant, and which have not). In some embodiments, providing conversation state 373 of the respective conversation in regard to the respective participant includes private labels 378, specified by the respective participant for the respective conversation.
In some embodiments, providing state 373 of the respective conversation in regard to the respective participant includes providing, in accordance with instructions from the participant, metadata (e.g., ignore flag 377-A) to ignore the respective conversation. This provides a participant with an option to manage conversations in accordance with a rule, in effect to archive conversations, and to reduce congestion in a conversation viewer. For example, when a participant marks a conversation with a system defined label of “ignore” or “mute,” ignore status flag 377-A for the participant (for the marked conversation) is set, and the conversation is thereafter treated (on behalf of this particular participant) much like an archived message or conversation. Other participants of the conversation may continue to see the conversation in their list of active conversations if they have not marked the conversation with the “ignore” label.
In some embodiments, the per-user conversation state 373 for each participant of each conversation is stored in conversation database 262, as shown in
As described in more detail below, in some embodiments, conversation server 130 stores, for each respective subscriber, a contact list (416, described in
When a conversation is sent to a client (e.g., 110-B in
Conversation list 414 associated with a user includes a plurality of user-conversation records 434, each record relating to a conversation in which the user is a participant. Each user-conversation record 434 includes:
As noted above, in some embodiments the conversation system includes a separate per-user inverse index 424 for each user of the conversation system; each such index 424 is an index that maps the terms, labels, tags, etc. of the conversations in which a user is participant to the conversations (and optionally, to the content units with the conversations, or locations within the conversations) containing those terms, labels, tags, etc. These per-user indices enable fast indexing and fast searching of the conversations in which a user is a participant. In some embodiments, additional indices (sometimes called “big wave” indices) are used to provide fast indexing and access to “big wave” conversations having large numbers (e.g., more than a threshold number, such as 500 or 100) of participants. In these embodiments, the content of “big wave” conversations is not indexed in the per-user inverse indices 424, and is instead indexed in one or more “big wave” indices. Similarly, in some embodiments in which groups of users participate in conversations as groups, additional per-group indices are used to index those conversations and to provide fast searching of those conversations; and the conversations (if any) in which a respective user participates only as a group member are not included in the user's per-user inverse index 424. Thus, when a user performs a search for conversations satisfying a user-specified query, multiple indices may be searched, in which case the search results from the multiple indices are merged (and optionally sorted and/or reduced) prior to returning the search results to the requesting user.
In some embodiments, conversation server 130 provides the same content of a conversation to all participants of the conversation, and provides each online participant with online presence information for the other participants in the same conversation. In some embodiments, the server allows a participant of a conversation to disable publication of their online presence information to other participants in the conversation. In some embodiments, the server allows a participant of a conversation to selectively enable publication of their online presence information to other participants in the conversation (e.g., allowing publication of the participant's online presence only to users designated by the participant; or alternately, disabling publication of the participant's online presence to users specifically designated by the participant).
In some embodiments, conversation server 130 provides the same content to each participant, formats content of the conversation to be compatible with one or more content types that a client 110 associated with a respective participant has been configured to receive, and transmits the formatted content to the client.
In some embodiments, when delivering the content of a conversation to certain clients (e.g., a cell phone or PDA), conversation server 130 formats the content by compressing multimedia data associated with the content (e.g., to reduce bandwidth requirements). In some embodiments, the server provides a subset of multimedia data associated with the content (e.g., a thumbnail image, or short audio/video clip) to the client. In some embodiments, the conversation server removes multimedia data associated with the content (e.g., strips out multimedia and just provides text) that is delivered to the client.
In some embodiments, conversation server 130 authenticates a user using authentication information 428 prior to providing content from conversations to the user.
In some embodiments, conversation server 130 sends content from conversations in which a respective user is a participant to a weblog (e.g., weblog server 226 or weblog client 228), specified (e.g., by Blog URL 430) in user record 402 for that user. When a respective participant in a conversation is an automated participant, content of the conversation is sent to the automated participant. The automated participant may represent a weblog, an email server or account, or a service provider such as a translation service, spelling checking service, or the like in the conversation.
Conversation server 130 provides (506) the same content from a conversation to all the participants of the conversation. In some embodiments, the server also provides (508) online presence information of each of the plurality of participants in the conversation to other participants in the conversation. The server receives (510) content from each of a plurality of participants of the conversation and transmits the received content to the other participants of the plurality of participants.
Conversation server 130 provides (512), upon an additional participant being added to the conversation, the same content of the conversation to the additional participant as provided to the identified set of participants, and adds the additional participant to the identified set of participants. As noted above, when the additional participant is using a client (e.g., 110 in
In some examples, participants can participate in “private conversations” (as described in greater detail above with reference to
In some embodiments, conversation server 130 formats (514) content of the conversation to be compatible with one or more content types that a client associated with a respective participant has been configured to receive, and transmits the formatted content to the client (e.g., 110 in
In some embodiments, conversation server 130 receives (518) a search request (often called a query or search query) from a participant, and provides to the participant a search result, including content from at least one of the plurality of conversations, in response to the search request. Alternately, or in addition, in response to the received search request the server provides (520) to the participant a search result that includes a list of one or more conversations that match the search request. In some embodiments, the search request is processed by search/query engine 260 (
In some embodiments, the metadata maintained for a conversation with respect to a particular participant includes (536) metadata (e.g., ignore flag 377-A in
In some embodiments, conversation server 130 stores (540), for each respective participant, a contact list associated with the respective participant. In some embodiments, the server verifies (542) (using authentication information 428) that the participant is authorized to receive the content of a conversation, prior to providing content to a participant.
In some embodiments, conversation server 130 maintains (544) a set of participants of a respective conversation, including one or more subscribers of the conversation system and an email participant identified by an email address. In some embodiments, conversation server 130 maintains (546) a set of participants of a respective conversation, including one or more subscribers of the conversation system and a weblog on which content of the conversation is posted.
Conversation server 130 receives (566) content from respective participants of the conversation and transmits to the clients associated with other participants of the conversation at least a portion of the received content. Conversation server 130 also provides (568), upon an additional participant being added to the conversation, to a client associated with the additional participant all content of the conversation that the client associated with the additional participant has been configured to receive.
Conversation server 130 also provides (576), upon an additional participant being added to the conversation, all the content of the conversation to a client associated with the additional participant, or alternately, all content of the conversation that the client associated with the additional participant has been configured to receive. In some embodiments, conversation server 130 provides (578) a uniform view of the conversation to a plurality of the participants.
Whenever a participant changes online status (e.g., goes from offline to online, by logging into the conversation system), the change in status is detected by a respective status monitor 134 (e.g., a status monitor in the conversation server assigned to the participant). A status monitor 134 at the conversation server to which the participant is assigned receives a message or otherwise detects the change in online status of that participant to “online” (or “active,” “busy,” or whatever status is appropriate). Furthermore, a status collector 136 at the conversation server gathers the online status of the contacts in that participant's contact list 416. While some of the contacts in the participant's contact list may be assigned to the same conversation server, other contacts in the participant's contact list are assigned to other conversation servers.
The status collector 136 of the conversation server to which the participant is assigned gathers the online status of the participant's contacts, including those assigned to other conversation servers, and forwards at least a portion of the collected status information to the participant (i.e., to the client or system currently being used by the participant). In some embodiments, the status collector broadcasts requests for status information of the participant's contacts to the other conversation servers, and the conversation servers to which the contacts are assigned respond to the requests. In some other embodiments, the status collector determines the conversation servers to which the contacts are assigned and sends requests for status information to those conversation servers. In some embodiments, the assignments of participants to conversation servers may be determined by reference to an index of all participants, a copy of which may be stored in all of the conversation servers or a subset thereof.
For example, if a participant A1 of the first set 138-A of participants, assigned to conversation server 130-A, changes online status from offline to online, a client application at the client being used by the participant A1 sends a message to the conversation server 130-A with which participant A1 is associated announcing that participant A1 is online. Status monitor 134-A at conversation server 130-A receives the message and updates the status of the participant A1 to online. Status monitors 134 of other conversation servers either do not receive this message, or ignore it because the participant A1 is not assigned to those other conversation servers. Status collector 136-A at Conversation server 130-A obtains a list of the contacts for the participant A1 (e.g., by accessing contact list 416 for participant A1). Using that list of contacts, status collector 136-A gathers status information from the conversation servers to which the contacts are assigned. Thus, if a contact is assigned to conversation server 130-A, then status collector 136-A accesses the contact's status information stored at conversation server 130-A. If a respective contact is assigned to conversation server 130-B, then conversation server 130-A communicates with conversation server 130-B to get the status information for the respective contact. A similar procedure occurs if a respective contact is assigned to conversation server 130-C.
Memory 706 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices. Memory 706 optionally includes one or more storage devices remotely located from the CPU(s) 702. Memory 706, or alternately the non-volatile memory device(s) within memory 706, includes a non-transitory computer readable storage medium. In some embodiments, memory 706 or the computer readable storage medium of memory 706 stores the following programs, modules and data structures, or a subset thereof:
Conversation engine 246 may include the following modules, or a subset thereof:
In some embodiments, conversation management modules 728 include the following modules, or a subset thereof:
Each of the above identified elements may be stored in one or more of the previously mentioned memory devices, and corresponds to a set of instructions for performing a function described above. The above identified modules or programs (i.e., sets of instructions) need not be implemented as separate software programs, procedures or modules, and thus various subsets of these modules may be combined or otherwise re-arranged in various embodiments. In some embodiments, memory 706 may store a subset of the modules and data structures identified above. Furthermore, memory 706 may store additional modules and data structures not described above.
Although
Memory 806 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices. Memory 806 optionally includes one or more storage devices remotely located from the CPU(s) 802. Memory 806, or alternately the non-volatile memory device(s) within memory 806, includes a non-transitory computer readable storage medium. In some embodiments, memory 806 or the computer readable storage medium of memory 806 stores the following programs, modules and data structures, or a subset thereof:
In some embodiments, the conversation web page 815 includes a client conversation module 818 or other client assistant that is embedded in web page 815. Client conversation module 818 comprises executable instructions that are executed by client 110; for example, client conversation module 818 may include instructions that are executed by a virtual machine (e.g., a Java virtual machine) that is part of browser 814. Conversation web page 815 includes a conversation user interface having icons, which when activated by a user, execute various tasks to enable a user to request a list of conversations, select a conversation for display, view various portions of a conversation, participate in the conversation (e.g., by adding content to or editing content of the conversation), start new conversations, download attachments, and so on. Icons in the conversation user interface may function as links to executable procedures and instructions in client conversation module 818. The aforementioned conversation record 820 and conversation list 826 may, in some embodiments, be downloaded in response to instructions sent by a client conversation module 818, or other client assistant embedded in web page 815, to a conversation server.
Conversation record 820 comprises a client version or subset of conversation record 310, described above with respect to
Each of the above identified modules corresponds to a set of instructions for performing the functions described above. The above identified modules or programs (i.e., sets of instructions) need not be implemented as separate software programs, procedures or modules, and thus various subsets of these modules may be combined or otherwise re-arranged in various embodiments. In some embodiments, memory 806 or the computer readable storage medium of memory 806 may store a subset of the modules and data structures identified above. Furthermore, memory 806 or the computer readable storage medium of memory 806 may store additional modules and data structures not described above.
Memory 906 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices. Memory 906 optionally includes one or more storage devices remotely located from the CPU(s) 902. Memory 906, or alternately the non-volatile memory device(s) within memory 906, includes a non-transitory computer readable storage medium. In some embodiments, memory 906 or the computer readable storage medium of memory 906 stores the following programs, modules and data structures, or a subset thereof:
Each of the above identified elements may be stored in one or more of the previously mentioned memory devices, and corresponds to a set of instructions for performing a function described above. The above identified modules or programs (i.e., sets of instructions) need not be implemented as separate software programs, procedures or modules, and thus various subsets of these modules may be combined or otherwise re-arranged in various embodiments. In some embodiments, memory 906 may store a subset of the modules and data structures identified above. Furthermore, memory 906 may store additional modules and data structures not described above.
Although
Memory 1006 includes high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices. Memory 1006 optionally includes one or more storage devices remotely located from the CPU(s) 1002. Memory 1006, or alternately the non-volatile memory device(s) within memory 1006, includes a non-transitory computer readable storage medium. In some embodiments, memory 1006 or the computer readable storage medium of memory 1006 stores the following programs, modules and data structures, or a subset thereof:
Each of the above identified elements may be stored in one or more of the previously mentioned memory devices, and corresponds to a set of instructions for performing a function described above. The above identified modules or programs (i.e., sets of instructions) need not be implemented as separate software programs, procedures or modules, and thus various subsets of these modules may be combined or otherwise re-arranged in various embodiments. In some embodiments, memory 1006 may store a subset of the modules and data structures identified above. Furthermore, memory 1006 may store additional modules and data structures not described above.
Although
Other Applications
Another application that may be associated with the conversation server hosting a respective conversation includes a contextual spell checker and correction application. Such an application can be used to find common misspellings, and to disambiguate intentionally defined words. Such an application may use an error model to determine if an work is spelled or used correctly. The model may find common errors based on letter reversal, phonetic similarity, location in a conversation or letter, or using other means. The application may provide on-the-fly, context based text correction. In some embodiments, the application provides a user-specific overlay of words that a user frequently uses or that the user has defined. In some embodiments, the application may insert a tag with a suggestion for a word that it considers to be incorrectly spelled, such that any participant (not just the author) can address and correct the word, if necessary.
Another application that may be associated with the conversation server hosting a respective conversation includes a contextual name display, using context-dependent disambiguation. In some embodiments, this disambiguation may provide space efficiency when displaying names. For example, a close friend or work colleague may be displayed using a first name only or a picture, whereas a stranger may be displayed with full name, title, etc. A set of rules (defined by the system or by the user or both) may be used to determine who to display and in what manner.
Another application that may be associated with the conversation server hosting a respective conversation includes a language translation (machine translation) application. This machine translation application may use the spell checking and/or a context sensitive dictionary to translate between languages. In some embodiments, these (and other) applications use an application protocol interface (API) to interact with the conversation server hosting the conversation. In some embodiments, the application allows a participant to reserve a namespace for that participant's personal applications, which the participant may share with other participants.
The conversation server 130 creates (1102) hosted conversation (e.g., in response to a request from a client or an automated participant server 118 to create a new conversation). Participants can be added to the conversation in many different ways. Typically the user that initiated the creation of the conversation will be the initial participant in the conversation, and that initial participant will be able to add more participants. However, in some embodiments, participants are added to conversations automatically (e.g., based on content of the conversation or security groups, etc.). As discussed in greater detail below, conversation server 130 interacts with different types of participants in different ways. Thus, when a participant is added to the conversation, conversation server 130 will typically determine the type of participant (e.g., whether the participant is a standard participant or a special-purpose automated participant). In some embodiments, the participant provides this information to conversation server 130. Thus, in some embodiments, a client 110 operated by a human user will register (1104) as a standard participant of the hosted conversation, while an automated participant server 118 will register (1105) as a special-purpose automated participant of a hosted conversation on conversation server 130.
Conversation server 130 adds (1106) a plurality of participants to the hosted conversation including the initial participant and any subsequently added participants. These participants may include one or more special-purpose automated participants and one or more standard participants. In some embodiments, a standard participant is (1108) a participant that responds dynamically to changes in the conversation. It should be understood that, in some embodiments, only human participants are considered to be standard participants. However, in some embodiments, standard participants include a computer program (e.g., a standard automated participant) that includes instructions to dynamically interact with the conversation in a manner that is indistinguishable from the manner of interaction of a human participant. In other words, the standard automated participant is informed of changes to the conversation and makes changes to the conversation in the same way that human participants are informed of changes to the conversation and make changes to the conversation.
In some embodiments a special-purpose automated participant is (1110) a computer-implemented participant that operates in accordance with instructions to perform one or more predefined operations in response to detecting predefined trigger criteria. Thus, the special-purpose automated participant does not interact with the conversation in the same manner as a human participant. Rather, the special-purpose automated participant performs a predefined function within the conversation. For example, the special-purpose automated participant may perform operations that enable the conversation to be synchronized with data hosted at a third-party webservice (e.g., 121 in
From time to time conversation server 130 will receive a request to modify a conversation from a first participant. Operations 1112-1126 are described below with reference to a set of conditions in which the first participant is a standard participant (e.g., a human participant).
Conversation server 130 stores (1112) a hosted conversation having a plurality of participants, the participants including one or more special-purpose automated participants and one or more standard participants. In other words, both human participants and automated participants are participants in the same conversation. The client (e.g., 110) associated with the standard participant receives (1114) preliminary edits to the conversation from a standard participant (e.g., a human user edits a conversation contribution, adds a new conversation contribution, adds an attachment, etc.). The client 110 performs (1116) the preliminary edits on the conversation (e.g., a client-side copy of the conversation), and transmits (1118) the preliminary edits to conversation server 130. For example, the preliminary edits are specific edits to the text (or other content) of the conversation that was presented (e.g., displayed) to the user of client 110 (e.g., editing the sentence “First of all we should make travel reservations,” to read “First of all we should make plane reservations” by deleting the word “travel” and typing the word “plane.”). In some implementations, the edits are index and range based (e.g., delete characters 1 through 5 and insert “Second” between character 0 and 6).
Conversation server 130 receives (1120) the request to modify the conversation from the first participant, which, when the first participant is a standard participant, includes an indication of the preliminary edits that were performed on the conversation by the first participant. In some embodiments (e.g., when the first participant is a standard participant), the preliminary edits are (1121) edits that were performed on a client-side copy of the conversation. In contrast, when the first participant is a special-purpose automated participant, the request to modify the conversation includes a request to perform an edit operation on a server-side, concurrency-resolved copy of the conversation, as described in greater detail below. Edits that are initially performed locally at a respective client 110 need to be combined with edits from other participants of the conversation at conversation server 130, and thus such edits are only preliminary edits until they are concurrency-resolved. An exemplary process for generating a concurrency-resolved set of edits is described (see
For example, if a user went through and replaced all occurrences of the word “first” with the word “second” and submitted those changes, and a second user added a sentence reading “First of all we should make plane reservations,” the concurrency-resolved conversation stored at conversation server 130 would have changed all occurrences of the word “first” to “second,” but would leave the newly added sentence alone, as that sentence was not previously part of the client-side conversation (e.g., the new sentence was not previously displayed to the user and thus was not edited by the user).
After receiving the request to modify the conversation (e.g., including the preliminary edits), conversation server 130 determines (1122) a set of edits that update the conversation in accordance with the request to modify the conversation, which, when the first participant is a standard participant, includes updating the conversation in accordance with the preliminary edits that were performed on the conversation by the first participant. In other words, conversation server 130 attempts to make the specific preliminary edits that were made to the client-side copy of the conversation to the server-side conversation. However, when one of the preliminary edits conflicts with another edit from another participant (e.g., the edited content has also been edited by another user or deleted, etc.), conversation server 130 may make an edit that is a combination of the edits from the two participants or may make the edit from the other participant instead of making the preliminary edit from the first participant.
Conversation server 130 sends (1124), to a second participant, the set of edits that update the conversation to an updated state, which, when the first participant is a standard participant, include concurrency-resolved edits that transform the conversation to the updated state. In some embodiments, the concurrency-resolved edits are participant-specific (e.g., each set of concurrency-resolved edits transforms the conversation from a prior state associated with a respective participant to the updated state). Thus, if the second participant has edited the conversation, the concurrency-resolved edits sent to the second participant include edits based on preliminary edits from other participants. In some embodiments, the set of edits are sent (1126) to the second participant in real time. In other words, there is no more than a nominal delay (e.g., less than 0.5 seconds, 1 second, 2 seconds, or the minimum time necessary to receive the request, generate the set of edits, and transmit the set of edits to the second user) between the time at which the request to modify the conversation is received from the standard participant and the time at which the set of edits are sent to the second participant.
From time to time conversation server 130 receives a request to modify a conversation from a first participant. Operations 1128-1198 are described with reference to a set of conditions where the first participant is a special-purpose automated participant.
Conversation server 130 stores (1128) the hosted conversation having a plurality of participants. The participants including one or more special-purpose automated participants and one or more standard participants. In other words, both human participants and automated participants are participants in the same conversation. After the special-purpose automated participant is associated with the conversation, automated participant server 118 associated with the special-purpose automated participant identifies (1130) a change in content at a third-party webservice (e.g., 121 in
After identifying the change, automated participant server 118 determines (1132) whether the change in content at the third-party webservice meets predefined conversation update criteria for the conversation. If the predefined conversation update criteria are (1133) not met, automated participant server 118 waits until another change is identified in the content at the third-party webservice. However, when the predefined conversation update criteria have (1134) been met, automated participant server 118 determines (1136) a set of one or more operations to update the conversation in accordance with the change in content at the third-party webservice. For example, the update could include adding content (e.g., video, audio, images, text) to the conversation, modifying content that already exists in the conversation (e.g., transmitting revisions to content that is synchronized between the conversation and the third-party webservice), and/or deleting content from the conversation.
After determining the set of one or more operations, automated participant server 118 sends (1138) the set of operations to conversation server 130. Conversation server 130 receives (1140) a request to modify the conversation from a first participant, which, when the first participant is a special-purpose automated participant, includes a request to perform the set of one or more operations on the conversation. In some embodiments, when the first participant is a special-purpose automated participant, the request to perform the operation is (1141) a request to perform an edit operation on a server-side, concurrency-resolved copy of the conversation. In contrast, when the first participant is a standard participant, the request to modify the conversation includes preliminary edits performed on a client-side copy of the conversation, as described in greater detail above. In other words, the operation determined by automated participant server 118 is sent to conversation server 130 to be performed on whatever is the most current copy of the hosted conversation at conversation server 130. Thus, if the conversation was updated after the request to perform the operation was sent (e.g., based on edits received from another user), the operation will be performed on the updated conversation at conversation server 130. For example, if the operation is to replace all occurrences of the word “first” with the word “second,” and after the request is sent a different user adds the sentence “First of all we should make plane reservations,” the operation would be performed on the updated conversation including the added sentence, so that the added sentence would be modified to read “Second of all we should make plane reservations.”
It should be understood that, in some embodiments, performing operations instead of sending a set of preliminary edits results in more stable and predictable interactions with the conversation and conversation server 130. Due to the fact that preliminary edits can conflict with edits by other participants and are thereafter typically concurrency-resolved, these preliminary edits are not always performed by conversation server 130 in a predictable manner. For example, index and range based edits indicate particular locations in the conversation where edits are to occur. However, if those particular locations are modified (e.g., as a result of edits by other participants), it may not be possible to perform one or more of the preliminary edits. In contrast, operations that are performed without using an index as a reference are more robust and can be performed without regard to edits received from other participants. In one embodiment, respective operations each include a selector and an action. The selectors indicate how elements (e.g., text, images, lines, characters, etc.) of the conversation are to be selected for modification (e.g., all “x,” first “x,” at (x), range (x, y)). The actions indicate what is to be done to the element of the conversation selected in accordance with the selector (e.g., insert, insertAfter, replace, delete, annotate, etc.). Thus, for example, an operation such as replacing all text strings equal to “foo” with a text string equal to “bar” can be performed without separately referencing the index location of each instance of “foo” in the conversation, as would be required if the request to modify the conversation used preliminary edits performed on a client-side copy of the conversation to specify the modifications, as described in greater detail above.
In some embodiments, the request to perform the operation on the conversation is received (1142) in response to an event external to conversation server 130. In other words, in these embodiments, the request is not received in response to any communication from conversation server 130, but is, instead is received in response to a communication from a third-party webservice (e.g., 121 in
After receiving the request to modify the conversation, conversation server 130 determines (1144) a set of edits that update the conversation in accordance with the request to modify the conversation, which, when the first participant is a special-purpose automated participant, includes performing the operation on the conversation. Subsequently, conversation server 130 sends (1146) the set of edits to a second participant that update the conversation to an updated state, which, when the first participant is a special-purpose automated participant, includes edits that update the conversation, in accordance with the operation, to the updated state. In some embodiments, the set of edits are sent (1148) to the second participant in real time. In other words, there is no more than a nominal delay (e.g., less than 0.5 seconds, 1 second, 2 seconds, or the minimum time necessary to receive the request, generate the set of edits, and transmit the set of edits to the second user) between the time at which the request to modify the conversation is received from the special-purpose automated participant and the time at which the set of edits are sent to the second participant. Moreover, it should be understood that, in some embodiments, the edits are sent out in real-time without regard to whether the request to modify the conversation was a request received from a standard participant or a request received from a special-purpose automated participant.
In some embodiments, when the first participant is a special-purpose automated participant, and the first participant is in communication with a third-party webservice, the request to perform an operation on the conversation is a request to add third-party webservice content, from the third-party webservice, to the conversation; and the set of edits that are sent to the second participant update (1150) the conversation by adding the third-party webservice content to the conversation. For example if the third-party webservice is a video hosting service (e.g., YouTube), the special-purpose automated participant may retrieve a hosted video or comments on the hosted video and add the video or the comments to the conversation via automated participant server 118.
In some embodiments, after sending the set of edits to the second participant, conversation server 130 receives (1152), from the second participant, a reply to the third-party webservice content. In response to the reply, conversation server 130 updates (1154) the conversation, and subsequently determines (1156) whether the updated conversation meets predefined notification criteria for the first participant. If the predefined notification criteria are (1157) not met, conversation server 130 waits until the conversation is updated again. However, when the updated conversation meets (1158) predefined notification criteria, conversation server 130 sends (1160) at least a predefined portion of the conversation to the first participant. In some embodiments, conversation server 130 additionally receives a response from the special-purpose automated participant corresponding to the reply.
In some embodiments, after sending the set of operations to conversation server 130, automated participant server 118 receives (1162), in response to the set of operations, a reply (e.g., the updated portion of the conversation), and sends (1164) the reply to the third-party webservice. In some embodiments, the third-party webservice is (1166) a media sharing application (Twitter, Google Buzz, Facebook, YouTube, etc); the content from the third-party webservice is a comment on media from the media sharing application; and the reply includes a response to the comment. In one example in which the third-party webservice is a comments application for YouTube videos, when a comment is added to a YouTube video, the comment is added to the conversation by a special-purpose automated participant that is monitoring the YouTube video for comments, and the updated conversation (including the comment) is sent to a human participant (e.g., the second participant). Continuing this example, if the human participant replies to the comment in the conversation, the special-purpose automated participant detects the comment and transmits the reply along to the YouTube comment application, where it is added as a reply to the comment in the YouTube comment application.
In other words, in some embodiments, the special-purpose automated participant synchronizes messages between the third-party webservice and the conversation at conversation server 130. By serving as a conduit for relaying content back and forth between the conversation and the third-party webservice, the special-purpose automated participant provides substantial advantages both to users of the third-party webservice as well as to users of the conversation system. In particular, a user of the third-party webservice can effectively participate in the conversation without ever directly communicating with conversation server 130, by interacting with the third-party webservice. Similarly, the first participant can effectively participate in discussions taking place at the third-party webservice without ever directly communicating with the third-party webservice, by interacting with the conversation at conversation server 130.
In some embodiments, the special-purpose automated participant is capable of serving as a proxy for users of the third-party webservice. In other words, automated participant server 118 can interact with conversation server 130 on behalf of a user of the third-party webservice. Typically, when the special-purpose automated participant is proxying for a user of a third-party webservice, it is advantageous to provide some information about the user for whom the special-purpose automated participant is proxying. Thus, in some of these embodiments, when the first participant is a special-purpose automated participant, the request to perform an operation on the conversation (e.g., the request described in greater detail above with reference to operation 1140) includes (1168) a request to perform the operation using a first identifier that uniquely identifies a first user of a third-party webservice.
Subsequently, when automated participant server 118 receives (1170) an additional request from a second user of the third-party webservice, automated participant server 118 transmits (1171) the additional request to conversation server 130 using a second identifier that uniquely identifies the second user of the third-party webservice. Conversation server 130 thereafter receives (1172) the additional request from the first participant (i.e., the special-purpose automated participant), where the additional request is a request to perform an operation using the second identifier that uniquely identifies the second user of the third-party webservice. In other words, a single special-purpose automated participant is able to proxy for two or more different users of a same respective third-party webservice. In some embodiments, the special-purpose automated participant is replicated for each user that is being proxied for by the special-purpose automated participant. As one example, the special-purpose automated participant's identifier is “robotID@appspot.google.com,” the first user's identifier is “user1@gmail.com,” the second user's user identifier is “user2@gmail.com,” and the first participant has two aliases: “user1+robotID@appspot.google.com” and “user2+robotID@appspot.google.com.” In this exemplary embodiment, each of these special-purpose automated participant aliases operates as a distinct participant in the conversation, even though the modifications made by the special-purpose automated participant are made by the same respective special-purpose automated participant (e.g., communications flow through the same automated participant server). Furthermore, each alias of the special-purpose automated participant can have its own set of permissions, its own avatar, its own user profile, etc., and can operate independently of the other aliases of the special-purpose automated participant. A user profile may include one or more of a user avatar (an image selected by the user to represent the user), phone numbers, physical addresses (sometimes called geographical addresses or mailing addresses), email addresses, website links, biographical information, interests, etc.
It should be understood that conversation server 130 may request a profile associated with a participant. A standard participant will typically have a user account with a conversation server in the conversation system and thus the user profile for the standard participant can be requested directly through the conversation system. However, as described in greater detail above, in some embodiments, automated participant server 118 serves as a proxy for users of the third-party webservice, and the first participant participates in the conversation using (1174) an identifier that includes a portion that identifies the first participant as a special-purpose automated participant and a portion that identifies the individual user of the third-party webservice. Typically, the user of the third-party webservice will not have a user account with any of the conversation servers of the conversation system, and thus the profile of the user of the third-party webservice will not be available to be requested by conversation server 130. In some of these embodiments, conversation server 130 sends (1176), to the first participant (e.g., the special-purpose automated participant), a request for a profile associated with the first identifier.
In some circumstances, the third-party webservice maintains user profiles for its users. Thus it is advantageous for automated participant server 118 to be able to use this profile information in its interactions with the conversation on behalf of its users. Automated participant server 118 receives (1178) the request for the profile associated with the identifier (e.g., user1+robotID@appspot.google.com) used by the special-purpose automated participant to interact with the conversation, and requests (1179) the profile for the first user from the third-party webservice. Subsequently, automated participant server 118 receives (1180) the requested profile for the first user from the third-party webservice and transmits (1182) the profile (or information extracted from the profile) to conversation server 130 for use as a profile for the special-purpose automated participant when the special purpose automated participant is using the identifier (e.g., user1+robotID@appspot.google.com). Conversation server 130 receives (1184), in response to the request sent to automated participant server 118, the profile information of the first user of the third-party webservice (e.g., the user profile for the first user maintained at the third-party webservice). In some embodiments, this information includes a complete profile of the first user, while in other embodiments only a subset (e.g., a publicly available portion) of the first user's user profile is sent to automated participant server 118. It should be understood that this process could be repeated any number of times for any number of different users for which the special-purpose automated participant is proxying.
While the preceding embodiments have primarily discussed active participation by the special-purpose automated participant, where the special-purpose automated participant initiates operations relating to the conversation in response to events that are external to the conversation system, the special-purpose automated participant can also be a passive participant. In many circumstances the special-purpose automated participant will also perform operations in response to events that occur within the conversation system. In other words, in some embodiments, after conversation server 130 updates (1186) the conversation, conversation server 130 determines (1188) whether the updated conversation meets predefined notification criteria for the first participant. If the predefined notification criteria are (1189) not met, conversation server 130 waits until another update to the conversation occurs. However, when the updated conversation meets (1190) predefined notification criteria, conversation server 130 sends (1192) at least a predefined portion of the conversation to the first participant. Automated participant server 118 receives (1194) the predefined portion of the conversation, determines whether a response is required and, if so, what kind of response.
When a response is required, automated participant server 118 generates (1196) a response based on the predefined portion of the conversation. Conversation server 130 subsequently receives (1198) the response from the first participant corresponding to the predefined portion of the conversation. For example, the special-purpose automated participant may be configured to respond to a new participant (e.g., user3) being added to the conversation by adding a participant specific welcome message to the participant (e.g., “Hello user3, welcome to the conversation!”). In some embodiments, the special-purpose automated participant provides the conversation system with automated participant notification criteria, which indicate the circumstances under which the special-purpose automated participant is to be notified of changes in the conversation. For example, the special-purpose automated participant may request notification from conversation server 130 when content using a specific keyword is added to a conversation or when a specific participant creates a new conversation or adds content to a preexisting conversation.
While the preceding embodiments have been described with respect to a single request from a standard participant or a special-purpose automated participant (e.g., either various ones of operations 1112-1126 are performed or various ones of operations 1128-1198 are performed), it should be understood that a conversation may include both one or more standard participants and one or more special-purpose automated participants. Thus, it is possible for both types of participants to make requests regarding the same conversation, as described in greater detail below. In other words, in some embodiments, a request from a standard participant is received in addition to a request from a special-purpose automated participant (e.g., various ones of operations 1112-1126 are performed in addition to various ones of operations 1128-1198). More specifically, in some embodiments, conversation server 130 stores a hosted conversation including a plurality of participants, the participants including one or more special-purpose automated participants and one or more standard participants, receives, from a standard participant, an indication of edits that were performed on the conversation; updates the conversation in accordance with the edits (so as to incorporate the edits by the standard participant and other edits by other standard participants with concurrency control); and sends, to one or more of the standard participants, edits to update the conversation to transform the conversation to a current version (so as to make the conversation current). Additionally, in these embodiments, conversation server 130, receives, from a special-purpose automated participant (e.g., via an automated participant server 118), a request to perform an operation on the conversation; performs the operation on the current version of the conversation; and sends, to one or more of the standard participants, a set of edits to update the conversation in accordance with the operation.
Note that details of other processes described herein with respect to method 500, (e.g.,
The foregoing description, for purpose of explanation, has been described with reference to specific embodiments. However, the illustrative discussions above are not intended to be exhaustive or to limit the invention to the precise forms disclosed. Many modifications and variations are possible in view of the above teachings. The embodiments were chosen and described in order to best explain the principles of the invention and its practical applications, to thereby enable others skilled in the art to best utilize the invention and various embodiments with various modifications as are suited to the particular use contemplated.
Byttow, David Mark, Prasetya, Marcel Adi, Osinga, Douwe M.
Patent | Priority | Assignee | Title |
10050918, | Mar 27 2015 | International Business Machines Corporation | Dynamic thread management for online conversations |
10373119, | Jan 11 2016 | Microsoft Technology Licensing, LLC | Checklist generation |
10614418, | Feb 02 2016 | Ricoh Company, LTD; Ricoh Company, Ltd. | Conference support system, conference support method, and recording medium |
10817553, | Jul 26 2017 | Rovi Guides, Inc. | Methods and systems for playing back indexed conversations based on the presence of other people |
10838588, | Oct 18 2012 | GUMMARUS, LLC | Methods, and computer program products for constraining a communication exchange |
10841258, | Oct 18 2012 | GUMMARUS, LLC | Methods and computer program products for browsing using a communicant identifier |
10887263, | Mar 27 2015 | International Business Machines Corporation | Dynamic thread management for online conversations |
10897369, | Oct 22 2012 | International Business Machines Corporation | Guiding a presenter in a collaborative session on word choice |
10904178, | Jul 09 2010 | GUMMARUS, LLC | Methods, systems, and computer program products for processing a request for a resource in a communication |
10944711, | Mar 28 2019 | Microsoft Technology Licensing, LLC | Paginated method to create decision tree conversation |
11210631, | Jan 11 2016 | Microsoft Technology Licensing, LLC | Checklist generation |
11315544, | Jun 25 2019 | International Business Machines Corporation | Cognitive modification of verbal communications from an interactive computing device |
11625681, | Feb 02 2016 | Ricoh Company, Ltd. | Conference support system, conference support method, and recording medium |
11671467, | Jun 24 2021 | Avaya Management L.P.; AVAYA MANAGEMENT L P | Automated session participation on behalf of absent participants |
11777880, | Sep 16 2020 | DROPBOX, INC | Messaging client application integrated with a content management system |
11960516, | Jul 26 2017 | Rovi Guides, Inc. | Methods and systems for playing back indexed conversations based on the presence of other people |
8862679, | Apr 18 2014 | SECRET, INC | Displaying comments on a secret in an anonymous social networking application |
9460073, | Feb 27 2013 | GOOGLE LLC | Systems and methods for mutations and operational transforms in a collaborative spreadsheet environment |
9489367, | Feb 27 2013 | GOOGLE LLC | Systems and methods for mutations and operational transforms in a collaborative spreadsheet environment |
9646001, | Sep 19 2011 | Microsoft Technology Licensing, LLC | Machine translation (MT) based spoken dialog systems customer/machine dialog |
9720897, | Feb 27 2013 | GOOGLE LLC | Systems and methods for mutations and operational transforms in a collaborative spreadsheet environment |
9779005, | Jun 24 2014 | CA, Inc. | Analyzing log streams based on correlations between data structures of defined node types |
Patent | Priority | Assignee | Title |
5671428, | Aug 28 1991 | Kabushiki Kaisha Toshiba | Collaborative document processing system with version and comment management |
6006239, | Mar 15 1996 | Microsoft Technology Licensing, LLC | Method and system for allowing multiple users to simultaneously edit a spreadsheet |
6181736, | Mar 25 1997 | MCLAUGHLIN, THOMAS J | Network communication system |
6212548, | Jul 30 1998 | TUMBLEWEED HOLDINGS LLC | System and method for multiple asynchronous text chat conversations |
6693652, | Sep 28 1999 | Ricoh Company, Ltd.; Ricoh Company, LTD | System and method for automatic generation of visual representations and links in a hierarchical messaging system |
6915336, | Jun 05 1998 | Oracle OTC Subsidiary LLC | Real time internet communication system |
7035903, | Nov 22 2000 | Xerox Corporation | Systems and methods for the discovery and presentation of electronic messages that are related to an electronic message |
7111044, | Jul 17 2002 | Malikie Innovations Limited | Method and system for displaying group chat sessions on wireless mobile terminals |
7188140, | Mar 13 2002 | Tao Technologies, LLC | System and method for providing enhanced persistent communications |
7222156, | Jan 25 2001 | Microsoft Technology Licensing, LLC | Integrating collaborative messaging into an electronic mail program |
7233951, | Feb 18 2004 | Microsoft Technology Licensing, LLC | Spreadsheet grid-like control for a web-based collaboration system |
7272641, | Jul 03 2001 | Canon Kabushiki Kaisha | Image information managing system |
7734589, | Sep 16 2005 | Ikorongo Technology, LLC | System and method for optimizing data uploading in a network based media sharing system |
7774703, | Feb 09 2006 | Microsoft Technology Licensing, LLC | Virtual shadow awareness for multi-user editors |
7933952, | Jun 29 2007 | Microsoft Technology Licensing, LLC | Collaborative document authoring |
7949633, | May 12 2008 | Adobe Inc | Shared edit access of electronic content |
8086679, | Oct 05 2007 | Sony Corporation | Information processing unit, content providing server, communication relay server, information processing method, content providing method and communication relay method |
20030182450, | |||
20040260974, | |||
20050076068, | |||
20050086605, | |||
20050108402, | |||
20050166154, | |||
20060026502, | |||
20060053194, | |||
20060117247, | |||
20060136511, | |||
20060136821, | |||
20060161516, | |||
20060212583, | |||
20060277210, | |||
20070130257, | |||
20070136662, | |||
20070198648, | |||
20070203886, | |||
20070233811, | |||
20070239869, | |||
20070250506, | |||
20070271340, | |||
20080016164, | |||
20080066106, | |||
20080147695, | |||
20080172607, | |||
20080178076, | |||
20080215588, | |||
20080250114, | |||
20080250329, | |||
20090006936, | |||
20090070301, | |||
20090112937, | |||
20090157811, | |||
20090177744, | |||
20090192845, | |||
20090228555, | |||
20090235181, | |||
20090271696, | |||
20090271806, | |||
20090275412, | |||
20090276471, | |||
20090313331, | |||
20090319910, | |||
20090327448, | |||
20100023557, | |||
20100169269, | |||
20100174783, | |||
20100180218, | |||
20100235216, | |||
20100299180, | |||
20100306185, | |||
20110010447, | |||
20120159649, | |||
WO2005112374, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
May 02 2011 | BYTTOW, DAVID MARK | Google Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 027033 | /0224 | |
May 02 2011 | PRASETYA, MARCEL ADI | Google Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 027033 | /0224 | |
May 17 2011 | Google Inc. | (assignment on the face of the patent) | / | |||
Sep 16 2011 | OSINGA, DOUWE M | Google Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 027033 | /0224 | |
Sep 29 2017 | Google Inc | GOOGLE LLC | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 044101 | /0299 |
Date | Maintenance Fee Events |
Feb 13 2017 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Feb 15 2021 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Date | Maintenance Schedule |
Aug 13 2016 | 4 years fee payment window open |
Feb 13 2017 | 6 months grace period start (w surcharge) |
Aug 13 2017 | patent expiry (for year 4) |
Aug 13 2019 | 2 years to revive unintentionally abandoned end. (for year 4) |
Aug 13 2020 | 8 years fee payment window open |
Feb 13 2021 | 6 months grace period start (w surcharge) |
Aug 13 2021 | patent expiry (for year 8) |
Aug 13 2023 | 2 years to revive unintentionally abandoned end. (for year 8) |
Aug 13 2024 | 12 years fee payment window open |
Feb 13 2025 | 6 months grace period start (w surcharge) |
Aug 13 2025 | patent expiry (for year 12) |
Aug 13 2027 | 2 years to revive unintentionally abandoned end. (for year 12) |