Recherche Images Maps Play YouTube Actualités Gmail Drive Plus »
Connexion
Les utilisateurs de lecteurs d'écran peuvent cliquer sur ce lien pour activer le mode d'accessibilité. Celui-ci propose les mêmes fonctionnalités principales, mais il est optimisé pour votre lecteur d'écran.

Brevets

  1. Recherche avancée dans les brevets
Numéro de publicationUS20070094387 A1
Type de publicationDemande
Numéro de demandeUS 11/564,370
Date de publication26 avr. 2007
Date de dépôt29 nov. 2006
Date de priorité28 févr. 2000
Autre référence de publicationUS7159039
Numéro de publication11564370, 564370, US 2007/0094387 A1, US 2007/094387 A1, US 20070094387 A1, US 20070094387A1, US 2007094387 A1, US 2007094387A1, US-A1-20070094387, US-A1-2007094387, US2007/0094387A1, US2007/094387A1, US20070094387 A1, US20070094387A1, US2007094387 A1, US2007094387A1
InventeursMark Hahn, Kevin Brophy, Anita Chow, Luis Letjer, David Robbins
Cessionnaire d'origineVerizon Laboratories Inc.
Exporter la citationBiBTeX, EndNote, RefMan
Liens externes: USPTO, Cession USPTO, Espacenet
Systems and Methods for Providing In-Band and Out-Of-Band Message Processing
US 20070094387 A1
Résumé
A personal messaging agent (220) performs enhanced messaging services. The personal messaging agent (220) includes a user profile (310), a message filter (320), and at least one external helper (330). The user profile (310) stores user preferences for processing messages. The message filter (320) receives messages, performs in-band processing on the messages based on the user preferences, and generates at least one event for triggering out-of-band processing of the messages. The external helpers (330) perform the out-of-band processing of the messages in response to the event(s).
Images(9)
Previous page
Next page
Revendications(17)
1. A personal messaging agent, comprising:
a user profile configured to store user preferences for processing messages;
a message filter configured to receive one or more messages, perform in-band processing on the message based on the user preferences, and generate at least one event for triggering out-of-band processing of the message; and
at least one external helper configured to perform the out-of-band processing of the messages in response to the at least one event.
2. The personal messaging agent of claim 1, wherein the message filter includes:
a message manager configured to examine the message and modify the message based on the user preferences, and
an event manager configured to send the at least one event to the at least one external helper to trigger the out-of-band processing.
3. The personal messaging agent of claim 2, wherein the message manager includes:
a tokenizer configured to read the message and reduce the message to a set of tokens.
4. The personal messaging agent of claim 2, wherein the message manager includes:
a plurality of message components corresponding to elements of the message, each of the message components being configured to recognize a specific portion of the message and modify the specific portion based on the user preferences.
5. The personal messaging agent of claim 4, wherein the message components include:
a header component configured to process a header portion of the message,
a separator component configured to process a separator portion of the message, and
a body component configured to process a body portion of the message.
6. The personal messaging agent of claim 1, wherein the message filter is further configured to generate an enhanced message from the in-band processing and transmit the enhanced message for delivery to one or more mailboxes associated with one or more message recipients.
7. The personal messaging agent of claim 6, wherein the at least one external helper is configured to further process the message after delivery to the one or more mailboxes.
8. The personal messaging agent of claim 7, wherein the at least one external helper is configured to at least one of automatically generate a reply to the message, deliver the message to one or more alternate mailboxes, and notify the one or more message recipients of the delivery of the message.
9. A system for providing personal messaging services, comprising:
means for storing user preferences for processing at least one message;
means for receiving a message;
means for performing in-band processing on the message based on the user preferences to create a processed message;
means for generating at least one event for triggering out-of-band processing of the processed message; and
means for performing the out-of-band processing of the processed message in response to the at least one event.
10. A method for providing enhanced messaging services, comprising:
receiving a message stream intended for a message recipient;
performing in-band processing on the message stream based on one or more preferences of the message recipient to create a processed message stream;
generating at least one event for triggering out-of-band processing of the processed message stream; and
performing the out-of-band processing of the processed message stream in response to the at least one event.
11. The method of claim 10, wherein the performing in-band processing includes:
examining the message stream, and
modifying the message stream based on the one or more preferences of the message recipient.
12. The method of claim 11, wherein the examining includes:
reading the message stream, and
reducing the message stream to a set of tokens.
13. The method of claim 10, wherein the performing in-band processing includes:
creating a plurality of message components that correspond to elements of the message stream, each of the message components being configured to recognize a specific portion of the message stream and modify the specific portion based on the one or more preferences of the message recipient.
14. The method of claim 13, wherein the message components include at least a header component, a separator component, and a body component; and
wherein the performing in-band processing further includes:
processing a header portion of the message stream by the header component,
processing a separator portion of the message stream by the separator component, and
processing a body portion of the message stream by the body component.
15. The method of claim 10, further comprising:
transmitting the processed message stream for delivery as a message to one or more mailboxes associated with the message recipient.
16. The method of claim 15, wherein the performing out-of-band processing includes:
processing the message after delivery to the one or more mailboxes.
17. The method of claim 16, wherein the processing includes:
at least one of automatically generating a reply to the processed message stream, delivering the processed message stream to one or more alternate mailboxes, and notifying the message recipient of the delivery of the processed message stream.
Description
    RELATED APPLICATION
  • [0001]
    This application is a continuation of U.S. patent application Ser. No. 09/652,908, filed Aug. 31, 2000, which claims priority under 35 U.S.C. § 119 based on U.S. Provisional Application No. 60/185,382, filed Feb. 28, 2000, the disclosures of which is incorporated herein by reference.
  • BACKGROUND OF THE INVENTION
  • [0002]
    1. Field of the Invention
  • [0003]
    The present invention relates generally to messaging systems and, more particularly, to systems and methods that provide enhanced services for e-mail messages.
  • [0004]
    2. Description of Related Art
  • [0005]
    Electronic mail (“e-mail”) is quickly becoming a standard mode of communication. E-mail's popularity can be attributed to the ease with which e-mail messages may be transmitted and the speed with which a transmitted message arrives at its intended destination. For example, to transmit a single e-mail message, the sender typically inputs a message and addresses the message with the recipient's e-mail address. When the message is complete, the sender commands the e-mail software to transmit the message, and the message is then delivered over a network, such as the Internet. The delivered message is quickly received by the recipient via a computer or the like.
  • [0006]
    FIG. 1 is a diagram of a conventional e-mail system 100. The e-mail system 100 includes a message arrival component 110, user mailboxes 120, message retrieval component 130, and e-mail clients 140. The message arrival component 110 connects to a network, such as the Internet, to receive e-mail messages from one or more e-mail senders, using, for example, computer devices. The message arrival component 110 includes a server 112 and a local delivery agent 114. The server 112 uses a standard transfer protocol, such as the Simple Mail Transfer Protocol (SMTP), to process the e-mail messages and place them in the appropriate user mailboxes 120, typically using the services of a local delivery agent 114. The local delivery agent 114 includes the appropriate software and/or hardware to perform the message delivery.
  • [0007]
    The user mailboxes 120 include storage locations of one or more memory devices assigned to particular e-mail recipients. The user mailboxes 120 typically store e-mail messages for retrieval by the recipients. The message retrieval component 130 includes a server 132 that uses a conventional message access protocol, such as Post Office Protocol 3 (POP3) or Internet Message Access Protocol 4 (IMAP4), to retrieve the e-mail messages from the user mailboxes 120. The e-mail clients 140 receive instructions from the e-mail recipients and, via the server 132, provide content and state information regarding the messages in the user mailboxes 120 to the e-mail recipients.
  • [0008]
    Processing by the e-mail system 100 typically commences with an e-mail sender using a computer device to construct and transmit an e-mail message. The e-mail message from the sender is encoded as an RFC822/MIME stream and routed through the network, based on its destination address, to a specific domain using a standard message transfer protocol, such as SMTP. Within that domain, the message stream is routed to the specific SMTP server, such as server 112, responsible for placing the message in the destination mailbox 120. The server 112 sends the message to the local delivery agent 114 for storage in the destination mailbox 120. The local delivery agent 114 delivers the message to the destination mailbox 120 and notifies the server 112 of the delivery status.
  • [0009]
    When an e-mail recipient desires to retrieve messages from the destination mailbox 120, the recipient uses a computer device to invoke an e-mail client 140 that instructs the server 132 to access the destination mailbox 120. The server 132 uses a standard message access protocol, such as POP3 or IMAP4, to open the destination mailbox 120 and return the content/state information about the message to the e-mail recipient.
  • [0010]
    Conventional e-mail service providers offer enhanced messaging services that are of value to the user to differentiate themselves from their competitors. Some examples of enhanced messaging features include extracting/blocking unwanted messages or removing unwanted parts of messages; inserting a targeted advertisement (to support low-cost/no-cost mail service); replacing a media file attachment with streaming controls (to reduce download time); notifying the user of the new message (e.g., sending a pager notification, displaying a dialog box, etc.); and redirecting the message to other preferred mail account(s).
  • [0011]
    Some conventional e-mail providers offer these services by providing an enhanced e-mail client. The enhanced e-mail client, however, is rigid in the sense that it restricts the available services to only those services that the e-mail client was originally designed to provide. Other conventional e-mail providers embed additional functionality into the e-mail message itself, independent of the e-mail client. This approach, however, increases network requirements and costs, both to the provider and the user.
  • [0012]
    As a result, a need exists for a flexible mechanism to offer enhanced e-mail services without substantially increasing requirements and costs to the provider or the user.
  • SUMMARY OF THE INVENTION
  • [0013]
    Systems and methods consistent with the present invention address this need by providing one or more personal messaging agents that intelligently process e-mail messages on behalf of a specific user, independent of the e-mail clients used to retrieve the messages.
  • [0014]
    In accordance with the purpose of the invention as embodied and broadly described herein, a personal messaging agent performs enhanced messaging services. The personal messaging agent includes a user profile, a message filter, and at least one external helper. The user profile stores user preferences for processing messages. The message filter receives messages, performs in-band processing on the messages based on the user preferences, and generates at least one event for triggering out-of-band processing of the messages. The external helpers perform the out-of-band processing of the messages in response to the event(s).
  • [0015]
    In another implementation consistent with the present invention, a message arrival system includes a server, multiple personal messaging agents, and a local delivery agent. The server receives message streams from message senders. Each of the message streams may be destined for one or more message recipients. The personal messaging agents receive the message streams from the server, process the message streams based on preferences of the one or more message recipients to create modified message streams, and output the modified message streams. The local delivery agent receives the modified message streams and delivers the modified message streams to mailboxes associated with the message recipients.
  • [0016]
    In yet another implementation consistent with the present invention, an e-mail system includes a message arrival component and a message retrieval component. The message arrival component includes a server, a personal messaging agent, and a local delivery agent. The server receives an e-mail message from an e-mail sender that is destined for one or more e-mail recipients. The personal messaging agent receives the e-mail message from the server, processes the e-mail message based on preferences of the e-mail recipients to create a processed e-mail message, and outputs the processed e-mail message. The local delivery agent receives the processed e-mail message and places the processed e-mail message in one or more mailboxes associated with the e-mail recipients. The message retrieval system retrieves the processed e-mail message from the mailboxes and delivers the processed e-mail message to the e-mail recipients.
  • [0017]
    In a further implementation consistent with the present invention, a method for performing personal e-mail services includes storing e-mail processing preferences for one or more e-mail recipients; receiving an e-mail message from an e-mail sender that is destined for one or more of the e-mail recipients; processing the e-mail message based on the e-mail processing preferences; and providing the processed e-mail message for delivery to the e-mail recipients.
  • [0018]
    In another implementation consistent with the present invention, personal messaging agents provide enhanced messaging services. Each of the personal messaging agents includes a user profile and a message filter. The user profile stores user preferences of a message recipient for processing a message. The message filter receives a message destined for the message recipient, processes the message based on the user preferences to produce a processed message, and delivers the processed message to the message recipient.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • [0019]
    The accompanying drawings, which are incorporated in and constitute apart oft his specification, illustrate the invention and, together with the description, explain the invention. In the drawings,
  • [0020]
    FIG. 1 is a diagram of a conventional e-mail system;
  • [0021]
    FIG. 2 is an exemplary diagram of an e-mail system in which systems and methods consistent with the present invention may be implemented;
  • [0022]
    FIG. 3 is a detailed diagram of the personal messaging agent (PMA) of FIG. 2 according to an implementation consistent with the present invention;
  • [0023]
    FIG. 4 is a detailed diagram of the message filter of FIG. 3 according to an implementation consistent with the present invention;
  • [0024]
    FIG. 5 is a detailed diagram of the message manager of FIG. 4 according to an implementation consistent with the present invention;
  • [0025]
    FIG. 6 is a flowchart of processing for providing enhanced message services according to an implementation consistent with the present invention;
  • [0026]
    FIG. 7 is a flowchart of processing for creating an enhanced message stream in an implementation consistent with the present invention; and
  • [0027]
    FIG. 8 is a flowchart of processing by components of the message filter of FIG. 3 according to an implementation consistent with the present invention.
  • DETAILED DESCRIPTION
  • [0028]
    The following detailed description of the invention refers to the accompanying drawings. The same reference numbers in different drawings identify the same or similar elements. Also, the following detailed description does not limit the invention. Instead, the scope of the invention is defined by the appended claims and equivalents.
  • [0029]
    Systems and methods consistent with the present invention provide a personal messaging agent that permits an e-mail message to be processed based on user-defined preferences. The personal messaging agent may be likened to a personal assistant that is tasked with opening a mail envelope for an individual, tailoring the contents according to the individual's personal preferences, resealing the envelope, placing it in the individual's preferred mailbox, and then notifying the individual of the new message.
  • [0000]
    Exemplary System
  • [0030]
    FIG. 2 is a diagram of an exemplary system 200 in which systems and methods consistent with the present invention may be implemented. The system 200 may include one or more e-mail senders, a network, a message arrival component 210, user mailboxes 120, a message retrieval component 130, e-mail clients 140, and one or more e-mail recipients. The message arrival component 210 may include a server 112 and a local delivery agent 114. As can be seen, the system 200 may include some of the elements found in the conventional system 100, such as the e-mail sender(s), the network, the server 112, the local delivery agent 114, the user mailboxes 120, the message retrieval component 130, the e-mail clients 140, and the e-mail recipient(s). Accordingly, these elements will not be described further.
  • [0031]
    The message arrival component 210 may also include one or more personal messaging agents (PMAs) 220 connected between the server 112 and the local delivery agent 114 to perform enhanced messaging services. To the server 112, the PMA 220 behaves like the local delivery agent 114. To the local delivery agent 114, the PMA 220 acts like the server 112. This transparency makes it easy to integrate the functionality of the PMA 220 into any existing e-mail infrastructure. The PMA 220 may be implemented in software, hardware, or a combination of software and hardware. If implemented in software, the PMA 220 may be stored within a computer-readable medium. A computer-readable medium may include one or more memory devices.
  • [0032]
    FIG. 3 is a detailed diagram of the PMA 220 according to an implementation consistent with the present invention. An instance of the PMA 220 may be created on a per message/per recipient basis (i.e., for each message placed in a specific recipient's mailbox 120). For example, a trigger may be generated upon receipt of a new message. The trigger may cause a process to execute that generates an instance of the PMA 220.
  • [0033]
    The PMA 220 may include a user profile 310, a message filter 320, and external helpers 330. The user profile 310 may store information regarding personal preferences of an e-mail recipient or user. The personal preferences may determine the way messages are processed by the message filter 320 and the external helpers 330 on behalf of the e-mail recipient or user.
  • [0034]
    The message filter 320 may parse an incoming message stream, such as an RFC822/MIME stream, inspect the message contents (i.e., the header and body parts), and dynamically modify the message (e.g., extract/insert/replace header fields and/or body parts) based on the user's preferences in the user profile 310. For example, the message filter 320 may extract a media file attachment and replace it with streaming controls or insert a targeted advertisement.
  • [0035]
    The message filter 320 may also generate “events” at various stages of message processing to allow the external helpers 330 to perform additional operations outside the context of the message stream (i.e., out-of-band). For example, after extracting a media file, the message filter 320 may generate an event that triggers an external helper 330 to perform any user-requested media translations (e.g., creating a textual transcript of an audio file). Similarly, when a (modified) message is finally placed in the user's mailbox 120, the message filter 320 may generate an event to initiate an external helper 330 to perform additional message-related processing. Examples include, but are not limited to, notifying the user of the new message (e.g., sending a pager notification, displaying a dialog box on a computer, etc.), redirecting the message to other preferred mail account(s), and automatically generating a customized response to the e-mail sender.
  • [0036]
    The external helpers 330 may include extensible mechanisms that allow the PMA 220 to separate the processing of a message into in-band and out-of-band processing. In-band processing refers to processing that has an impact on the enhanced message stream being produced. Out-of-band processing refers to everything else. For example, consider the replacement of a large audio attachment with streaming media controls in terms of in-band and out-of band processing. To replace an audio attachment, the audio file must be extracted from the message stream, converted to a streaming format, placed on a media server, and replaced with interactive controls in the message stream to allow the user to activate the media stream. Extracting the audio to a media file and replacing it with streaming controls are in-band processing since they directly impact the resulting message stream. Manipulating the file format and interacting with a media server have no impact on the message stream and, therefore, are considered out-of-band processing that can be performed in parallel with the in-band processing or, perhaps, deferred.
  • [0037]
    Another example of out-of-band processing includes performing cross-media translation (e.g., converting the audio file into a textual transcript). This distinction between in-band and out-of-band processing ensures efficient processing that is not subject to the delays associated with adjunct processing and allows the PMA 220 to be easily extended, without adversely impacting processing performance.
  • [0038]
    In addition, an event may be generated when the local delivery agent 114 returns its status indicating whether the enhanced message was successfully placed in the user's mailbox 120. The external helper 330 for this event can perform many different operations, such as notifying the user of the new message (e.g., sending a pager notification, displaying a dialog box on a computer, etc.), redirecting the message to other preferred mail account(s), and automatically generating a customized response to the e-mail sender.
  • [0000]
    Exemplary Message Filter
  • [0039]
    The message filter 320 plays the central role of examining and possibly enhancing a message stream as it passes between the server 112 and the local delivery agent 114. The message filter 320 may initiate the local delivery agent 114 responsible for placing the enhanced message in the user's mailbox 120. The message filter 320 may then process the incoming message stream, generate an enhanced message stream (as well as other output files), and trigger events that initiate external helpers 330. To support these operations, the message filter 320 may include several components.
  • [0040]
    FIG. 4 is a detailed diagram of the message filter 320 according to an implementation consistent with the present invention. The message filter 320 may include a message manager 410, a stream manager 420, and an event manager 430. The message manager 410 is the central component of the message filter 320 and performs the in-band message recognition/enhancement operations. The stream manager 420 manages the output streams needed during message processing, including the enhanced message stream to the local delivery agent 114 as well as any other streams needed to create various output files (e.g., an extracted media file). The event manager 430 delivers events to the external helpers 330.
  • [0041]
    The message manager 410 performs the examination and possible modification oft he message stream. In some implementations consistent with the present invention, the message manager 410 does not store a complete representation of the input message in memory. Rather, the message manager 410 may buffer the smallest possible unit of the message stream until a determination can be made about the disposition of that unit, at which point the results are placed in the output stream. By minimizing the amount of memory required, the message manager 410 places few demands on the computing/storage resources of the host platform. In order to perform the recognition task, the message manager 410 creates a collection of support components.
  • [0042]
    FIG. 5 is a detailed diagram of the message manager 410 according to an implementation consistent with the present invention. The message manager 410 may include an attribute manager 510, a tokenizer 520, and message components unit 530. The attribute manager 510 may maintain a hierarchical namespace that contains name value pairs for items, such as user preferences, message fields, and processing state. The attribute manager 510 may also provide functions for adding/removing hierarchies, searching, adding name value pairs, and retrieving the value for a named item.
  • [0043]
    The tokenizer 520 may include a lexical analyzer responsible for reading the incoming message stream and reducing it to a set of tokens. The tokenizer 520 may assign each token a name and match it with a corresponding value that will be used to reconstruct the enhanced message stream.
  • [0044]
    The message components unit 530 may create a number of components that correspond to the structural elements of an e-mail message. Initially, it creates three components that mimic the three major structural elements of any message: a header 532, a separator 534, and a body 536. Each of the components may recognize a specific piece of an e-mail message, tailor it based on user-defined preferences, and then pass the results to the output stream (i.e., the enhanced message stream). The message components unit 530 may create additional components, such as field, boundary, and body part, as necessary to perform similar functions for other significant sub-components of an e-mail message.
  • [0045]
    Along with the tokenizer 520 and the attribute manager 510, the message components unit 530 form a complete parser for e-mail messages. Each of the components identified above provides a common set of functions: Initialize, Recognize, Actions, and End.
  • [0046]
    The Initialize function may be performed prior to any other function and is responsible for general startup housekeeping relevant to the specific message component. The Initialize function is invoked whenever an attempt to identify that particular type of message component is initiated. The particular message component dictates the types of processing performed. For example, the Initialize function of the body part component may ask the attribute manager 510 to create a new frame in the name space to ensure that any name/value pairs defined by this body part do not conflict with those from the header or any other body part.
  • [0047]
    The Recognize function is responsible for identifying that portion of the input message stream that corresponds to the message component. Each message component implements a subset of the message stream grammar. For example, a message header includes one or more fields and each field includes a label and a value. In order to recognize a message header, the Recognize function of the header component 532 repeatedly invokes the functions of a field component until it encounters something other than a field in the input message stream. All processing that occurs within the Recognize function can be customized based on user preferences. For example, a user preference that large audio attachments be replaced with streaming controls will cause the Recognize function of a body part to redirect its audio content to a file rather than to the resulting output stream.
  • [0048]
    The Actions function is responsible for taking any semantic actions relevant to the recognized message component. Possible semantic actions include saving information that affects the processing of other message components or applying user preferences to the generated output stream. Continuing the previous example with respect to large audio attachments, the Actions function of a “Content-Transfer-Encoding” field, which identifies the encoding used for the content, saves its value in the attribute manager 510 so that its encompassing body part can properly recognize and extract the audio content. Then, based on user-defined preferences, the Actions function of the body part component may insert streaming controls into the output stream.
  • [0049]
    The End function is performed after all other functions and is responsible for cleanly wrapping up any processing necessary for that message component. For example, because of possible transformations that may be applied to a message, the original “Content-Type” field in the message header may not accurately describe the resulting message and, thus, must be adjusted. The End function of the header component 532 ensures that an appropriate “Content-Type” field is placed in the output stream. Like the other functions, the End function may also apply user preferences. The End function of the body component 536 may handle the case in which a user authorizes that advertisements be included at the end of a message.
  • [0000]
    Exemplary Processing
  • [0050]
    FIG. 6 is a flowchart of processing for providing enhanced message services according to an implementation consistent with the present invention. Processing may begin when an e-mail sender creates an e-mail message using, for example, conventional e-mail software. The e-mail software may encode the e-mail message as a message stream, such as an RFC822/MIME steam, and transmit it across the network based on its destination address. The network may route the message stream to a specific domain using a standard message transfer protocol, such as SMTP. Within that domain, a server responsible for placing the message in a destination mailbox, such as the server 112, receives the message stream step [610].
  • [0051]
    The server 112 processes the message stream to identify the appropriate destination mailbox and sends the message stream to an instance of the PMA 220 [step 620]. The PMA 220 processes the message stream to create an enhanced message stream based on user preferences [step 630].
  • [0052]
    FIG. 7 is a flowchart of processing for creating an enhanced message stream in an implementation consistent with the present invention. The message filter 320 (FIG. 3) within the PMA 220 receives the message stream [step 710]. The message filter 320 may parse the message stream [step 720]. For example, the message filter 320 may analyze the message stream to identify different parts of the message, such as the header, separator, and body. The message filter 320 may then inspect the message contents to possibly determine what fields are included in each of the message parts [step 730].
  • [0053]
    The message filter 320 may dynamically modify the message based on user preferences [step 740]. The message filter 320 may obtain the user preferences from the user profile 310. Based on the user preferences, the message filter 320 may perform any necessary in-band processing on the message stream, thereby creating an enhanced message stream.
  • [0054]
    The message filter 320 may also generate events relating to out-of-band processing of the message stream [step 750]. For example, the out-of-band processing may include notifying the e-mail recipient of the new message, performing media translations, such as creating a textual transcript from an audio file, automatically generating a reply message, etc. The external helpers 330 perform the out-of-band processing in response to the events generated by the message filter 320 [step 760]. In some implementations consistent with the present invention, steps 750 and 760 may occur concurrently with step 740.
  • [0055]
    Generally, steps 720-740 may be described in terms of processing performed by the components of the message filter 320. FIG. 8 is a flowchart of processing by components of the message filter 320 according to an implementation consistent with the present invention. The tokenizer 520 (FIG. 5) may read the message stream [step 810] and reduce it to a set of tokens [step 820]. The tokenizer 520 may assign a name to each token and match it with a corresponding value that may be used later to reconstruct the enhanced message stream.
  • [0056]
    The message components unit 530 may create a number of components that correspond to the structural elements of the message [step 830]. For example, the message components unit 530 may initially create header 532, separator 534, and body 536 components (i.e., three components that correspond to the major structural elements of any message). The message components unit 530 may create additional components that correspond to other significant sub-components of the message.
  • [0057]
    Each of the components 532-536 may recognize a specific portion of the message and modify it based on user preferences [step 840]. The modified portions may then be combined to form the enhanced message stream.
  • [0058]
    Returning to FIG. 6, the PMA 220 sends the enhanced message stream to the local delivery agent 114 for delivery to the appropriate destination user mailbox 120 [step 640]. The local delivery agent 114 may deliver the enhanced message stream to the user mailbox 120 [step 650]. When the local delivery agent 114 finishes the delivery, the local delivery agent 114 may notify the PMA 220 whether the delivery was successful [step 660]. The local delivery agent 114 may make the notification through the use of a status message. The PMA 220 may, in turn, notify the server 112 of the success of the message delivery.
  • [0059]
    Once the enhanced message has been delivered to the user mailbox 120, the PMA 220 may further process the enhanced message based on the user preferences [step 670]. For example, the PMA 220 may notify the user of the new message (e.g., sending a pager notification, displaying a dialog box on a computer, etc.), forward the message to other preferred mail account(s), or automatically generate a customized response to the e-mail sender.
  • [0060]
    The e-mail recipient may then retrieve the message using an e-mail client 140. The e-mail client 140 may use a conventional message access protocol, such as POP3 or IMAP4, to open the user mailbox 120 and return the content/state information about the message to the e-mail recipient.
  • CONCLUSION
  • [0061]
    Systems and methods consistent with the present invention provide enhanced message services using cost-effective, extensible processing techniques. The processing techniques include, for example, embedding interactive and/or actionable components directly within a message to provide enhanced functionality to a user. The systems and methods separate message modification into in-band and out-of-band processing to achieve efficiency, flexibility, and scalability.
  • [0062]
    The foregoing description of preferred embodiments of the present invention provides illustration and description, but is not intended to be exhaustive or to limit the invention to the precise form disclosed. Modifications and variations are possible in light of the above teachings or may be acquired from practice of the invention. For example, systems and methods have been described in terms of e-mail messages. In other implementations consistent with the present invention, other types of messages may be used.
  • [0063]
    Also, it has been described that an instance of the PMA 220 is created to produce a single customized message stream on a per message/per recipient basis. In other implementations consistent with the present invention, the PMA 220 operates over multiple message streams for multiple recipients.
  • [0064]
    The scope of the invention is defined by the claims and their equivalents.
Citations de brevets
Brevet cité Date de dépôt Date de publication Déposant Titre
US4190533 *12 févr. 197626 févr. 1980Amsted Industries IncorporatedFilter method
US4197205 *23 mars 19798 avr. 1980Gene HirsDeep bed filter
US5032294 *13 mars 199016 juil. 1991Schulz Christopher RMulti-cell gravity filter with central control chamber
US5283887 *19 déc. 19901 févr. 1994Bull Hn Information Systems Inc.Automatic document format conversion in an electronic mail system based upon user preference
US5422883 *16 oct. 19926 juin 1995International Business Machines CorporationCall setup and channel allocation for a multi-media network bus
US5436898 *8 oct. 199225 juil. 1995International Business Machines CorporationMulti-media network bus
US5517498 *20 sept. 199314 mai 1996International Business Machines CorporationSpatial reuse of bandwidth on a ring network
US5532937 *31 janv. 19942 juil. 1996International Business Machines CorporationSwitching of multiple multimedia data streams
US5544318 *16 avr. 19936 août 1996Accom, Inc.,Asynchronous media server request processing system for servicing reprioritizing request from a client determines whether or not to delay executing said reprioritizing request
US5666349 *28 août 19969 sept. 1997Siemens AktiengesellschaftMethod for controlling components of a communication system
US5737395 *22 avr. 19967 avr. 1998Centigram Communications CorporationSystem and method for integrating voice, facsimile and electronic mail data through a personal computer
US5748884 *13 juin 19965 mai 1998Mci CorporationAutonotification system for notifying recipients of detected events in a network environment
US5768505 *19 déc. 199516 juin 1998International Business Machines CorporationObject oriented mail server framework mechanism
US5781614 *19 janv. 199614 juil. 1998Lucent Technologies Inc.Message retrieval via alternative access
US5809512 *23 juil. 199615 sept. 1998Matsushita Electric Industrial Co., Ltd.Information provider apparatus enabling selective playing of multimedia information by interactive input based on displayed hypertext information
US5818447 *6 juin 19966 oct. 1998Microsoft CorporationSystem and method for in-place editing of an electronic mail message using a separate program
US5857187 *10 juil. 19965 janv. 1999Matsushita Electric Industrial Co., Ltd.Information management apparatus providing efficient management of multimedia titles in a client-server network
US5951638 *21 mars 199714 sept. 1999International Business Machines CorporationIntegrated multimedia messaging system
US5966386 *4 mars 199712 oct. 1999Digital Vision Laboratories Corp.Multimedia network system and method of communication of same
US5995093 *19 nov. 199730 nov. 1999U.S. Philips CorporationMethod and device for configuring a multimedia message for presentation
US6023700 *17 juin 19978 févr. 2000Cranberry Properties, LlcElectronic mail distribution system for integrated electronic communication
US6052442 *25 nov. 199718 avr. 2000Internet Magic, Inc.Internet answering machine
US6052735 *10 avr. 199818 avr. 2000Microsoft CorporationElectronic mail object synchronization between a desktop computer and mobile device
US6067568 *10 déc. 199623 mai 2000International Business Machines CorporationAutomatic setup of services for computer system users
US6126078 *19 févr. 19973 oct. 2000Kaba Schliesssysteme AgIdentification medium with passive electronic data carrier storing a plurality of independent applications
US6134582 *26 mai 199817 oct. 2000Microsoft CorporationSystem and method for managing electronic mail messages using a client-based database
US6141001 *20 août 199731 oct. 2000AlcatelMethod of synchronizing the presentation of static and dynamic components of an interactive multimedia document
US6157630 *26 janv. 19985 déc. 2000Motorola, Inc.Communications system with radio device and server
US6182118 *27 oct. 199730 janv. 2001Cranberry Properties LlcSystem and method for distributing electronic messages in accordance with rules
US6185551 *16 juin 19976 févr. 2001Digital Equipment CorporationWeb-based electronic mail service apparatus and method using full text and label indexing
US6191783 *7 juil. 199920 févr. 2001U.S. Philips Corp.Method and device for configuring a multimedia message for presentation
US6246490 *13 nov. 199512 juin 2001Siemens AktiengesellschaftMethod and arrangement for the transmission of facsimile-encoded information between multimedia-capable communication terminal equipment
US6253202 *18 sept. 199826 juin 2001Tacit Knowledge Systems, Inc.Method, system and apparatus for authorizing access by a first user to a knowledge profile of a second user responsive to an access request from the first user
US6253207 *25 sept. 199726 juin 2001Lucent Technologies Inc.Method and apparatus for transporting multimedia information over heterogeneous wide area networks
US6333973 *23 avr. 199725 déc. 2001Nortel Networks LimitedIntegrated message center
US6484196 *20 mars 199819 nov. 2002Advanced Web SolutionsInternet messaging system and method for use in computer networks
US6487564 *10 juil. 199626 nov. 2002Matsushita Electric Industrial Co., Ltd.Multimedia playing apparatus utilizing synchronization of scenario-defined processing time points with playing of finite-time monomedia item
US6490728 *13 juil. 19993 déc. 2002Sony CorporationChannel information transmitting method and receiving apparatus
US6507872 *7 juin 199514 janv. 2003David Michael GeshwindClass of methods for improving perceived efficiency of end-user interactive access of a large database such as the world-wide web via a communication network such as “The Internet”
US6535586 *30 déc. 199818 mars 2003At&T Corp.System for the remote notification and retrieval of electronically stored messages
US6542462 *27 mai 19981 avr. 2003Lucent Technologies Inc.Method and apparatus for overload control of multimedia communications in a hybrid switching system
US6570676 *17 mai 200027 mai 2003Siemens AktiengesellschaftMethod and system the transmission of facsimile-encoded information between multimedia-capable communication terminal equipment
US6597738 *27 août 199922 juil. 2003Hyundai Curitel, Inc.Motion descriptor generating apparatus by using accumulated motion histogram and a method therefor
US6678361 *5 oct. 200113 janv. 2004Nokia CorporationMethod for delivering messages
US6718368 *3 juin 19996 avr. 2004General Interactive, Inc.System and method for content-sensitive automatic reply message generation for text-based asynchronous communications
US6744729 *17 août 20011 juin 2004Interactive Sapience Corp.Intelligent fabric
US6744773 *13 août 19981 juin 2004Avaya Technology Corp.Method and apparatus for managing inter-domain addresses between a plurality of domains
US6782412 *24 août 199924 août 2004Verizon Laboratories Inc.Systems and methods for providing unified multimedia communication services
US6885406 *30 nov. 200126 avr. 2005Canon Kabushiki KaishaApparatus and method for controlling display of image information including character information, including appropriate size control of a display window
US6959221 *1 avr. 199925 oct. 2005Matsushita Electric Industrial Co., Ltd.Portable viewing system
US6966065 *7 mars 200015 nov. 2005Sony CorporationData transmission control method, data transmitting method, data transmitting apparatus, and receiving apparatus
US6988093 *11 oct. 200217 janv. 2006Commissariat A L'energie AtomiqueProcess for indexing, storage and comparison of multimedia documents
US20010013130 *5 févr. 20019 août 2001Hidekazu ShimizuDigital broadcasting system and event message transmission method
US20010018766 *27 févr. 200130 août 2001Katsuyuki MoritaData broadcast content generation system
US20010052019 *5 févr. 200113 déc. 2001Ovt, Inc.Video mail delivery system
US20020044634 *5 oct. 200118 avr. 2002Michael RookeMethod for delivering messages
US20020067433 *30 nov. 20016 juin 2002Hideaki YuiApparatus and method for controlling display of image information including character information
US20020107003 *2 févr. 20018 août 2002Martin Ronald BruceMethod and apparatus for leaving a multimedia mail message without ringing a wireless phone
US20020111991 *22 févr. 200015 août 2002Wood Christopher NoahMessage management system for handling personal messages from e-mail and voice-mail sources over the internet
US20020135698 *11 juin 200126 sept. 2002Hiroki ShinoharaTransmission system, receiver, and broadcast system
US20020171857 *16 mai 200221 nov. 2002Matsushita Electric Industrial Co., Ltd.Information printing system
US20020171872 *17 mai 200221 nov. 2002Matsushita Electric Industrial Co., Ltd.Image information processing apparatus and image information processing method
US20030041159 *17 août 200127 févr. 2003David TinsleySystems and method for presenting customizable multimedia presentations
US20030043191 *17 août 20016 mars 2003David TinsleySystems and methods for displaying a graphical user interface
US20030043815 *17 août 20016 mars 2003David TinsleyIntelligent fabric
US20030097423 *23 oct. 200222 mai 2003Yuka OzawaPreview system for data broadcast contents
US20030101164 *11 oct. 200229 mai 2003Marc PicMethod of indexing and comparing multimedia documents
US20030105739 *11 oct. 20025 juin 2003Hassane EssafiMethod and a system for identifying and verifying the content of multimedia documents
US20030120634 *10 déc. 200226 juin 2003Hiroyuki KoikeData processing system, data processing method, information processing device, and computer program
US20030174248 *25 févr. 200318 sept. 2003Canon Kabushiki KaishaReception apparatus
US20030182386 *14 janv. 200325 sept. 2003Geshwind David MichaelRelated class of methods for improving perceived efficiency of end-user interactive access of a large database such as the World-Wide Web via a communication network such as "The Internet"
US20030182387 *14 janv. 200325 sept. 2003Geshwind David MichaelClass of methods for improving perceived efficiency of end-user interactive access of a large database such as the world-wide web via a communication network such as "The Internet"
US20030182439 *14 janv. 200325 sept. 2003Geshwind David MichaelClass of methods for improving perceived efficiency of end-user interactive access of a large database such as the World-Wide Web via a communication network such as "The Internet"
US20030195980 *14 janv. 200316 oct. 2003Geshwind David MichaelClass of methods for improving perceived efficiency of end-user interactive access of a large database such as the World-Wide Web via a communication network such as "The Internet"
US20030231259 *1 avr. 200318 déc. 2003Hideaki YuiMulti-screen synthesis apparatus, method of controlling the apparatus, and program for controlling the apparatus
US20040003120 *20 févr. 20031 janv. 2004Akira NaganoDigital data broadcasting program producing apparatus
US20040004885 *6 août 20018 janv. 2004Christophe CompsMethod of storing data in a multimedia file using relative timebases
US20040027890 *3 juin 200212 févr. 2004Nobuo NakanishiRecording apparatus, recording medium, reproduction apparatus, program, and method
US20040028037 *22 déc. 200012 févr. 2004Juha RasanenMethod and system for modifying a connection parameter
US20040067766 *15 janv. 20028 avr. 2004Kakuya YamamotoReceiver, portable terminal and receiving system
US20040075678 *14 oct. 200322 avr. 2004Fujitsu LimitedMultimedia contents editing apparatus and multimedia contents playback apparatus
US20040076145 *22 déc. 200022 avr. 2004Timo KauhanenMethod and system for establishing a multimedia connection by negotiating capability in an outband control channel
US20040077333 *22 déc. 200022 avr. 2004Juha-Pekka KoskinenMethod and network device for accounting chargeable signaling
US20040098365 *13 sept. 200120 mai 2004Christophe CompsMethod for synchronizing a multimedia file
US20040127211 *23 sept. 20031 juil. 2004Jean-Philippe WaryMethod for the production, by a service provider, of a multimedia isolating identifier
US20040139336 *18 déc. 200215 juil. 2004Mclean Ivan HughDigital content distribution system
US20040143816 *4 déc. 200322 juil. 2004Canon Kabushiki KaishaInformation processing apparatus, information processing method, storage medium, and program
US20040261028 *12 juil. 200223 déc. 2004Alexandre Cotarmanac'hMethod for broadcasting multimedia signals towards a plurality of terminals
US20050015801 *14 juin 200220 janv. 2005Takashi HososdaInformation providing system, broadcast receiving apparatus, and server apparatus
US20050091698 *15 oct. 200428 avr. 2005Canon Kabushiki KaishaContents acquisition system
US20050155057 *19 mars 200314 juil. 2005Yumin WeiDownloading of programs into broadcast-receivers
US20050165887 *4 févr. 200328 juil. 2005Atsushi AsaiBrowser and program containing multi-medium content
US20050182852 *14 févr. 200418 août 2005David TinsleyIntelligent fabric
US20050183133 *22 mai 200318 août 2005Kelly Declan P.Web-based television
US20050201559 *23 avr. 200315 sept. 2005Van Der Heijden Gerardus Wilhelmus T.Conditional access system
US20050204401 *27 mai 200315 sept. 2005Koniklijke Philips Electronics N.V.Dvd virtual machine
US20050256596 *26 juil. 200517 nov. 2005Mitsuteru KataokaPortable viewing/listening system
US20050286703 *13 mai 200529 déc. 2005AlcatelMethod for forwarding a call in a fixed telecommunication's network and such network
US20060015926 *20 oct. 200319 janv. 2006Koninklijke Philips Electronics N.V.Embedded data signaling
Référencé par
Brevet citant Date de dépôt Date de publication Déposant Titre
US7308482 *12 févr. 200211 déc. 2007At&T Bls Intellectual Property, Inc.Methods and systems for communicating with service technicians in a telecommunications system
US8150940 *20 nov. 20073 avr. 2012At&T Intellectual Property I, LpMethods and systems for communicating with service technicians in a telecommunications system
US8321500 *25 nov. 200827 nov. 2012International Business Machines CorporationMethod and system for generating messages
US8386498 *5 août 200926 févr. 2013Loglogic, Inc.Message descriptions
US8509729 *17 nov. 200913 août 2013At&T Mobility Ii LlcInteractive personal emergency communications
US20030154253 *12 févr. 200214 août 2003Smith Steven G.Methods and systems for communicating with service techinicians in a telecommunications system
US20080120395 *20 nov. 200722 mai 2008Smith Steven GMethods and Systems for Communicating with Service Technicians in a Telecommunications System
US20090013091 *3 juil. 20078 janv. 2009Microsoft CorporationCustomer based message routing
US20090138585 *25 nov. 200828 mai 2009Ying Chun GouMethod and System for Generating Messages
US20110035390 *5 août 200910 févr. 2011Loglogic, Inc.Message Descriptions
US20110117874 *17 nov. 200919 mai 2011At&T Mobility Ii LlcInteractive Personal Emergency Communications
US20110151871 *27 déc. 201023 juin 2011Aylus Networks, Inc.Ims networks with avs sessions with multiple access networks
US20140067782 *2 sept. 20126 mars 2014Microsoft CorporationSocial network responses to queries
Classifications
Classification aux États-Unis709/224, 709/227
Classification internationaleG06F15/16
Classification coopérativeG06Q10/107
Classification européenneG06Q10/107
Événements juridiques
DateCodeÉvénementDescription
28 juil. 2014ASAssignment
Owner name: VERIZON PATENT AND LICENSING INC., NEW JERSEY
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:VERIZON LABORATORIES INC.;REEL/FRAME:033428/0478
Effective date: 20140409