WO2010028401A1 - System and method for collaborative short messaging and discussion - Google Patents
System and method for collaborative short messaging and discussion Download PDFInfo
- Publication number
- WO2010028401A1 WO2010028401A1 PCT/US2009/056284 US2009056284W WO2010028401A1 WO 2010028401 A1 WO2010028401 A1 WO 2010028401A1 US 2009056284 W US2009056284 W US 2009056284W WO 2010028401 A1 WO2010028401 A1 WO 2010028401A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- message
- messages
- user
- users
- client
- Prior art date
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L51/00—User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
- H04L51/52—User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail for supporting social networking services
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q10/00—Administration; Management
- G06Q10/10—Office automation; Time management
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L51/00—User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
- H04L51/21—Monitoring or handling of messages
- H04L51/216—Handling conversation history, e.g. grouping of messages in sessions or threads
Definitions
- the present invention relates to electronic messaging over the Internet, and more particularly to a system and method for collaborative short messaging and discussion.
- a computer-implemented method for collaborative short messaging and discussion comprises grouping users into client networks based on existing shared attributes. System resources are partitioned for messaging across client networks. Users in a client network are allowed to view or respond only to messages within the client network.
- Figure 1 illustrates an exemplary system for collaborative short messaging and discussion, according to one embodiment
- Figure 2 illustrates exemplary embodiments of the web client interface for use with the present system, according to one embodiment
- Figure 3 illustrates a block diagram of an exemplary process for message distribution, according to one embodiment
- Figure 4 illustrates a flow chart of an exemplary process for message processing, according to one embodiment
- Figure 5 illustrates an exemplary data structure for storing and associating messages, according to one embodiment
- Figure 6 illustrates a flow chart of an exemplary process for message broadcasting, according to one embodiment
- Figure 7 illustrates a flow chart of an exemplary process for caching message feeds, according to one embodiment.
- Figure 8 illustrates a flow chart of an exemplary process for a web message request; according to one embodiment.
- a system and method for collaborative short messaging and discussion are disclosed.
- a computer network short messaging and discussion system designed for collaboration within an existing group.
- Features include message threading and tagging with keywords, and private messages and groups.
- the present system is network partitioned: Users are grouped into a client network based on the domain portion of their email addresses. For example, joe@foo.com and bob@foo.com will both be members of the foo.com client network, and only have access to its contents. Because there is no overlap of data between client networks, databases and other resources can be partitioned into groups of networks. [0018] In the following description, for purposes of explanation, specific nomenclature is set forth to provide a thorough understanding of the various inventive concepts disclosed herein. However, it will be apparent to one skilled in the art that these specific details are not required in order to practice the various inventive concepts disclosed herein. [0019] System Architecture
- FIG. 1 illustrates an exemplary system for collaborative short messaging and discussion, according to one embodiment.
- System 100 includes client devices 103, 104, 1 13, and 1 14, client networks 105, and 1 15 with which client devices are associated, internet 1 10, network(s) 101, web server 120, user storage 125, message processing and broadcasting server 130, memory cache 140, instant message (IM) server 150, database 160, enterprise search server 170, email server 180 and SMS server 190.
- client devices 103, 104, 1 13, and 1 14 client networks 105, and 1 15 with which client devices are associated, internet 1 10, network(s) 101, web server 120, user storage 125, message processing and broadcasting server 130, memory cache 140, instant message (IM) server 150, database 160, enterprise search server 170, email server 180 and SMS server 190.
- IM instant message
- System 100 is interconnected by the internet 1 10 and network(s) 101.
- network(s) 101 is described as being the internet; alternatively, network(s) 101 may be Wide Area Networks (WAN), a Local Area Networks (LAN), or any other system of interconnection enabling two or more devices to exchange information.
- WAN Wide Area Networks
- LAN Local Area Networks
- One or more client devices 103, 104, 1 13, and 1 14 allow web access via browsers such as Microsoft Internet explorer, Apple Safari, Mozilla, Firefox or any other browser that supports HTML and JavaScript that may allow network access via the web.
- Client devices 104, 1 13, and 114 may personal computers.
- Client device 103 is a web enabled phone or other web enabled mobile device.
- client device 103 is a non- web-enabled mobile phone capable of SMS.
- Users of client devices 103, 104, 1 13, and 1 14, are grouped into client networks.
- a user in system 100 is a specific person's account associated with a single client network.
- a client network is a collection of users, messages, and keyword tags.
- users are grouped into client networks based on the domain portion of the users' email address. For example, in FIG 1, users of client devices 103 and 104 are grouped in client network 105 because they share the same email domain (e.g.
- Web server 120 is a web server that uses any of protocols and/or applications including Hypertext transfer Protocol (HTTP), File Transfer Protocol (FTP), Extensible Messaging and Presence Protocol (XMPP), or other similar connection protocols.
- HTTP Hypertext transfer Protocol
- FTP File Transfer Protocol
- XMPP Extensible Messaging and Presence Protocol
- the operating system may be Windows, LINUX, SUN Solaris, Mac OS, or other similar operating system.
- Users create an account on web server 120 and are grouped into client networks. Messages are sent from client devices 103, 104, 1 13 or 114 to web server 120 through internet 1 10.
- Message processing and broadcasting server 130 is a server capable of processing the content of messages, operating a message queue, and directing messages to the appropriate resource in system 100.
- the operating system may be Windows, LINUX, SUN Solaris, Mac OS, or other similar operating system.
- Message processing and broadcasting server 130 may distribute messages to email server 180, SMS server 190, IM server 150, memory cache 140, database 160, and enterprise search server 170.
- Instant message server 150 is a server using any protocols and/or applications for sending instant messages including Extensible Messaging and Presence Protocol (XMPP), ejabberd, and Bi-Directional-Streams Over HTTP (BOSH).
- Enterprise search server 170 is a server using any protocol and/or application for enterprise searches such as Apche's SoIr.
- User Storage 125 is a storage drive or other device capable of file storage. Preferably user photos are stored in user storage 125.
- FIG. 2 illustrates exemplary embodiments of the web client interface for use with the present system, according to one embodiment.
- web client interface 220 operates through a web browser 210 on client device 200.
- web client interface 260 is designated application software for a personal computer operating Microsoft Windows, or Mac OS, or application software for a mobile device such as Apple's iPhone, RIM's Blackberry, or Google's Android for exmple.
- FIG. 3 illustrates a block diagram of a process for message distribution, according to one embodiment.
- Messages need to be delivered to all connected clients. This includes clients connected via the web client interface 390, SMS 375, email 370, Instant Message 380, or other communication schemes.
- system 100 delivers the "all" feed to users who request it. Additional embodiments include rate-limiting this feed (and dropping messages when the messaging rate is too high), or simply removing it as an option for some or all clients.
- message post handling 310 Before a new message 300 is sent out, it is subjected to message post handling 310 on the client device. For example, during message post handling, the user is able to view the message before it is transmitted.
- message processing 320 After message processing 320, the new message is dispersed across system resources. These include enterprise search 330, database 340, message feeds 350 and message broadcasting 360. Enterprise search 330 allows for word searches within message. Feed Inbox 350 associates the new message with all message feeds that the message is relevant to, and database 360 archives the message.
- a notification table describing which message feeds users want and by which delivery method e.g. IM, SMS, email
- delivery method e.g. IM, SMS, email
- messages are then handed off to the appropriate delivery system depending on which method (e.g. IM, SMS, email) user has enabled for delivery.
- Some delivery systems may have further configuration parameters (windows of delivery time, for example, or a global on/off toggle), and this configuration parameter is consulted before delivering a message.
- users have the option of tagging messages for users and/or keywords.
- This tagging feature allows users to seamlessly direct messages to relevant message feeds during composition of the message. It also allows users within the client network to search the client network for messages tagged with a particular user, or messages tagged with a particular keyword. Further, it allows users to subscribe to message feeds containing user specified tags.
- users can tag other users in the body of a message by prefixing a username with"@”. Likewise, users can tag keywords by prefixing a keyword with a pound "#" sign. For example:
- Figure 4 illustrates a flow chart of an exemplary process for message processing, according to one embodiment.
- a new message is dequeued (400) from the message queue and the body of the message is searched for tagged usernames (410). If username tags are found (420) then the sender's client network is searched to determine whether the tagged username(s) exist in the client network (423). If a tagged usemame exists within the client network, a username tag is added to the message as a reference (425) and the process proceeds. If no username tags are found (420), or the username does not exist in the sender's client network, then the process proceeds.
- the body of the message is searched for tagged keywords (430). If a keyword tag is found (440), the system checks whether the keyword already exists in the sender's client network as a keyword (443). If the tagged keyword does not presently exist in the client network as a keyword, a keyword tag is created in the client network (445) and a keyword tag is added to the message as a reference (447). And if the tagged keyword already exists in the sender's client network as a keyword it is added to the message as a reference (447). [0042] Once the message is screened for tags, it is determined whether the message is a reply to another message (450).
- the message receives the message ID of the original message (460) and inherits the original message's thread ID (470), this allows for message threading.
- Messages which are not replies are given a new thread ID matching its new message ID; when a message's ID matches its thread ID, it is a "thread starter".
- replies maintain the knowledge of the message they were in reply to.
- Tags in the body of the message are stored as special tokens (480) that are later replaced with links, or similar mechanisms, when the message is displayed on the web client interface. After all tags in the body of the message are tokenized (480), the message is saved (490) and enqueued for recipient notification (495). [0044] Structure of a Message
- FIG. 5 illustrates an exemplary data structure for storing messages, according to one embodiment.
- New messages are stored starting with the body, then the references, and finally the row with the meta-data in the messages table. This ensures new messages showing up in the sequence of message IDs are immediately ready for delivery.
- the structure of a message consists of table 500 and associated tables 510 and 520.
- Table 500 contains the message Id 501 , the network the message is associated with — Network_id 502 — and the massage body or pointer to the message body, Body 503, according to one embodiment.
- Associated table 510 contains information for message transmittal and threading. These include Id 511, Network_id 512, Replied_id 513, Thread id 514, Sender id 515, Sender_type 516, and Ref_id 517.
- Associated table 520 includes information for a message reference, such as tagged keyword. These include Id 521, Network_id 522,
- Reference_id 523 Reference type 524, Reference_as 525, and Ref_id 526.
- the type "re” is used when the referenced_type is a user, and that user was the sender of the message that this message is in reply to. For example, if Zack sends a message that David replies to, David's message will have a message_references record where referenced_id/referenced_type map to his user object, and referenced as is set to "re".
- to allows directed messages.
- Tagged is used for those things explicitly tagged in the body of a message using @ or #, or similar tagging identifier.
- In_thread is used when references are inherited from previous messages in the thread.
- Threading is accomplished by giving users a reply feature which tags the new message with the ID of the original, as well as inheriting the original message's thread ID. Messages which are not replies are given a new thread ID matching its message ID; when a message's ID matches its thread ID, it is a "thread starter".
- Figure 6 illustrates a flow chart of an exemplary process for message broadcasting, according to one embodiment.
- the process begins by pulling a message from the message queue (600).
- the process determined all the message feeds that the message is relevant to
- the process determines which users receive those feeds (620). For every user which receives the feed(s), the process determines which delivery methods the user has enabled (e.g. email, SMS, IM) (630). The message is then forwarded to each users' enabled delivery method according to steps 610, 620, and 630 and the process is repeated as long as there are messages in the message queue (600).
- delivery methods e.g. email, SMS, IM
- the system organizes messages at the time of creation into feeds.
- the present system for collaborative short massaging and discussion identifies collections of messages, or feeds, which are related in some way.
- a user wishing to view messages selects the appropriate feed and has immediate access to messages within that feed without having to do expensive (e.g. time consuming and resource intensive) queries against a relational database.
- the system handles several orders of magnitude — more reads than writes — so the system allows the difficult work of figuring out if a message should be visible in a given context to be handled once during message creation, rather than hundreds or thousands of times during a message's visible lifetime.
- Examples of message feeds include: all public messages in a particular client network, all messages in a particular client network not in a specific group, messages from a specific user, messages sent by a specific user, messages in a specific group, messages in a specific group by a specific user, messages in a specific group also tagged with a specific keyword, private messages to a specific user, messages tagged with a specific keyword, messages from all bots "followed” by a specific user (see subscriptions below), messages from a specific bot, messages referencing or in reply to a specific user, messages representing a chain of replies, messages "followed” by a specific user (see subscriptions below), messages within a specific conversation which is an ad-hoc collection of messages not organized by reply chain, and messages marked by a specific user as favorites.
- Subscriptions come in two verities, according to one embodiment.
- the first verity of subscription occurs when a user subscribes to another user's message feed or to a feed for a tagged keyword.
- the second verity of subscription occurs when a user selects a particular delivery method (e.g. email, SMS, IM) for a feed.
- a particular delivery method e.g. email, SMS, IM
- FIG. 7 illustrates a block diagram of a process for caching message feeds, according to one embodiment.
- New messages (700) are written to the following feed cache for each relevant user subscription (710).
- Messages are then written to the custom tab feed cache for each relevant user custom tab (720). It is then determined whether a user is the sender of the message and if the message is a reply (730). If a user is the sender of the message and the message is a reply (730) then messages are written to the relevant feed caches for all participants in the message thread (740).
- Users connected to the system for collaborative short messaging and discussion through the web client interface can view a number of pages with message feeds including messages with a particular tag, a user's “updates" (their non-replies), a user's “replies” (their replies to others), a user's own “following” tab or any of their custom following tabs, a user sent tab, a user's received tab (all messages that mention or are in reply to that user), or all messages in the client network, according to one embodiment. Any of these pages can be viewed in threaded mode.
- Each user has a unique Jabber ID ("JID").
- JID Jabber ID
- a unique resource is generated and assigned to that user's JID for that page/request. For example, if user David requests all messages with the keyword "workfeed”, a resource is generated as the identifier for that request and assigned to David's JID.
- This JID/resource combination is subscribed to the feed the user is looking at so that new messages to that feed will be delivered to that user.
- the JID/resource is unsubscribed from the feed when it sends an offline presence.
- Database 160 and memory cache 140 store the record of which JIDs are presently subscribed to which feeds.
- FIG. 8 illustrates a flow chart of an exemplary process for a web message request, according to one embodiment.
- the message feed cache is searched for messages relevant to the request (810) and returns all relevant cached messages (820). If no relevant messages are found (810), then the database is searched for relevant messages (815). If relevant messages are found in the database (815), the database returns the relevant messages and the cache is updated (820), otherwise no relevant messages exist and the system returns an error (817).
- the relevant messages are returned a unique resource is generated and assigned to that user's JID for that page/request (840). That JID/resource combination is subscribed to the feed the user is viewing (850). If the user remains online, then new messages to the feed are delivered to the user (865). If the user is no longer present online the user's JID/resource is unsubscribed from the feed.
Landscapes
- Engineering & Computer Science (AREA)
- Business, Economics & Management (AREA)
- Strategic Management (AREA)
- Entrepreneurship & Innovation (AREA)
- Human Resources & Organizations (AREA)
- Operations Research (AREA)
- Quality & Reliability (AREA)
- Computer Networks & Wireless Communication (AREA)
- Computing Systems (AREA)
- Economics (AREA)
- Marketing (AREA)
- Signal Processing (AREA)
- Data Mining & Analysis (AREA)
- Tourism & Hospitality (AREA)
- Physics & Mathematics (AREA)
- General Business, Economics & Management (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Information Transfer Between Computers (AREA)
Abstract
A system and method for collaborative short messaging and discussion are described. According to one embodiment, a computer-implemented method for collaborative short messaging and discussion, comprises grouping users into client networks based on existing shared attributes. System resources are partitioned for messaging across client networks. Users in a client network are allowed to view or respond only to messages within the client network.
Description
SYSTEM AND METHOD FOR COLLABORATIVE SHORT MESSAGING AND DISCUSSION
FIELD
[0001] The present invention relates to electronic messaging over the Internet, and more particularly to a system and method for collaborative short messaging and discussion.
BACKGROUND
[0002] Online and mobile social networking applications allow users to create an account online and to send and receive messages to and from other users, and view messages posted by other users. Typically users create a profile and define their network of associated users by inviting other users to join their network or by using software to find existing relationships recorded on computer (e.g. Facebook, Myspace, and Linkedln). [0003] More recently, micro-blogging has become an effective means of collaborative discussion, allowing participants to share information at any given moment on a particular topic. In micro-blogging social networks (e.g. Twitter), users can send and receive messages through a website, Short Message Service (SMS), or dedicated application software. But like typical social networking applications, micro-blogging social networks have minimal message threading capabilities. A user searching for the most recent information on a particular topic is likely to be presented with many messages that are irrelevant because the core of the message is not necessarily directed to the topic searched.
SUMMARY
[0004] A system and method for collaborative short messaging and discussion are described. According to one embodiment, a computer-implemented method for collaborative short messaging and discussion, comprises grouping users into client networks based on existing shared attributes. System resources are partitioned for messaging across client networks. Users in a client network are allowed to view or respond only to messages within the client network.
[0005] The present application claims the benefit of and priority to U.S. Provisional Patent Application No. 61/ 094,818 entitled "System and Method for Collaborative Short Messaging and Discussion" and filed on September 5, 2008, and is hereby, incorporated by reference.
BRIEF DESCRIPTION OF THE DRAWINGS
[0006] The accompanying drawings, which are included as part of the present specification, illustrate the presently preferred embodiment of the present invention and together with the general description given above and the detailed description of the preferred embodiment given below serve to explain and teach the principles of the present invention.
[0007] Figure 1 illustrates an exemplary system for collaborative short messaging and discussion, according to one embodiment;
[0008] Figure 2 illustrates exemplary embodiments of the web client interface for use with the present system, according to one embodiment;
[0009] Figure 3 illustrates a block diagram of an exemplary process for message distribution, according to one embodiment;
[0010] Figure 4 illustrates a flow chart of an exemplary process for message processing, according to one embodiment;
[0011] Figure 5 illustrates an exemplary data structure for storing and associating messages, according to one embodiment;
[0012] Figure 6 illustrates a flow chart of an exemplary process for message broadcasting, according to one embodiment;
[0013] Figure 7 illustrates a flow chart of an exemplary process for caching message feeds, according to one embodiment; and
[0014] Figure 8 illustrates a flow chart of an exemplary process for a web message request; according to one embodiment.
[0015] It should be noted that the figures are not necessarily drawn to scale and that elements of similar structures or functions are generally represented by like reference numerals for illustrative purposes throughout the figures. It also should be noted that the figures are only intended to facilitate the description of the various embodiments described herein. The figures do not describe every aspect of the teachings described herein and do not limit the scope of the claims.
DETAILED DESCRIPTION
[0016] A system and method for collaborative short messaging and discussion are disclosed. According to one embodiment, a computer network short messaging and discussion system designed for collaboration within an existing group. Features include message threading and tagging with keywords, and private messages and groups.
[0017] In one embodiment the present system is network partitioned: Users are grouped into a client network based on the domain portion of their email addresses. For example, joe@foo.com and bob@foo.com will both be members of the foo.com client network, and only have access to its contents. Because there is no overlap of data between client networks, databases and other resources can be partitioned into groups of networks. [0018] In the following description, for purposes of explanation, specific nomenclature is set forth to provide a thorough understanding of the various inventive concepts disclosed herein.
However, it will be apparent to one skilled in the art that these specific details are not required in order to practice the various inventive concepts disclosed herein. [0019] System Architecture
[0020] Figure 1 illustrates an exemplary system for collaborative short messaging and discussion, according to one embodiment. System 100 includes client devices 103, 104, 1 13, and 1 14, client networks 105, and 1 15 with which client devices are associated, internet 1 10, network(s) 101, web server 120, user storage 125, message processing and broadcasting server 130, memory cache 140, instant message (IM) server 150, database 160, enterprise search server 170, email server 180 and SMS server 190.
[0021] System 100 is interconnected by the internet 1 10 and network(s) 101. According to one embodiment, network(s) 101 is described as being the internet; alternatively, network(s) 101 may be Wide Area Networks (WAN), a Local Area Networks (LAN), or any other system of interconnection enabling two or more devices to exchange information.
[0022] One or more client devices 103, 104, 1 13, and 1 14 allow web access via browsers such as Microsoft Internet explorer, Apple Safari, Mozilla, Firefox or any other browser that supports HTML and JavaScript that may allow network access via the web. Client devices 104, 1 13, and 114 may personal computers. Client device 103 is a web enabled phone or other web enabled mobile device. Alternatively client device 103 is a non- web-enabled mobile phone capable of SMS.
[0023] Users of client devices 103, 104, 1 13, and 1 14, are grouped into client networks. A user in system 100 is a specific person's account associated with a single client network. A client network is a collection of users, messages, and keyword tags. In a client network a user only has the ability to see public information of other users in that client network; users outside the client network cannot see any information in a client network unless they are specifically granted access to such a client network. In the preferred embodiment, users are grouped into client networks based on the domain portion of the users' email address. For example, in FIG 1, users of client devices 103 and 104 are grouped in client network 105 because they share the same email domain (e.g. joe@foo.com and bob@foo.com). Likewise, users of client devices 1 13, and 1 14 are grouped in client network 1 15 because they share the same email domain. [0024] Web server 120 is a web server that uses any of protocols and/or applications including Hypertext transfer Protocol (HTTP), File Transfer Protocol (FTP), Extensible Messaging and Presence Protocol (XMPP), or other similar connection protocols. The operating system may be Windows, LINUX, SUN Solaris, Mac OS, or other similar operating system. Users create an account on web server 120 and are grouped into client networks.
Messages are sent from client devices 103, 104, 1 13 or 114 to web server 120 through internet 1 10. Messages are received via web server 120, email server 180, and/or SMS server 190. [0025] Message processing and broadcasting server 130 is a server capable of processing the content of messages, operating a message queue, and directing messages to the appropriate resource in system 100. The operating system may be Windows, LINUX, SUN Solaris, Mac OS, or other similar operating system. Message processing and broadcasting server 130 may distribute messages to email server 180, SMS server 190, IM server 150, memory cache 140, database 160, and enterprise search server 170.
[0026] Instant message server 150 is a server using any protocols and/or applications for sending instant messages including Extensible Messaging and Presence Protocol (XMPP), ejabberd, and Bi-Directional-Streams Over HTTP (BOSH). Enterprise search server 170 is a server using any protocol and/or application for enterprise searches such as Apche's SoIr. [0027] User Storage 125 is a storage drive or other device capable of file storage. Preferably user photos are stored in user storage 125.
[0028] Figure 2 illustrates exemplary embodiments of the web client interface for use with the present system, according to one embodiment. In one embodiment, web client interface 220 operates through a web browser 210 on client device 200. In another embodiment, web client interface 260 is designated application software for a personal computer operating Microsoft Windows, or Mac OS, or application software for a mobile device such as Apple's iPhone, RIM's Blackberry, or Google's Android for exmple.
[0029] Figure 3 illustrates a block diagram of a process for message distribution, according to one embodiment. Messages need to be delivered to all connected clients. This includes clients connected via the web client interface 390, SMS 375, email 370, Instant Message 380, or other communication schemes. According to one embodiment, system 100 delivers the "all" feed to users who request it. Additional embodiments include rate-limiting this feed (and dropping messages when the messaging rate is too high), or simply removing it as an option for some or all clients.
[0030] Before a new message 300 is sent out, it is subjected to message post handling 310 on the client device. For example, during message post handling, the user is able to view the message before it is transmitted. Once the message is sent from the client device and received by the system, the message is subject to message processing 320 which is discussed in detail in Figure 4. After message processing 320, the new message is dispersed across system resources. These include enterprise search 330, database 340, message feeds 350 and message broadcasting 360. Enterprise search 330 allows for word searches within message. Feed Inbox
350 associates the new message with all message feeds that the message is relevant to, and database 360 archives the message.
[0031] For push delivery, a notification table describing which message feeds users want and by which delivery method (e.g. IM, SMS, email) is consulted. During message broadcasting
360, messages are then handed off to the appropriate delivery system depending on which method (e.g. IM, SMS, email) user has enabled for delivery. Some delivery systems may have further configuration parameters (windows of delivery time, for example, or a global on/off toggle), and this configuration parameter is consulted before delivering a message.
[0032] Tagging Messages
[0033] In the present system for collaborative short messaging and discussion users have the option of tagging messages for users and/or keywords. This tagging feature allows users to seamlessly direct messages to relevant message feeds during composition of the message. It also allows users within the client network to search the client network for messages tagged with a particular user, or messages tagged with a particular keyword. Further, it allows users to subscribe to message feeds containing user specified tags. In one embodiment, users can tag other users in the body of a message by prefixing a username with"@". Likewise, users can tag keywords by prefixing a keyword with a pound "#" sign. For example:
[0034] Zack Parker: Hey @kgale, check with @apisoni to see if he's done with the #im gateway for #workfeed.
[0035] This message from user Zack Parker is tagged with "im" and "workfeed", along with users kgale and apisoni. Replies to this message will inherit all of these tags (both keyword and user), so a user following the tags will see relevant replies without people having to remember to keep tagging all messages in the thread. For Example, David Sacks in reply to Zack Parker: [0036] David Sacks: I just talked to Adam. He said he was done and moving on to his #skynet presentation.
[0037] This reply from user David Sacks to the original message from user Zack Parker is tagged with users kgale and apisoni, keywords "im", "workfeed", and now keyword "skynet".
Note that the "skynet" tag does not apply to the original, but it will apply to any responses to this message.
[0038] Message Processing
[0039] Figure 4 illustrates a flow chart of an exemplary process for message processing, according to one embodiment.
[0040] First, a new message is dequeued (400) from the message queue and the body of the message is searched for tagged usernames (410). If username tags are found (420) then the sender's client network is searched to determine whether the tagged username(s) exist in the
client network (423). If a tagged usemame exists within the client network, a username tag is added to the message as a reference (425) and the process proceeds. If no username tags are found (420), or the username does not exist in the sender's client network, then the process proceeds.
[0041] The body of the message is searched for tagged keywords (430). If a keyword tag is found (440), the system checks whether the keyword already exists in the sender's client network as a keyword (443). If the tagged keyword does not presently exist in the client network as a keyword, a keyword tag is created in the client network (445) and a keyword tag is added to the message as a reference (447). And if the tagged keyword already exists in the sender's client network as a keyword it is added to the message as a reference (447). [0042] Once the message is screened for tags, it is determined whether the message is a reply to another message (450). As a result of the determination (450), if the message is a reply, the message receives the message ID of the original message (460) and inherits the original message's thread ID (470), this allows for message threading. Messages which are not replies are given a new thread ID matching its new message ID; when a message's ID matches its thread ID, it is a "thread starter". Thus, while threads are only 1 level deep, replies maintain the knowledge of the message they were in reply to.
[0043] Tags in the body of the message are stored as special tokens (480) that are later replaced with links, or similar mechanisms, when the message is displayed on the web client interface. After all tags in the body of the message are tokenized (480), the message is saved (490) and enqueued for recipient notification (495). [0044] Structure of a Message
[0045] In the present system for collaborative short massaging and discussion, although messages are relatively small, many updates are posted through SMS and IM. And given that the web client interface encourages small messages, in the preferred embodiment, most messages will tend to be under 200 characters, but no character limit is imposed. Figure 5 illustrates an exemplary data structure for storing messages, according to one embodiment. [0046] New messages are stored starting with the body, then the references, and finally the row with the meta-data in the messages table. This ensures new messages showing up in the sequence of message IDs are immediately ready for delivery.
[0047] The structure of a message consists of table 500 and associated tables 510 and 520. Table 500 contains the message Id 501 , the network the message is associated with — Network_id 502 — and the massage body or pointer to the message body, Body 503, according to one embodiment. Associated table 510 contains information for message transmittal and threading. These include Id 511, Network_id 512, Replied_id 513, Thread id 514, Sender id
515, Sender_type 516, and Ref_id 517. Associated table 520 includes information for a message reference, such as tagged keyword. These include Id 521, Network_id 522,
Reference_id 523, Reference type 524, Reference_as 525, and Ref_id 526.
[0048] The row called Referenced as allows for association of different types of references with individual messages. The possible values of Referenced as are "re", "to", "tagged" or
"in thread". The type "re" is used when the referenced_type is a user, and that user was the sender of the message that this message is in reply to. For example, if Zack sends a message that David replies to, David's message will have a message_references record where referenced_id/referenced_type map to his user object, and referenced as is set to "re". The type
"to" allows directed messages. "Tagged" is used for those things explicitly tagged in the body of a message using @ or #, or similar tagging identifier. "In_thread" is used when references are inherited from previous messages in the thread.
[0049] The present system for collaborative short massaging and discussion uses this list as a hierarchy to determine whether the value in referenced_as is "tagged" or better, meaning "re",
"to", or "tagged" but not just "injhread". This hierarchy is also used to prevent saving the same reference twice. If user David replies to user apisoni and also puts "@apisoni" in the body, only one reference will be stored, using "re" instead of "tagged".
[0050] From the example reply above, the four inherited references (#im, #workfeed,
@apisoni, @kgale) would be stored with referenced_as=in_thread, and the new reference
(#skynet) would be stored with referenced_as=tagged. Another "re" reference will have to be added for the user representing Zack Parker.
[0051] The distinction between "tagged" and "in thread" is best illustrated by comparing the list of messages seen on a tag's page (injhread or better) to those seen on a user's "received" tab (tagged or better.) This makes the received tab clearer, as all messages shown there explicitly reference the user in the body of the message.
[0052] Threading is accomplished by giving users a reply feature which tags the new message with the ID of the original, as well as inheriting the original message's thread ID. Messages which are not replies are given a new thread ID matching its message ID; when a message's ID matches its thread ID, it is a "thread starter".
[0053] Message Broadcasting
[0054] Figure 6 illustrates a flow chart of an exemplary process for message broadcasting, according to one embodiment. The process begins by pulling a message from the message queue (600). The process determined all the message feeds that the message is relevant to
(610). For every message feed that the message is relevant to (610), the process determines which users receive those feeds (620). For every user which receives the feed(s), the process
determines which delivery methods the user has enabled (e.g. email, SMS, IM) (630). The message is then forwarded to each users' enabled delivery method according to steps 610, 620, and 630 and the process is repeated as long as there are messages in the message queue (600).
[0055] Message Feeds and Subscriptions
[0056] To enable the system to scale to handle very large numbers of users and messages, the system organizes messages at the time of creation into feeds. The present system for collaborative short massaging and discussion identifies collections of messages, or feeds, which are related in some way.
[0057] A user wishing to view messages selects the appropriate feed and has immediate access to messages within that feed without having to do expensive (e.g. time consuming and resource intensive) queries against a relational database. The system handles several orders of magnitude — more reads than writes — so the system allows the difficult work of figuring out if a message should be visible in a given context to be handled once during message creation, rather than hundreds or thousands of times during a message's visible lifetime.
[0058] Message delivery writes ahead directly into the feed cache, which is used during message polling. This allows the system to handle the vast majority of feeds from in-memory cache without using a relational database or fetching messages from hard drives.
[0059] Examples of message feeds include: all public messages in a particular client network, all messages in a particular client network not in a specific group, messages from a specific user, messages sent by a specific user, messages in a specific group, messages in a specific group by a specific user, messages in a specific group also tagged with a specific keyword, private messages to a specific user, messages tagged with a specific keyword, messages from all bots "followed" by a specific user (see subscriptions below), messages from a specific bot, messages referencing or in reply to a specific user, messages representing a chain of replies, messages "followed" by a specific user (see subscriptions below), messages within a specific conversation which is an ad-hoc collection of messages not organized by reply chain, and messages marked by a specific user as favorites.
[0060] Subscriptions come in two verities, according to one embodiment. The first verity of subscription occurs when a user subscribes to another user's message feed or to a feed for a tagged keyword. The second verity of subscription occurs when a user selects a particular delivery method (e.g. email, SMS, IM) for a feed.
[0061] Figure 7 illustrates a block diagram of a process for caching message feeds, according to one embodiment. New messages (700) are written to the following feed cache for each relevant user subscription (710). Messages are then written to the custom tab feed cache for each relevant user custom tab (720). It is then determined whether a user is the sender of the
message and if the message is a reply (730). If a user is the sender of the message and the message is a reply (730) then messages are written to the relevant feed caches for all participants in the message thread (740).
[0062] For each reference in a message, it is determined whether the reference is to the user (750). Messages with references "to" the user, in reply "re" to the user, or where the user is tagged in the message (755), are written to the received feed cache for that user (760). Messages that contain tags of keywords (770), are written to the tag feed cache (780). [0063] Web Message Requests
[0064] Users connected to the system for collaborative short messaging and discussion through the web client interface can view a number of pages with message feeds including messages with a particular tag, a user's "updates" (their non-replies), a user's "replies" (their replies to others), a user's own "following" tab or any of their custom following tabs, a user sent tab, a user's received tab (all messages that mention or are in reply to that user), or all messages in the client network, according to one embodiment. Any of these pages can be viewed in threaded mode.
[0065] Each user has a unique Jabber ID ("JID"). When a user views a page on the web client interface, a unique resource is generated and assigned to that user's JID for that page/request. For example, if user David requests all messages with the keyword "workfeed", a resource is generated as the identifier for that request and assigned to David's JID. This JID/resource combination is subscribed to the feed the user is looking at so that new messages to that feed will be delivered to that user. The JID/resource is unsubscribed from the feed when it sends an offline presence. Database 160 and memory cache 140 store the record of which JIDs are presently subscribed to which feeds.
[0066] Figure 8 illustrates a flow chart of an exemplary process for a web message request, according to one embodiment. When an initial request is made for a page with a particular message feed (800), the message feed cache is searched for messages relevant to the request (810) and returns all relevant cached messages (820). If no relevant messages are found (810), then the database is searched for relevant messages (815). If relevant messages are found in the database (815), the database returns the relevant messages and the cache is updated (820), otherwise no relevant messages exist and the system returns an error (817). [0067] When the relevant messages are returned a unique resource is generated and assigned to that user's JID for that page/request (840). That JID/resource combination is subscribed to the feed the user is viewing (850). If the user remains online, then new messages to the feed are delivered to the user (865). If the user is no longer present online the user's JID/resource is unsubscribed from the feed.
Claims
1. A computer-implemented method for collaborative short messaging and discussion, comprising: grouping users into client networks based on existing shared attributes; partitioning system resources for messaging across client networks; and allowing users in a client network to view or respond only to messages within the client network.
2. The computer-implemented method of claim 1, wherein users are grouped in client networks based on shared email addresses domains.
3. The computer-implemented method of claim 1 further comprising: allowing users to tag word-objects in messages; maintaining a table of tagged word-objects for each message; and allowing users to search for messages tagged for specified word-objects.
4. The computer-implemented method of claim 3, wherein users can subscribe to messages tagged with specified word-objects.
5. A computer-implemented method, comprising:
Joining a client network for collaborative short messaging and discussion; and composing a short message wherein user tags one or more word-objects within the message during composition;
6. The computer-implemented method of claim 3, wherein tagged word-objects are keywords.
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
EP09812402A EP2335161A4 (en) | 2008-09-05 | 2009-09-08 | System and method for collaborative short messaging and discussion |
JP2011526284A JP5674665B2 (en) | 2008-09-05 | 2009-09-08 | System and method for collaborative short message and discussion |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US9481808P | 2008-09-05 | 2008-09-05 | |
US61/094,818 | 2008-09-05 |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2010028401A1 true WO2010028401A1 (en) | 2010-03-11 |
Family
ID=41797565
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/US2009/056284 WO2010028401A1 (en) | 2008-09-05 | 2009-09-08 | System and method for collaborative short messaging and discussion |
Country Status (4)
Country | Link |
---|---|
US (2) | US20100064015A1 (en) |
EP (1) | EP2335161A4 (en) |
JP (1) | JP5674665B2 (en) |
WO (1) | WO2010028401A1 (en) |
Families Citing this family (18)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9514444B2 (en) | 2009-01-15 | 2016-12-06 | Sococo, Inc. | Encapsulating virtual area based communicant assemblies |
US9129263B2 (en) * | 2009-12-01 | 2015-09-08 | Yahoo! Inc. | System and method for automatically building up topic-specific messaging identities |
US9817637B2 (en) * | 2010-07-01 | 2017-11-14 | Salesforce.Com, Inc. | Methods and systems for providing enhancements to a business networking feed |
US8280860B2 (en) * | 2010-11-15 | 2012-10-02 | Quantum Corporation | Method for increasing deduplication speed on data streams fragmented by shuffling |
US9418160B2 (en) * | 2010-12-17 | 2016-08-16 | Microsoft Technology Licensing, Llc | Hash tag management in a microblogging infrastructure |
CN102737062B (en) * | 2011-04-15 | 2016-08-17 | 腾讯科技(深圳)有限公司 | A kind of good friend's Notification Method and device |
US9634977B2 (en) | 2012-10-01 | 2017-04-25 | Salesforce.Com, Inc. | Systems and methods of redactive messaging |
US9590929B2 (en) * | 2013-04-11 | 2017-03-07 | International Business Machines Corporation | Directed message notification in chat sessions |
US20150100576A1 (en) * | 2013-10-09 | 2015-04-09 | Foxwordy, Inc. | Default Network |
CN104144110B (en) * | 2014-01-24 | 2016-11-09 | 腾讯科技(深圳)有限公司 | The method and system of PUSH message |
US10601745B2 (en) | 2015-03-25 | 2020-03-24 | Pypestream Inc. | Systems and methods for channel based communication and engagement through advertising units |
US9647968B2 (en) * | 2015-03-25 | 2017-05-09 | Pypestream Inc | Systems and methods for invoking chatbots in a channel based communication system |
US10659403B2 (en) | 2015-03-25 | 2020-05-19 | Pypestream, Inc. | Systems and methods for navigating nodes in channel based chatbots using natural language understanding |
WO2016154603A1 (en) * | 2015-03-25 | 2016-09-29 | Pypestream Inc. | Channel based communication and transaction system |
US20170017928A1 (en) * | 2015-07-15 | 2017-01-19 | Microsoft Technology Licensing, Llc | Inferring physical meeting location |
US11477302B2 (en) | 2016-07-06 | 2022-10-18 | Palo Alto Research Center Incorporated | Computer-implemented system and method for distributed activity detection |
US10069782B2 (en) | 2016-08-12 | 2018-09-04 | Xenovus Inc. | Method and system to facilitate electronic communication between internal teams and external contacts |
DE102017119183A1 (en) * | 2017-08-22 | 2019-02-28 | Unify Patente Gmbh & Co. Kg | Computer-implemented method for controlling a collaboration platform, communication and collaboration application, and communication and collaboration platform |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20020032735A1 (en) * | 2000-08-25 | 2002-03-14 | Daniel Burnstein | Apparatus, means and methods for automatic community formation for phones and computer networks |
US20030100322A1 (en) * | 2001-11-28 | 2003-05-29 | Lg Electronics Inc. | Method for transmitting short message service using tag |
Family Cites Families (21)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6272437B1 (en) * | 1998-04-17 | 2001-08-07 | Cae Inc. | Method and apparatus for improved inspection and classification of attributes of a workpiece |
JP4849706B2 (en) * | 1999-03-31 | 2012-01-11 | ソニー株式会社 | Information provision processing apparatus, information provision processing method, and information provision processing program storage medium |
US7496626B2 (en) * | 2003-12-10 | 2009-02-24 | International Business Machines Corporation | System and method for role pen based messaging in a synchronous collaborative environment |
US8316128B2 (en) * | 2004-01-26 | 2012-11-20 | Forte Internet Software, Inc. | Methods and system for creating and managing identity oriented networked communication |
JP2005228126A (en) * | 2004-02-13 | 2005-08-25 | Nippon Telegr & Teleph Corp <Ntt> | Information notification method/program/program recording medium/device, service management device, and service system |
US20060129916A1 (en) * | 2004-12-03 | 2006-06-15 | Volk Andrew R | RSS rendering via a media player |
US20070055731A1 (en) * | 2005-09-07 | 2007-03-08 | Jason Thibeault | System and method for secure communications utilizing really simple syndication protocol |
JP4614854B2 (en) * | 2005-09-27 | 2011-01-19 | 日本電信電話株式会社 | Community management device and community management program |
US7797256B2 (en) * | 2006-08-02 | 2010-09-14 | Facebook, Inc. | Generating segmented community flyers in a social networking system |
US20070282962A1 (en) * | 2006-06-01 | 2007-12-06 | Microsoft Corporation | Auto-Subscribing to Syndication Feeds Using Contact Lists |
US7734705B1 (en) * | 2006-06-21 | 2010-06-08 | Wheeler Jr Roland E | System and method for flexibly managing heterogeneous message delivery |
JP4810339B2 (en) * | 2006-07-12 | 2011-11-09 | 株式会社リコー | Network communication apparatus, network communication apparatus control method, network communication apparatus control program, and recording medium |
US20080147578A1 (en) * | 2006-12-14 | 2008-06-19 | Dean Leffingwell | System for prioritizing search results retrieved in response to a computerized search query |
US20080183814A1 (en) * | 2007-01-29 | 2008-07-31 | Yahoo! Inc. | Representing online presence for groups |
US7747705B1 (en) * | 2007-05-08 | 2010-06-29 | Avaya Inc. | Method to make a discussion forum or RSS feed a source for customer contact into a multimedia contact center that is capable of handling emails |
US20090037520A1 (en) * | 2007-07-30 | 2009-02-05 | Caterpillar Inc. | System and method for secure file transfer |
US20090063264A1 (en) * | 2007-09-04 | 2009-03-05 | Patronsoft Limited | Method for transmitting online advertisements to users |
US20090089380A1 (en) * | 2007-09-28 | 2009-04-02 | Microsoft Corporation | Aggregating and Delivering Information |
EP2301208A1 (en) * | 2008-05-20 | 2011-03-30 | Raytheon Company | System and method for dynamic contact lists |
EP2281387A4 (en) * | 2008-05-20 | 2013-03-20 | Raytheon Co | System and method for collaborative messaging and data distribution |
US7984103B2 (en) * | 2008-11-25 | 2011-07-19 | International Business Machines Corporation | System and method for managing data transfers between information protocols |
-
2009
- 2009-09-08 WO PCT/US2009/056284 patent/WO2010028401A1/en active Application Filing
- 2009-09-08 US US12/555,800 patent/US20100064015A1/en not_active Abandoned
- 2009-09-08 JP JP2011526284A patent/JP5674665B2/en not_active Expired - Fee Related
- 2009-09-08 EP EP09812402A patent/EP2335161A4/en not_active Withdrawn
-
2011
- 2011-08-24 US US13/217,213 patent/US20110307569A1/en not_active Abandoned
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20020032735A1 (en) * | 2000-08-25 | 2002-03-14 | Daniel Burnstein | Apparatus, means and methods for automatic community formation for phones and computer networks |
US20030100322A1 (en) * | 2001-11-28 | 2003-05-29 | Lg Electronics Inc. | Method for transmitting short message service using tag |
Non-Patent Citations (1)
Title |
---|
See also references of EP2335161A4 * |
Also Published As
Publication number | Publication date |
---|---|
JP2012502371A (en) | 2012-01-26 |
EP2335161A1 (en) | 2011-06-22 |
US20100064015A1 (en) | 2010-03-11 |
EP2335161A4 (en) | 2012-03-28 |
JP5674665B2 (en) | 2015-02-25 |
US20110307569A1 (en) | 2011-12-15 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20100064015A1 (en) | System And Method For Collaborative Short Messaging And Discussion | |
US9137190B2 (en) | System and method for content-based message distribution | |
JP2012502371A5 (en) | System and method for collaborative short message and discussion | |
US8909719B2 (en) | Method of managing feeds based on classifications | |
US10798190B2 (en) | Tracking changes to content on an external source in an online social network | |
US9553835B2 (en) | Active e-mails | |
US10013399B2 (en) | Post-to-post profile control | |
US7610287B1 (en) | System and method for impromptu shared communication spaces | |
US10353915B2 (en) | Customizing tracking changes to user content in an online social network | |
US8577967B1 (en) | Method and system for managing real-time communications in an email inbox | |
US8375309B2 (en) | Integration of collaboration systems in an instant messaging application | |
US7082458B1 (en) | Dialog facilitation system for generating contextual order-preserving dialog postings and posting summaries from electronic messages | |
US8788602B1 (en) | Method and system for providing notifications for specific messages | |
US20120297026A1 (en) | Aggregation system | |
US8504545B2 (en) | Apparatus and methods for managing a social media universe | |
US20240020305A1 (en) | Systems and methods for automatic archiving, sorting, and/or indexing of secondary message content | |
US20160364453A1 (en) | Method, system and apparatus for managing contact data | |
US8805933B2 (en) | System and method for building interest profiles from related messages |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
121 | Ep: the epo has been informed by wipo that ep was designated in this application |
Ref document number: 09812402 Country of ref document: EP Kind code of ref document: A1 |
|
ENP | Entry into the national phase |
Ref document number: 2011526284 Country of ref document: JP Kind code of ref document: A |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
WWE | Wipo information: entry into national phase |
Ref document number: 2009812402 Country of ref document: EP |