WO1999014909A1 - Messaging system - Google Patents

Messaging system Download PDF

Info

Publication number
WO1999014909A1
WO1999014909A1 PCT/GB1998/002696 GB9802696W WO9914909A1 WO 1999014909 A1 WO1999014909 A1 WO 1999014909A1 GB 9802696 W GB9802696 W GB 9802696W WO 9914909 A1 WO9914909 A1 WO 9914909A1
Authority
WO
WIPO (PCT)
Prior art keywords
message
filter
test
store
stored
Prior art date
Application number
PCT/GB1998/002696
Other languages
French (fr)
Inventor
Jonathan Andrew Chalmers
Jonathan Stewart Leggatt
Neil James Sims
Sudha Thyagarajan
Original Assignee
British Telecommunications Public Limited Company
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by British Telecommunications Public Limited Company filed Critical British Telecommunications Public Limited Company
Priority to AU88801/98A priority Critical patent/AU8880198A/en
Publication of WO1999014909A1 publication Critical patent/WO1999014909A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L51/00User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
    • H04L51/06Message adaptation to terminal or network requirements
    • H04L51/063Content adaptation, e.g. replacement of unsuitable content
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L51/00User-to-user messaging in packet-switching networks, transmitted according to store-and-forward or real-time protocols, e.g. e-mail
    • H04L51/21Monitoring or handling of messages
    • H04L51/212Monitoring or handling of messages using filtering or selective blocking

Definitions

  • a conventional electronic mail system is based typically upon a client/server arrangement.
  • a user of the mail system gains access typically from a personal computer (PC) or workstation running a proprietary mail client product, providing front-end mail facilities to the user.
  • Relatively simple text-based protocols enable the client to communicate with a compatible mail server over an interconnecting network.
  • the mail server provides user access to a personal mailbox in a message store and handles the interchange of messages between users of the mail system and with users of other mail systems. Communication with other mail systems may take place over either a dedicated network, for example where two mail systems are within the same company, or via the Internet or other publicly available network.
  • a typical mail system includes facilities to enable a user connected to the system to create a message, define the recipient(s) of the message, despatch the message to the defined recipient(s), store incoming messages in a personal mailbox and download received messages from the mailbox to a PC for viewing. Further facilities are typically provided for the management of a user's mailbox.
  • Mail servers interchange messages with other mail servers of other mail systems, usually via intermediate gateways, using standard message transfer protocols such as the Internet's Simple Message Transport Protocol (SMTP) described in RFC821 [POSTEL, 1 982].
  • Gateways communicate with other mail system gateways either by direct network interconnection or via a common mail backbone; in the latter case each mail system requires only a gateway to the mail backbone to enable communication with any other mail system with a gateway to the backbone.
  • SMTP Mail servers interchange messages with other mail servers of other mail systems, usually via intermediate gateways, using standard message transfer protocols such as the Internet's Simple Message Transport Protocol (SMTP) described in RFC821 [POSTEL, 1 982].
  • SMTP Simple Message Transport Protocol
  • Gateways communicate with other mail system gateways either by direct network interconnection or via a common mail backbone; in the latter case each mail system requires only a gateway to the mail backbone to enable communication with any other mail system with a gateway to the backbone.
  • the Internet's SMTP Mail Service
  • Gateways provide message buffering where necessary to manage the throughput of messages, for example during congestion in an intervening communications link. Gateways also carry out processing where a change in either message format or protocol is required for transmission over the next stage, for instance at a gateway to an X.400 mail backbone or conversion to 7-bit ASCII format at an SMTP gateway, sometimes incurring a considerable processing overhead. If many large messages come together at a particular gateway, considerable delays may arise in the storage and forwarding of those and other messages.
  • the accepted standard format for messages carried by the Internet mail system is defined by RFC822 and comprises header information, including the identity of the sender and the intended recipient(s), the date and subject, followed by the body of the message in a plain text format.
  • a multi-part message may also be assembled comprising several "body parts", each body part including a header and a body, as defined by RFC822 and Multi-purpose Internet Mail Extensions (MIME) documented in RFC1 521 [BORENSTEIN N (Bellcore) & FREED N (Innosoft), RFC1 521 - "MIME (Multi-purpose Internet Mail Extensions) Part One: Mechanisms for Specifying and Describing the Format of Internet Message Bodies", September 1 993] and RFC1 522 [MOORE K, RFC1 522 - "MIME (Multi-purpose Internet Mail Extensions) Part Two: Message Header Extensions for non-ASCII Text", University of Tennessee, September 1 993], now widely adopted.
  • MIME Multi-purpose Internet Mail Extensions
  • the MIME standard enables one or more message body parts of various types to be conveyed within the message, each body part including a header and a body encoded as 7-bit ASCII text or other encoding to enable transfer through the message system.
  • the MIME standard provides a means for specifying, within the respective headers, the type or types of associated message content being conveyed and their method of encoding, e.g. text, bit-mapped images, audio or video samples, within enclosed body parts to the message.
  • the headings enable a receiver of a message to identify the type of data included within a body part and to invoke an appropriate viewer to decode it and reproduce it locally.
  • multi-media files or a file generated by a particular computer program, a word processor program for example may be conveyed as part of a conventional mail message within a body part of the message.
  • the body part comprises a header defining the type of data in the enclosed file, and a body comprising the file itself to which has been applied any further encoding necessary for the purposes of transfer through the mail system.
  • a file conveyed within a message body part in this way is known as an "attachment" to the message.
  • a file containing a digitised audio recording may be conveyed as an attachment to a message, the attachment being encoded for transfer by the mail system and being associated with a header defining the type of data in the file.
  • a typical small organisation or office may use an Internet-connected local messaging system comprising a mail server and a gateway to SMTP mail. Messages are exchanged with other mail systems via the SMTP gateway. Under the store and forward principle, before despatching a message, a local mail server stores it in the sender's local message store. Similarly, messages received from other mail users are stored in the recipient's incoming mailbox in the message store. In a simple arrangement of two directly interconnected mail systems, a message will be stored twice in passing between the sender and a recipient, once by the sender's local mail server and once by the recipient's. A message bound for multiple recipients will be stored by each recipient's local mail server.
  • a message traversing an internal mail system of a moderate sized organisation occupying a number of sites may pass through three or four store and forward message transfer stages in passing from a sender to a recipient of that message.
  • a message filter arranged, in use, to transfer electronic mail messages, the filter comprising: means to receive a message to be transferred; a rule set defining at least one test to be performed; and storing means connected, in use, to a store; the filter further comprising: testing means to perform a test as determined by the rule set; selecting means arranged, in dependence upon the result of the test, to select a part of the received message, the storing means being arranged to store that selected part in the store; referencing means to assemble a reference message including a reference to the stored part of the message; and forwarding means to forward the reference message to an intended destination.
  • a mail message may include a header defining the message content type as "message/external-body", and a reference defining the location and identity of an externally stored file.
  • a message part may be stored in a file store and a so called “reference message” may be constructed comprising a reference to the externally stored message part.
  • a message filter according to embodiments of the invention is installed in a mail system to selectively implement message transfer using the "mail by reference" process.
  • a whole message it is not necessary for a whole message to be transferred to an intended destination by means of the mail system itself - it is only necessary to indicate to a recipient, at each intended destination, where a non- transferred part of the message has been stored.
  • an embodiment of the message filter may intercept a message being sent by the mail system, select a part of the message - a body part conveying an attachment for example, which may be the whole of the message or one of a number of body parts conveying different attachments - extract the selected part, which may include decoding from a particular mail system's encoding if necessary to obtain the selected part, and store the resultant part or attachment in a location accessible by equipment at each intended destination of the message.
  • a conventional message is then assembled - a "reference message" - incorporating a reference to the stored part of the message and sent through the mail system to the intended destination(s) in the normal way, in this example without the stored attachment. In this way an attachment would be said to have been "referenced”.
  • a recipient may access the referenced store and transfer the referenced attachment of the original message from the store using, for example, a file transfer protocol such as FTP, but not using the mail system itself to convey the attachment to its intended destination.
  • a file transfer protocol such as FTP
  • the at least one test to be performed by the message filter includes identifying the resources available within a mail system to receive messages, determining the resources required to receive the message to be transferred and comparing the resources available with the resources required.
  • Embodiments of the invention may provide a means for analysing messages in a mail system and, subject to various pre-determined conditions, to implement a mail by reference method of message transfer for messages being sent. Messages may be sent by users of the mail system or they may be sent by other pieces of equipment. Mail by reference may be implemented either in respect of messages bound for destinations within the same mail system or in respect of messages bound for destinations on other mail systems, or both.
  • Embodiments of the invention may provide a message filter "close to the source" of messages, for example within the mail system serving the originator of large messages or those intended for widespread distribution, behind a mail system "firewall", within a gateway or at some other point, including equipment associated with the originator of messages. This would be of particular benefit within large organisations having several interconnected mail systems serving different sites.
  • Large internal memos may be sent to multiple destinations subject to a pre-determined policy of referencing messages above a certain size, for example.
  • a message filter according to an embodiment of the invention may implement such a policy at a point close to the source of any such memo distribution.
  • the filter may perform a variety of different tests to determine whether a message should be forwarded in its original form or referenced.
  • Predetermined thresholds may be established for the message filter, for example regarding the total size of a message or the number of intended destinations of a message, taking into account the available storage capacity available to the filter, the message processing capability of the filter and other components of the associated mail system, the number of users of the mail system, etc. If a test on a message to be sent is found to result in a threshold being exceeded in any respect, the filter may reference the whole or a part of the message.
  • the type of data being conveyed by a message may be determined by the filter, the presence of certain types of data causing the whole or a part of the message to be referenced by the filter.
  • Embodiments of the invention may alternatively provide a message filter "close to the intended destination" of mail messages, for example if such a message filter is installed in each mail system capable of receiving messages, or at a gateway for incoming messages to a mail system or group of mail systems, or installed as part of a firewall to a company mail system.
  • a message filter may also be installed on equipment associated with particular destinations, for example to assist with the management of incoming messages, or be arranged to act in respect of messages incoming to or outgoing from a particular user or group of users.
  • the message filter may act on messages originating elsewhere in the same mail system or group of mail systems, on messages incoming to the mail system from other mail systems or on all incoming messages to a particular destination.
  • a message filter arranged, in use, to receive reference messages, the filter comprising: means to receive a reference message, the reference message including a respective identifier for each of one or more intended destinations and including a reference to a stored message part; a rule set defining at least one test to be performed; and storing means connected, in use, to a store; the filter further comprising: testing means to perform a test as defined by the rule set; message assembly means arranged, in dependence upon the result of the test, to assemble a message to be sent; and forwarding means to forward the message to be sent to an intended destination of the reference message.
  • the filter may be arranged to receive reference messages and to deposit a received reference message with an intended recipient without change, or to perform functions in respect of the reference message and the stored part or parts of the original message referenced within the reference message, according to pre- determined conditions established for the filter.
  • a message filter according to the second aspect of the present invention may be found especially useful, for example, in limiting the amount of storage space consumed within the mail system by large messages bound for many intended destinations within that mail system.
  • Such a facility may, for example, offer protection against malicious attack by "mail bombs" originating either from inside or outside the mail system.
  • the store is a distributed data store and the reference to a stored part of a received message comprises an identification of the location of the stored part of the message in the distributed data store.
  • the Internet is a multimedia computer communications network built on worldwide telephone and data networks. Over 100,000 servers of various types are connected to the Internet providing a publicly accessible distributed data store.
  • An "HTTP server” is a particular type of server holding files of information as data written according to an Internet communication protocol called HyperText Transfer Protocol (HTTP).
  • HTTP HyperText Transfer Protocol
  • WEB pages are written in a special WEB language called HyperText Markup Language (HTML) creating links to other pages on the WEB, as appropriate, and providing a means to navigate through information on the WEB.
  • Information held on the WEB is accessible to anyone having a computer connected to the Internet and with an interest in accessing it.
  • a Universal Resource Locator URL has been adopted as a standard among Internet users to provide a consistent international naming convention to identify all WEB resources, including for instance documents, programs, sound and video clips.
  • a URL defines exactly where to find any given resource on the WEB.
  • HTTP Hypertext Transfer Protocol
  • WEB pages URL-identified files (WEB pages) to be accessed and downloaded to user equipment connected to the Internet.
  • WEB browsers communicate with WEB resources, such as HTTP servers, using the standard Internet protocols such as HTTP to download selected WEB pages, interpret embedded HTML commands inserted at the time of markup by the WEB page authors and, if appropriate, display those pages graphically. Browsers are available to reproduce multi-media files transferred over the Internet, offering greater levels of functionality than is typical with electronic mail system client products.
  • a message filter may store a message or a part of the message on, for example, a commonly accessible WEB server as WEB pages referenced by a URL, constructing and forwarding a corresponding reference message specifying the URL to an intended destination from where, in turn, use may be made of the Internet and Internet protocols to download the URL-referenced message or message part.
  • a recipient at the destination may then use a WEB browser, for example, to view the downloaded message or message part.
  • a message filter may recognise a URL contained in the message and, if required, download the identified WEB page or pages on behalf of a recipient at the destination.
  • a method of transferring electronic mail messages comprising: receiving a message to be transferred, the message including a respective identifier for one or more intended destinations; performing a pre-determined test; and, in dependence upon the result of said pre-determined test: selecting a part of the message and storing the selected part in a store; assembling a reference message, the reference message including a reference to the stored part of the message; and forwarding the reference message to an intended destination of the received message.
  • a method of transferring electronic mail messages comprising: receiving a message to be transferred, the message including a respective identifier for one or more intended destinations and including a reference to a stored message part; performing a pre-determined test; and, in dependence upon the result of said pre-determined test: assembling a message to be delivered; and forwarding the message to be delivered to an intended destination of the received message.
  • an electronic mail system including a message filter arranged to analyse electronic mail messages, the filter comprising: means to receive a message to be analysed; a rule set defining at least one test to be performed; and storing means connected, in use, to a store; the filter further comprising: testing means to perform a test as determined by the rule set; selecting means arranged, in dependence upon the result of the test, to select a part of the received message, the storing means being arranged to store the selected part in the store; referencing means to assemble a reference message including a reference to the stored part of the message; and forwarding means to forward the reference message to an intended destination.
  • a message filter will now be described as an embodiment of the present invention, by way of example only, with reference to the accompanying drawings of which:
  • Figure 1 shows a mail appliance incorporating a message filter according to embodiments of the invention
  • Figure 2 depicts an example of message transfer by reference
  • Figure 3 is a flow diagram showing the operation of a filter according to a particular embodiment of the invention, in respect of outgoing messages from users of a mail appliance incorporating the invention;
  • Figure 4 is a flow diagram showing the operation of a message filter according to a particular embodiment of the invention, in respect of conventional mail messages incoming to users of a mail appliance incorporating the invention;
  • Figure 5 is a flow diagram, extended from Figure 4, showing the operation of a message filter according to a particular embodiment of the invention, in respect of incoming reference messages.
  • the message filter 2 is shown as a component of a so called "mail appliance" 1 .
  • the mail appliance 1 may be regarded as a logical association of features arranged, according to embodiments of the invention, to provide electronic mail services to a domain of users, such as a company office or to one or more pieces of equipment.
  • the mail appliance 1 may include known features of a conventional electronic mail system, found implemented on a conventional mail server, together with features particular to the present invention.
  • the mail applicance 1 includes a conventional author component 4 to assist in the creation of electronic mail messages and a conventional mailbox 5 providing a store for incoming or outgoing message.
  • It also includes a store 6 for further file storage by the mail appliance 1 and a message filter 2 according to a preferred embodiment of the invention, connected to a rule set 3 to control the operation of the filter 2 for the mail appliance 1 .
  • the store 6, while logically part of the mail appliance 1 may be a remote store on a Web server, accessible over the Internet.
  • the message filter 2 analyses all messages being sent from sources within the domain of the mail appliance 1 or being received by the mail appliance 1 from outside the domain, applying the principles of message transfer and delivery by reference, where required according to the rule set 3.
  • the message filter 2 of Figure 1 may be implemented in one of a number of possible ways.
  • the filter 2 may be implemented as part of the functionality of a mail server, arranged to intercept messages being sent by clients of the mail server or received by the mail server from elsewhere.
  • the filter 2 may be arranged to operate as a stand-alone device, communicating with mail servers or directly with mail server components using conventional protocols such as SMTP, IMAP4 and POP3 and with remote storage devices using HTTP or FTP for example.
  • the first part 21 is a body part comprising an initial header, "HEADER 1 ", preferably defined in accordance with the Internet mail standard for header information established by RFC822 in combination with Multi-purpose Internet Mail Extensions (MIME) defined by RFC1 521 /2, followed optionally by a plain text body inserted by the sender.
  • "HEADER 1" may comprise the following:
  • the optional plain text portion following "HEADER 1 " may be a simple message to the recipient, for example, "Print the attachment and make copies.” followed by a delimiter "-99" to define the boundary of the body part.
  • the second part 22 is a body part comprising a header, "HEADER 2", and a body.
  • the body may be an encoded attachment, for example a document, image or audio clip being conveyed as part of the message 20.
  • the header "HEADER 2" may comprise simply a description of the attachment data type and method of encoding, for example:
  • the base64 encoded attachment image is inserted following "HEADER 2", terminating with the delimiter "-99--" to indicate the end of the body part and the end of the message 20. If required, additional body parts comprising headers and encoded attachments may be included in the message 20.
  • the message filter On receiving a message 20 conveying the attachment, the message filter
  • the filter 2 operating in accordance with the rule set 3, may determine that the attachment is, for example, too large to be conveyed by an electronic mail system and should be stored in a store 6, available to the filter 2 and likely to be available from the intended destination of the message.
  • the filter 2 separates the attachment from the message 20, if necessary decoding any encoding applied for the purposes of message transfer, and stores it (24) in the store 6.
  • the filter 2 then inserts or appends to the remaining first part 21 of the message 20 a reference defining the location and identity of the stored attachment (24) in the store 6.
  • the reference may be incorporated as an additional field in the message header or as a simple plain text entry in the message identifiable as such to the recipient.
  • the resultant message 23, including the reference to the stored attachment (24), is called a "reference message" .
  • the reference message 23 is then conveyed by the electronic mail system as a conventional message to the intended destination or destinations.
  • information selected from the message headers "HEADER 1 " and/or "HEADER 2" may be stored (24) along with the attachment in the store 6 so that an audit trail may be preserved in respect of stored message parts.
  • the whole of the original message may be stored in the store 6 rather than just an attachment or particular body part of the message.
  • a recipient user or system at the destination may use the supplied reference in a suitable file transfer mechanism to either transfer or stream the stored attachment (24), via an interlinking communications network, for local reproduction.
  • the attachment (22, 24) would not, however, be transferred using the electronic mail system.
  • the filter 2 communicates with mail appliance storage devices (6) and other resources (4, 5) and, if necessary, with other mail systems, using standard network and mail system protocols such as SMTP for message transfer, FTP for file transfer, etc. and supports standard message formats.
  • SMTP message transfer
  • FTP file transfer
  • MIME standard mechanism
  • a standard mechanism is already available, as defined by MIME, by which a reference to an externally stored message part may be defined and conveyed in a reference message 23 as part of the message header.
  • the MIME "message/external-body" sub-type may be used in the Content-Type field of a MIME message header, followed by a reference to the computing platform, file identity and directory in which the separated message part or attachment is externally stored.
  • the reference message 23 may comprise a header "HEADER 3" constructed using fields from the original "HEADER 1 " and "HEADER 2" together with information on the store location 6 and identity assigned to the stored message part 24, the header being followed by any plain text included with the original message 20 in the first part 21 , as follows:
  • the attachment in this example is stored on the server "myserver.bt.com” in the "graphics” directory as a file with filename "myslide.gif" and may be transferred from the server using the ANON-FTP file transfer protocol.
  • other means for specifying the location of a stored message part may be used in a reference message as long as the means are standardised among potential participant mail systems and appliances.
  • the filter 2 interrogates the rule set 3.
  • the rule set 3 may comprise a database of rules expressing the policy of the filter in respect of different types of message. Rules may be implemented in a number of different forms dependent upon the complexity of the policy being defined by the rule set and the flexibility required to change the rules from time to time.
  • a simple policy of referencing any message to be delivered to one of a number of particular mail destinations may be implemented by means of a rule set database comprising a simple plain text data file listing the identities of those destinations in respect of whose messages the policy is to apply.
  • a computer program implementing the functionality of the filter 2 may comprise, at the point at which the rule set 3 is interrogated upon receipt of a message to be delivered, a simple conditional instruction:
  • MESSAGE_RECIPIENT is the identity of an intended destination specified in the header of the received message
  • MAIL_BY_REFERENCE is a program subroutine to select a part of the message, store it and create a corresponding reference message. If the identity of a recipient of the message is not contained in the data file, then the filter's DEFAULT program subroutine may pass the message on for delivery without change.
  • More complex policies may be implemented in the rule set 3 by means of instructions in the rule set database to execute particular filter program subroutines under specified conditions.
  • an instruction may be stored in the rule set 3 to reference all messages addressed to a particular destination you.there@that-server.bt.co.uk, but only if the message size exceeds 10kbytes and there is at least one attachment included in the message.
  • An appropriate instruction may be as follows:
  • SIZE: and “ATTACHMENTS:” may refer to predefined functions included in the computer program implementing the functionality of the filter 2, designed respectively to determine the size of the received message, for example by counting the bytes, and to determine the number and type of body parts making up the received message, for example by analysing the message headers.
  • the MAIL BY REFERENCE program is to be executed to reference a part or parts of the received message, otherwise to execute a DEFAULT program - to deliver the message intact, for example.
  • This rule would reference any message of size greater than 1 0 kbytes, conveying a single attachment and bound for more than 5 destinations.
  • messages bound for the domain "bt.com” would only be referenced in respect of particular users, defined elsewhere in the rule set for example. Failing that, if the message included more than one attachment, then each would be referenced in the text portion of the reference message. The DEFAULT behaviour would be carried out by the filter if none of these requirements were met.
  • a message filter may be located at an early stage in the transmission path of a message, at the originating mail appliance for example, so that any portion due to be filtered out of an electronic mail system by the filter may be unbound from the message, stored and referenced close to its source rather than be passed through a significant portion of the mail system.
  • a flow diagram is provided showing the operation of a message filter 2 wherein messages are being sent from sources within the domain of a mail appliance 1 incorporating the filter 2.
  • the filter 2 receives a message to be sent from within the domain.
  • the filter 2 interrogates the rule set 3 to determine the tests to be performed on the received message, expressed for example using the scheme described above.
  • the tests defined by the rule set 3 begin at STEP 303 with a determination by the filter 2 of the size of the message to be sent.
  • the filter 2 compares the message size from STEP 303 with a threshold size, 100 Kbytes for example, as determined by the rule set 3. If the size does not exceed the threshold then the filter proceeds to STEP 310 to determine the type of data being conveyed by the message.
  • the filter 2 tests for a multi-media data type attachment. If the message data type is found not to be multi-media, then the filter proceeds to STEP 320 to determine the number of intended destinations of the message within the domain of the mail appliance 1 .
  • the filter 2 compares the number of destinations from STEP 320 with a threshold determined by the rule set 3. If the number is found to exceed the threshold, 20 destinations for example, then at STEP 350 the message is passed on to the next stage of transit; to the incoming mail box (5) associated with each destination if within the domain of the mail appliance 1 or, if external, sent over the network to the next message transfer stage en route to another mail appliance or mail system.
  • the filter 2 proceeds to select a part of the message, in this example an attachment to the message, and to store the selected part in a store 6 appropriate to the type of data conveyed by the message.
  • the selected part may, in general, include the whole of the message, or one or more body parts selected from the message.
  • the selected part or parts include header information.
  • the filter 2 creates a reference message containing a reference to the location and identity of the stored part of the message in the store 6.
  • the filter 2 sends the reference message to the or each intended destination of the message.
  • STEP 342 may involve the filter 2 communicating with the mailbox 5 and depositing the reference message in the incoming mail box associated with each nominated destination.
  • any message part of multi-media data type detected at STEP 31 1 is also stored and referenced by steps 340 to 342, though a video server, for example, may then be selected within the store 6 at STEP 340 if the data type was found to be 'video' . If the number of intended destinations within the domain of the appliance
  • the filter 2 determines the total message storage space required to deliver the message to the incoming mail box associated with each nominated destination within the domain.
  • the filter 2 compares the total storage space required with a threshold level for the mail appliance as determined by the rule set 3.
  • the threshold may be an absolute limit, 3 Mbytes for example, or it may be set by a determination of available mailbox 5 storage space. If, at STEP 331 , the threshold is exceeded, then at STEP 340 a part of the message is selected and extracted and a single copy stored in a store 6.
  • STEP 341 creates a reference message in respect of that stored part and STEP 342 sends the reference message to each intended destination. It is also possible, if required at STEP 342 according to the rule set 3, to send reference messages only to intended destinations within the domain of the mail appliance 1 , the original message being sent in full to destinations outside the domain without referencing.
  • a filter designed to support a large mail user community with a large message throughput may be adapted to rapid operation in a fast processing environment whereas a filter adapted to run on a lap-top PC in support of a single roving mail user may be satisfactorily implemented on a much smaller scale, although offering similar features.
  • the associated rule set 3 may be adapted to the filter's environment, establishing thresholds for message analysis taking account, for example, of the volume of storage space available to the mail appliance 1 , the processing capability of the filter, the number of users within the domain, the expected number of messages incoming to or outgoing from the domain and the communications bandwidth available to and from the mail appliance 1 .
  • Available storage space may be automatically monitored so that thresholds relating to message size and number of recipients, for example, may be adjusted dynamically.
  • a flow diagram is provided showing the operation of a message filter 2 in respect of messages being received by the mail appliance 1 from outside the domain of the appliance, each message being bound for a mail destination within the domain.
  • an incoming message is received by the filter 2.
  • the filter 2 interrogates the rule set 3 to determine the tests to be performed in respect of messages incoming to the mail appliance 1 . Specifically in this example, the tests so determined begin at STEP 403 with a test to establish whether the message being received by the appliance
  • the filter 2 determines, at STEP 410, the size of the message.
  • the filter 2 compares the size from STEP 410 with a threshold size, 100 Kbytes for example, as determined by the rule set 3. If the size is below the threshold then the filter proceeds to determine, at STEP 420, the number of intended destinations of the message located within the domain of the mail appliance 1 .
  • the filter proceeds to determine, at STEP 420, the number of intended destinations of the message located within the domain of the mail appliance 1 .
  • the filter determines, at STEP 420, the number of intended destinations of the message located within the domain of the mail appliance 1 .
  • the filter 2 compares the number of destinations from STEP 420 with a threshold number, 20 for example, as determined by the rule set 3 for the appliance 1 . If the number is below the threshold then at STEP 450 the filter communicates with the mailbox 5 of the appliance 1 and deposits the message in the incoming mail box associated with each nominated destination.
  • the filter extracts a part of the message and stores it in an appropriate 'remote' storage device.
  • the size threshold used at STEP 41 1 may, for example, indicate the amount of 'local' storage available within the store 6 of the appliance 1 which, if exceeded by the message size, or if a threat is perceived of a number of messages arriving of such a size, then 'remote' storage is selected at STEP 440 to protect the appliance against actual or potential overload.
  • a 'remote' component of the store 6 may be provided for such a purpose.
  • a reference message is created in respect of the stored part of the message, containing a reference to the location of the stored part, and the reference message is delivered, at STEP 450, to the incoming mail box associated with each nominated destination. If, at STEP 421 , the filter determines that the number of intended destinations within the domain is in excess of the threshold for the appliance 1 , 20 for example, then a determination is made, at STEP 430, of the total storage space required to deliver the message to each of the nominated destinations, calculated in this example by multiplying the number of nominated destinations within the domain from STEP 420 by the size of the message from STEP 410.
  • the filter 2 compares the space calculated at STEP 430 with a threshold as determined by the rule set 3, an absolute value of 3 Mbytes for example, or the available storage space in the mailbox 5. If the total size exceeds the threshold, then at STEP 440 a part of the message is extracted, as before, and stored 'remotely' .
  • a reference message is created at STEP 441 and delivered at STEP 450 to the incoming mail box associated with each nominated destination within the domain. Below the threshold for total storage, at STEP 431 , the message is delivered intact to each nominated destination (STEP 450).
  • the filter 2 finds that a reference message has been received by the mail appliance 1 , then further processing steps are carried out by the filter 2 according to the policy expressed by the rule set 3 in respect of reference messages. Preferably, in this embodiment of the invention, the steps are demonstrated by the flow diagram of Figure 5.
  • the filter 2 firstly determines, at STEP 501 , the location of the stored part or parts of the message from the reference or references contained in the reference message, and the size of those stored parts. If necessary, within STEP 501 , the filter 2 may send a signal to the referenced store to obtain information about the size of stored parts.
  • the filter 2 may arrange, at STEP 570, to transfer the stored message part to a more local store, for example the store 6 of the mail appliance 1 .
  • This policy may prove particularly advantageous if a number of destinations within the domain are nominated to receive the message and each is likely to require access to the stored message part.
  • the filter 2 proceeds at STEP 571 to amend the reference message to reference the newly stored part.
  • the same policy, as enacted by steps 570 and 571 may be applied if the filter 2 determines at STEP 510 and 51 1 that, whereas at STEP 502 the store was not overseas, the store is nevertheless inaccessible from one or more of the nominated message destinations in the domain of the mail appliance 1 .
  • the filter 2 may arrange, at steps 570 and 571 respectively, to transfer the stored part to a store that is accessible from all the nominated destinations, the store 6 of the mail appliance 1 for example, and amend the reference message accordingly.
  • the next step, in this embodiment, STEP 520 is to determine whether or not the total size of the message, including stored parts, exceeds a threshold size, 100 Kbytes for example, as determined by the rule set 3. If STEP 520 finds that the threshold size is exceeded, then at STEP 580 the filter 2 communicates with the mailbox 5 of the appliance 1 and deposits only the reference message in the incoming mail box associated with each nominated destination. If at STEP 520 the message size does not exceed the threshold, then at STEP 530 the filter 2 proceeds to determine the number of intended destinations of the message within the domain of the mail appliance 1 . At STEP 531 the filter 2 compares the number determined from STEP 530 with a threshold, 20 for example, as determined by the rule set 3 for the appliance 1 . If the threshold is exceeded then at STEP 580 the filter 2 communicates with the mailbox 5 of the appliance 1 and deposits only the reference message in the incoming mail box associated with each nominated destination.
  • a threshold size 100 Kbytes for example, as determined by the rule set 3.
  • the filter 2 proceeds to determine the total storage space required in the mailbox 5 to deliver the full message in conventional format - that is, the stored part or parts included as a part of each copy of the message to be delivered - to each of the nominated destinations in the domain.
  • the filter 2 compares the total storage space required with a threshold, an absolute value of 3 Mbytes for example, as determined by the rule set 3 for the mail appliance 1 , or the actual storage capacity available in the mailbox 5 at the time. If the required space is found to exceed the available storage capacity in the mailbox 5, for example, then at STEP 580 only the reference message is delivered to the incoming mail box associated with each nominated destination.
  • the option is available, at STEP 550, for a nominated destination to receive the message in either a referenced format, or in full as a conventional message, the stored part or parts being included as part of the message to be delivered to that destination.
  • STEP 550 determines the preference of each nominated recipient for conventional or reference-type messages.
  • a preference for reference messages at STEP 550 results, at STEP 580 in only the reference message being delivered to the incoming mail box associated with that destination.
  • the filter 2 first obtains, at STEP 560, the stored part or parts of the message from the referenced store.
  • the filter 2 then reassembles a message comprising any body parts of the reference message along with the stored part or parts retrieved at STEP 560 from the store, encoded to the applicable message standard and including an appropriate header or headers.
  • the full message is then deposited in the incoming mail box associated with that destination.
  • a message filter according to particular embodiments of the invention may be introduced into any one of a variety of different mail system types, be they implemented in the form of a mail appliance as described above, or using conventional mail servers.
  • a conventional mail server or a mail appliance may be adapted to include a message filter according to preferred embodiments of the invention by means of a controlling computer program, written, for example, in the 'C or "C + + " programming languages, and installed onto a controlling computer within the mail system, the mail server for example.
  • the functionality provided by the filter may be logically contained within the entity that is the mail appliance, although the controlling software may be physically distributed across one or more computing platforms.
  • the controlling program may be arranged to interface with component parts of a mail system or mail appliance by generating standard protocols such as SMTP, FTP, HTTP, SNMP and IMAP4, appropriate to the component being addressed by the control program.
  • a message filter may communicate with, for example, a message store to deposit a reference message bound for a particular destination, or a more general store for storing or retrieving attachments.
  • a message filter is linked to a store comprising a Lotus Notes server ("Lotus Notes" is a trade mark of Lotus Development Corporation) on which a Lotus Notes mailbox and a document database is provided.
  • the Lotus Notes server is chosen for its accessibility from destinations of messages being processed by the filter.
  • Lotus Notes allows groups of users to interact and share information that can be of a highly unstructured nature.
  • it provides a document database server which stores, and manages multi-user access to semi- structured data, including text, images, audio and video.
  • the filter may store, in the Lotus Notes mailbox, a copy of a received message which, as a result of tests performed by the filter, is to be transferred "by reference".
  • Controlling software installed on the Lotus Notes server optionally implemented within Lotus Notes itself and forming part of the functionality of the filter, then analyses the stored message, selects and copies that part or those parts to be referenced, which may include the whole of the stored message, and creates WEB pages in the document database provided on the Lotus Notes server or to be stored elsewhere, incorporating the selected part or parts and/or including appropriate HTML links to them within the pages.
  • the controlling software on the Notes server then signals a message within the filter indicating the URL(s) of the created WEB pages together with information extracted from the message headers required to identify the intended destinations of the message and any other information, as required.
  • the filter is able to create a reference message including the URL(s) and to forward it to each of the one or more intended destinations, either by way of an individual copy to each destination or, if bound for more than one destination, alternatively as a single copy addressed to multiple destinations.
  • the filter may create another reference message from the information held within the Lotus Notes mailbox on the Lotus Notes server and attempt to sent it.
  • any thresholds or other filtering actions defined for the filter 2 according to the rule set 3 may be arranged to apply only in respect of a single user or group of users within the domain of the mail appliance 1 or mail system, or in respect of a user or group of users of another mail appliance or mail system.
  • the rule set 3 may set different thresholds or filtering actions in respect of messages to or from different users or groups of users. If the mail appliance 1 serves a domain comprising a single user, then the rule set 3 will, naturally, define actions of the filter 3 in respect of messages outgoing or incoming to that user. However, the rule set 3 in such a case may also take account of specific sources or destinations outside of the domain of the appliance 1 in respect of messages incoming to or outgoing from the single user in the domain of the appliance 1 .
  • a date of expiration may be specified by the filter 2 and communicated to the store 6 at the time of storing the message part according to a pre-determined policy defined by the rule set 3 for the filter 2.
  • the date of expiration of a stored message part is monitored and, when the expiration date arrives, the stored part is automatically archived and/or deleted from the store.
  • the date of expiration may be also be included by the filter 2 in the corresponding reference message forwarded to each intended destination so that a recipient at each destination is informed of the date before which the stored message part is to be read or copied if it is not to become unavailable.
  • a filter of the present invention may be implemented involving further means of delivery of reference messages to intended destinations and recipients.
  • the filter may be arranged to assemble a synthesised voice reference message indicating the location of a separately stored part of a message, initiating a process of delivery of the voice reference message by means, for example, of a conventional fixed or mobile telephone call or voicemail message.
  • the reference may alternatively be assembled and delivered as a facsimile message, or as a radio pager message to a pager with an alphanumeric display or voice delivery means, or by any other means.
  • a filter according to embodiments of the invention may also be involved as a stepping stone in passing a message from one mail system to another mail system, for example as the first point of receipt in a network of internal company mail systems for messages received from outside the company.
  • a filter may be configured to recognise an intended destination mail system to which a message received by the filter is to be sent, and to apply a policy defined by an appropriate rule set to such messages based upon information held or obtained relating to the identified target mail system or as determined by overall company policy.

Abstract

A message filter (2) is provided to analyse, according to predetermined criteria of analysis stored in a rules database (3), electronic mail messages being sent or received by an electronic mail system. Depending upon the results of the analysis of a message, the filter (2) may select the whole or a part of the message and arrange for the storage of the selected part in a store (6), constructing a reference message containing a reference to the stored message part and forwarding the reference message to an intended destination of the message.

Description

MESSAGING SYSTEM
This invention relates to messaging systems and finds particular application in electronic mail systems. A conventional electronic mail system is based typically upon a client/server arrangement. A user of the mail system gains access typically from a personal computer (PC) or workstation running a proprietary mail client product, providing front-end mail facilities to the user. Relatively simple text-based protocols enable the client to communicate with a compatible mail server over an interconnecting network. The mail server provides user access to a personal mailbox in a message store and handles the interchange of messages between users of the mail system and with users of other mail systems. Communication with other mail systems may take place over either a dedicated network, for example where two mail systems are within the same company, or via the Internet or other publicly available network.
A typical mail system includes facilities to enable a user connected to the system to create a message, define the recipient(s) of the message, despatch the message to the defined recipient(s), store incoming messages in a personal mailbox and download received messages from the mailbox to a PC for viewing. Further facilities are typically provided for the management of a user's mailbox.
Most mail system suppliers have adopted standard protocols and message formats for communication between mail system components and with other proprietary mail systems, particularly where the Internet is used to convey messages between mail systems. An accepted standard Internet message header format is described in Internet Request For Comment (RFC) 822 [CROCKER DH, RFC822 - "Standard for the Format of ARPA Internet Text Messages", 1 982], published on-line on the Internet, while other protocols such as the Internet Message Access Protocol (IMAP4) [CRISPIN M, RFC1 730 - "Internet Message Access Protocol - Version 4", 1 994] and Post Office Protocol (POP3) [MYERS J & ROSE M, RFC1 725 - "Post Office Protocol - Version 3", 1 994] have been adopted for accessing mailboxes.
Mail servers interchange messages with other mail servers of other mail systems, usually via intermediate gateways, using standard message transfer protocols such as the Internet's Simple Message Transport Protocol (SMTP) described in RFC821 [POSTEL, 1 982]. Gateways communicate with other mail system gateways either by direct network interconnection or via a common mail backbone; in the latter case each mail system requires only a gateway to the mail backbone to enable communication with any other mail system with a gateway to the backbone. The Internet's SMTP Mail Service, for example, provides just such a mail backbone.
Conventional electronic mail systems transfer messages by a 'store and forward' method, a message being stored locally before being forwarded to a subsequent stage in a communication path from sender to recipient. Messages are passed from server to gateway, from gateway to gateway and so on using simple protocols such as SMTP. Gateways provide message buffering where necessary to manage the throughput of messages, for example during congestion in an intervening communications link. Gateways also carry out processing where a change in either message format or protocol is required for transmission over the next stage, for instance at a gateway to an X.400 mail backbone or conversion to 7-bit ASCII format at an SMTP gateway, sometimes incurring a considerable processing overhead. If many large messages come together at a particular gateway, considerable delays may arise in the storage and forwarding of those and other messages. The accepted standard format for messages carried by the Internet mail system is defined by RFC822 and comprises header information, including the identity of the sender and the intended recipient(s), the date and subject, followed by the body of the message in a plain text format. A multi-part message may also be assembled comprising several "body parts", each body part including a header and a body, as defined by RFC822 and Multi-purpose Internet Mail Extensions (MIME) documented in RFC1 521 [BORENSTEIN N (Bellcore) & FREED N (Innosoft), RFC1 521 - "MIME (Multi-purpose Internet Mail Extensions) Part One: Mechanisms for Specifying and Describing the Format of Internet Message Bodies", September 1 993] and RFC1 522 [MOORE K, RFC1 522 - "MIME (Multi-purpose Internet Mail Extensions) Part Two: Message Header Extensions for non-ASCII Text", University of Tennessee, September 1 993], now widely adopted. The MIME standard enables one or more message body parts of various types to be conveyed within the message, each body part including a header and a body encoded as 7-bit ASCII text or other encoding to enable transfer through the message system. The MIME standard provides a means for specifying, within the respective headers, the type or types of associated message content being conveyed and their method of encoding, e.g. text, bit-mapped images, audio or video samples, within enclosed body parts to the message. The headings enable a receiver of a message to identify the type of data included within a body part and to invoke an appropriate viewer to decode it and reproduce it locally. In this way, multi-media files or a file generated by a particular computer program, a word processor program for example, may be conveyed as part of a conventional mail message within a body part of the message. The body part comprises a header defining the type of data in the enclosed file, and a body comprising the file itself to which has been applied any further encoding necessary for the purposes of transfer through the mail system. A file conveyed within a message body part in this way is known as an "attachment" to the message. For example, a file containing a digitised audio recording may be conveyed as an attachment to a message, the attachment being encoded for transfer by the mail system and being associated with a header defining the type of data in the file.
A typical small organisation or office may use an Internet-connected local messaging system comprising a mail server and a gateway to SMTP mail. Messages are exchanged with other mail systems via the SMTP gateway. Under the store and forward principle, before despatching a message, a local mail server stores it in the sender's local message store. Similarly, messages received from other mail users are stored in the recipient's incoming mailbox in the message store. In a simple arrangement of two directly interconnected mail systems, a message will be stored twice in passing between the sender and a recipient, once by the sender's local mail server and once by the recipient's. A message bound for multiple recipients will be stored by each recipient's local mail server. Further copies of a message may also be stored at intermediate stages in a communication path, such as at gateways, if only on a temporary queuing basis. A message traversing an internal mail system of a moderate sized organisation occupying a number of sites, may pass through three or four store and forward message transfer stages in passing from a sender to a recipient of that message.
While conventional mail systems have the advantage of simplicity of architecture and of the protocols used, such simplicity can be a disadvantage in the absence of unlimited processing, storage and communication bandwidth. The store and forward principle, while simple, is a relatively inefficient way to handle message transfer, particularly at stages of high demand for message throughput. The potential for total gridlock in a message system is ever present, both within company mail systems and between company and public mail systems. A malicious user may cause a mail system to become unavailable for days by sending a very large message, such as a 2 GByte video attachment, to many users simultaneously. However, while such "mail bombs" are currently the preserve of the saboteur, there is an increasing demand to be able to send legitimate multimedia message attachments across mail systems. Such attachments are inherently large, even after data compression, and may not always be reproducible at the intended destination, wasting mail system resources in their delivery.
According to a first aspect of the present invention, there is provided a message filter arranged, in use, to transfer electronic mail messages, the filter comprising: means to receive a message to be transferred; a rule set defining at least one test to be performed; and storing means connected, in use, to a store; the filter further comprising: testing means to perform a test as determined by the rule set; selecting means arranged, in dependence upon the result of the test, to select a part of the received message, the storing means being arranged to store that selected part in the store; referencing means to assemble a reference message including a reference to the stored part of the message; and forwarding means to forward the reference message to an intended destination.
It is known from the MIME standard to construct an electronic mail message containing a reference to one or more files stored in a known file store. The referenced files are not transported through a mail system with the message; only the reference to the stored file(s) is transported in the message. According to MIME, a mail message may include a header defining the message content type as "message/external-body", and a reference defining the location and identity of an externally stored file. Using this or an equivalent mechanism, a message part may be stored in a file store and a so called "reference message" may be constructed comprising a reference to the externally stored message part. The process in which a reference to an externally stored message part is conveyed in a mail message, rather than conveying the message part itself, shall be referred to herein as "mail by reference". Preferably, a message filter according to embodiments of the invention is installed in a mail system to selectively implement message transfer using the "mail by reference" process. Thus it is not necessary for a whole message to be transferred to an intended destination by means of the mail system itself - it is only necessary to indicate to a recipient, at each intended destination, where a non- transferred part of the message has been stored. That is, an embodiment of the message filter may intercept a message being sent by the mail system, select a part of the message - a body part conveying an attachment for example, which may be the whole of the message or one of a number of body parts conveying different attachments - extract the selected part, which may include decoding from a particular mail system's encoding if necessary to obtain the selected part, and store the resultant part or attachment in a location accessible by equipment at each intended destination of the message. A conventional message is then assembled - a "reference message" - incorporating a reference to the stored part of the message and sent through the mail system to the intended destination(s) in the normal way, in this example without the stored attachment. In this way an attachment would be said to have been "referenced". On arrival of the reference message at an intended destination, a recipient may access the referenced store and transfer the referenced attachment of the original message from the store using, for example, a file transfer protocol such as FTP, but not using the mail system itself to convey the attachment to its intended destination.
In a preferred embodiment, the at least one test to be performed by the message filter includes identifying the resources available within a mail system to receive messages, determining the resources required to receive the message to be transferred and comparing the resources available with the resources required. Embodiments of the invention may provide a means for analysing messages in a mail system and, subject to various pre-determined conditions, to implement a mail by reference method of message transfer for messages being sent. Messages may be sent by users of the mail system or they may be sent by other pieces of equipment. Mail by reference may be implemented either in respect of messages bound for destinations within the same mail system or in respect of messages bound for destinations on other mail systems, or both.
Embodiments of the invention may provide a message filter "close to the source" of messages, for example within the mail system serving the originator of large messages or those intended for widespread distribution, behind a mail system "firewall", within a gateway or at some other point, including equipment associated with the originator of messages. This would be of particular benefit within large organisations having several interconnected mail systems serving different sites. Large internal memos may be sent to multiple destinations subject to a pre-determined policy of referencing messages above a certain size, for example. A message filter according to an embodiment of the invention may implement such a policy at a point close to the source of any such memo distribution.
Preferably, the filter may perform a variety of different tests to determine whether a message should be forwarded in its original form or referenced. Predetermined thresholds may be established for the message filter, for example regarding the total size of a message or the number of intended destinations of a message, taking into account the available storage capacity available to the filter, the message processing capability of the filter and other components of the associated mail system, the number of users of the mail system, etc. If a test on a message to be sent is found to result in a threshold being exceeded in any respect, the filter may reference the whole or a part of the message. Alternatively, the type of data being conveyed by a message may be determined by the filter, the presence of certain types of data causing the whole or a part of the message to be referenced by the filter.
Embodiments of the invention may alternatively provide a message filter "close to the intended destination" of mail messages, for example if such a message filter is installed in each mail system capable of receiving messages, or at a gateway for incoming messages to a mail system or group of mail systems, or installed as part of a firewall to a company mail system. Such a filter may also be installed on equipment associated with particular destinations, for example to assist with the management of incoming messages, or be arranged to act in respect of messages incoming to or outgoing from a particular user or group of users. The message filter may act on messages originating elsewhere in the same mail system or group of mail systems, on messages incoming to the mail system from other mail systems or on all incoming messages to a particular destination.
According to a second aspect of the invention there is provided a message filter arranged, in use, to receive reference messages, the filter comprising: means to receive a reference message, the reference message including a respective identifier for each of one or more intended destinations and including a reference to a stored message part; a rule set defining at least one test to be performed; and storing means connected, in use, to a store; the filter further comprising: testing means to perform a test as defined by the rule set; message assembly means arranged, in dependence upon the result of the test, to assemble a message to be sent; and forwarding means to forward the message to be sent to an intended destination of the reference message.
The filter may be arranged to receive reference messages and to deposit a received reference message with an intended recipient without change, or to perform functions in respect of the reference message and the stored part or parts of the original message referenced within the reference message, according to pre- determined conditions established for the filter.
A message filter according to the second aspect of the present invention may be found especially useful, for example, in limiting the amount of storage space consumed within the mail system by large messages bound for many intended destinations within that mail system. Such a facility may, for example, offer protection against malicious attack by "mail bombs" originating either from inside or outside the mail system.
Preferably the store is a distributed data store and the reference to a stored part of a received message comprises an identification of the location of the stored part of the message in the distributed data store. The Internet is a multimedia computer communications network built on worldwide telephone and data networks. Over 100,000 servers of various types are connected to the Internet providing a publicly accessible distributed data store. An "HTTP server" is a particular type of server holding files of information as data written according to an Internet communication protocol called HyperText Transfer Protocol (HTTP). Data files stored on HTTP servers and accessible by means of HTTP are known as "WEB pages" which form part of the "World Wide Web", or simply the "WEB". WEB pages are written in a special WEB language called HyperText Markup Language (HTML) creating links to other pages on the WEB, as appropriate, and providing a means to navigate through information on the WEB. Information held on the WEB is accessible to anyone having a computer connected to the Internet and with an interest in accessing it. A Universal Resource Locator (URL) has been adopted as a standard among Internet users to provide a consistent international naming convention to identify all WEB resources, including for instance documents, programs, sound and video clips. A URL defines exactly where to find any given resource on the WEB. The Hypertext Transfer Protocol (HTTP) enables URL-identified files (WEB pages) to be accessed and downloaded to user equipment connected to the Internet.
Users typically access information held on the WEB using proprietary WEB browser products running on their personal computers (PCs) or workstations linked to the Internet. WEB browsers communicate with WEB resources, such as HTTP servers, using the standard Internet protocols such as HTTP to download selected WEB pages, interpret embedded HTML commands inserted at the time of markup by the WEB page authors and, if appropriate, display those pages graphically. Browsers are available to reproduce multi-media files transferred over the Internet, offering greater levels of functionality than is typical with electronic mail system client products.
A message filter according to an embodiment of the present invention may store a message or a part of the message on, for example, a commonly accessible WEB server as WEB pages referenced by a URL, constructing and forwarding a corresponding reference message specifying the URL to an intended destination from where, in turn, use may be made of the Internet and Internet protocols to download the URL-referenced message or message part. A recipient at the destination may then use a WEB browser, for example, to view the downloaded message or message part.
Similarly, in respect of an incoming reference message, a message filter according to an embodiment of the present invention may recognise a URL contained in the message and, if required, download the identified WEB page or pages on behalf of a recipient at the destination. According to a third aspect of the invention there is provided a method of transferring electronic mail messages, comprising: receiving a message to be transferred, the message including a respective identifier for one or more intended destinations; performing a pre-determined test; and, in dependence upon the result of said pre-determined test: selecting a part of the message and storing the selected part in a store; assembling a reference message, the reference message including a reference to the stored part of the message; and forwarding the reference message to an intended destination of the received message.
According to a fourth aspect of the invention, there is provided a method of transferring electronic mail messages, comprising: receiving a message to be transferred, the message including a respective identifier for one or more intended destinations and including a reference to a stored message part; performing a pre-determined test; and, in dependence upon the result of said pre-determined test: assembling a message to be delivered; and forwarding the message to be delivered to an intended destination of the received message.
According to a fifth aspect of the invention, there is provided an electronic mail system including a message filter arranged to analyse electronic mail messages, the filter comprising: means to receive a message to be analysed; a rule set defining at least one test to be performed; and storing means connected, in use, to a store; the filter further comprising: testing means to perform a test as determined by the rule set; selecting means arranged, in dependence upon the result of the test, to select a part of the received message, the storing means being arranged to store the selected part in the store; referencing means to assemble a reference message including a reference to the stored part of the message; and forwarding means to forward the reference message to an intended destination. A message filter will now be described as an embodiment of the present invention, by way of example only, with reference to the accompanying drawings of which:
Figure 1 shows a mail appliance incorporating a message filter according to embodiments of the invention; Figure 2 depicts an example of message transfer by reference;
Figure 3 is a flow diagram showing the operation of a filter according to a particular embodiment of the invention, in respect of outgoing messages from users of a mail appliance incorporating the invention;
Figure 4 is a flow diagram showing the operation of a message filter according to a particular embodiment of the invention, in respect of conventional mail messages incoming to users of a mail appliance incorporating the invention;
Figure 5 is a flow diagram, extended from Figure 4, showing the operation of a message filter according to a particular embodiment of the invention, in respect of incoming reference messages.
Referring to Figure 1 , the message filter 2 is shown as a component of a so called "mail appliance" 1 . The mail appliance 1 may be regarded as a logical association of features arranged, according to embodiments of the invention, to provide electronic mail services to a domain of users, such as a company office or to one or more pieces of equipment. The mail appliance 1 may include known features of a conventional electronic mail system, found implemented on a conventional mail server, together with features particular to the present invention. In particular, the mail applicance 1 includes a conventional author component 4 to assist in the creation of electronic mail messages and a conventional mailbox 5 providing a store for incoming or outgoing message. It also includes a store 6 for further file storage by the mail appliance 1 and a message filter 2 according to a preferred embodiment of the invention, connected to a rule set 3 to control the operation of the filter 2 for the mail appliance 1 . The store 6, while logically part of the mail appliance 1 , may be a remote store on a Web server, accessible over the Internet. The message filter 2 analyses all messages being sent from sources within the domain of the mail appliance 1 or being received by the mail appliance 1 from outside the domain, applying the principles of message transfer and delivery by reference, where required according to the rule set 3. The message filter 2 of Figure 1 may be implemented in one of a number of possible ways. For example, it may be implemented as part of the functionality of a mail server, arranged to intercept messages being sent by clients of the mail server or received by the mail server from elsewhere. Alternatively, the filter 2 may be arranged to operate as a stand-alone device, communicating with mail servers or directly with mail server components using conventional protocols such as SMTP, IMAP4 and POP3 and with remote storage devices using HTTP or FTP for example.
Referring to Figure 2, an example of electronic mail message transfer involving a two part message 20 is shown. The first part 21 is a body part comprising an initial header, "HEADER 1 ", preferably defined in accordance with the Internet mail standard for header information established by RFC822 in combination with Multi-purpose Internet Mail Extensions (MIME) defined by RFC1 521 /2, followed optionally by a plain text body inserted by the sender. For example, "HEADER 1 " may comprise the following:
MIME-Version: 1 .0
Date: Wed, 1 1 Sep 1 996 1 9:08:00 -0400
From: Aye Sender < asender@this-host.bt.co.uk >
Subject: Graphic for meeting To: You There < you.there@that-host.bt.co.uk >
Cc: The Boss <tboss@some-host.bt.co.uk>
Content-Type: multipart/mixed; boundary = 99
The optional plain text portion following "HEADER 1 " may be a simple message to the recipient, for example, "Print the attachment and make copies." followed by a delimiter "-99" to define the boundary of the body part.
The second part 22 is a body part comprising a header, "HEADER 2", and a body. The body may be an encoded attachment, for example a document, image or audio clip being conveyed as part of the message 20. The header "HEADER 2" may comprise simply a description of the attachment data type and method of encoding, for example:
Content-Type: image/gif
Content-Transfer-Encoding: base64
In this example, the base64 encoded attachment image is inserted following "HEADER 2", terminating with the delimiter "-99--" to indicate the end of the body part and the end of the message 20. If required, additional body parts comprising headers and encoded attachments may be included in the message 20.
On receiving a message 20 conveying the attachment, the message filter
2, operating in accordance with the rule set 3, may determine that the attachment is, for example, too large to be conveyed by an electronic mail system and should be stored in a store 6, available to the filter 2 and likely to be available from the intended destination of the message. The filter 2 separates the attachment from the message 20, if necessary decoding any encoding applied for the purposes of message transfer, and stores it (24) in the store 6. The filter 2 then inserts or appends to the remaining first part 21 of the message 20 a reference defining the location and identity of the stored attachment (24) in the store 6. The reference may be incorporated as an additional field in the message header or as a simple plain text entry in the message identifiable as such to the recipient. The resultant message 23, including the reference to the stored attachment (24), is called a "reference message" . The reference message 23 is then conveyed by the electronic mail system as a conventional message to the intended destination or destinations.
Preferably, information selected from the message headers "HEADER 1 " and/or "HEADER 2" may be stored (24) along with the attachment in the store 6 so that an audit trail may be preserved in respect of stored message parts. Alternatively, the whole of the original message may be stored in the store 6 rather than just an attachment or particular body part of the message.
Upon receipt of the reference message 23, a recipient user or system at the destination may use the supplied reference in a suitable file transfer mechanism to either transfer or stream the stored attachment (24), via an interlinking communications network, for local reproduction. The attachment (22, 24) would not, however, be transferred using the electronic mail system.
As illustrated in Figure 1 , the filter 2 communicates with mail appliance storage devices (6) and other resources (4, 5) and, if necessary, with other mail systems, using standard network and mail system protocols such as SMTP for message transfer, FTP for file transfer, etc. and supports standard message formats. In addition, a standard mechanism is already available, as defined by MIME, by which a reference to an externally stored message part may be defined and conveyed in a reference message 23 as part of the message header. The MIME "message/external-body" sub-type may be used in the Content-Type field of a MIME message header, followed by a reference to the computing platform, file identity and directory in which the separated message part or attachment is externally stored. Therefore, in the example above, the reference message 23 may comprise a header "HEADER 3" constructed using fields from the original "HEADER 1 " and "HEADER 2" together with information on the store location 6 and identity assigned to the stored message part 24, the header being followed by any plain text included with the original message 20 in the first part 21 , as follows:
MIME-Version: 1 .0
Date: Wed, 1 1 Sep 1 996 1 9:08:00 -0400
From: Aye Sender < asender@this-host.bt.co.uk >
Subject: Graphic for meeting
To: You There < you.there@that-host.bt.co.uk > Cc: The Boss <tboss@some-host.bt.co.uk>
Content-Type: multipart/mixed; boundary = 99 Content-Type: message/external-body; name = "myslide.gif"; site = "myserver.bt.com"; access-type = ANON-FTP; directory = "graphics"; mode = "image"; expiration = "Mon, 1 May 1 997 10:00:00 -0000 (GMT)" -99
Content-Type: Text/plain; charset = ASCII
Print the attachment and make copies.
-99-
The attachment in this example is stored on the server "myserver.bt.com" in the "graphics" directory as a file with filename "myslide.gif" and may be transferred from the server using the ANON-FTP file transfer protocol. However, other means for specifying the location of a stored message part may be used in a reference message as long as the means are standardised among potential participant mail systems and appliances.
In determining the conditions under which a received message or a part of a message is to be referenced, the filter 2 interrogates the rule set 3. The rule set 3 may comprise a database of rules expressing the policy of the filter in respect of different types of message. Rules may be implemented in a number of different forms dependent upon the complexity of the policy being defined by the rule set and the flexibility required to change the rules from time to time.
For example, a simple policy of referencing any message to be delivered to one of a number of particular mail destinations may be implemented by means of a rule set database comprising a simple plain text data file listing the identities of those destinations in respect of whose messages the policy is to apply. A computer program implementing the functionality of the filter 2 may comprise, at the point at which the rule set 3 is interrogated upon receipt of a message to be delivered, a simple conditional instruction:
if < MESSAGE_RECIPIENT > in data file
{
## execute MAIL BY REFERENCE subroutine if a match has been found
} else
{
## execute DEFAULT subroutine if no match has been found
} where MESSAGE_RECIPIENT is the identity of an intended destination specified in the header of the received message and MAIL_BY_REFERENCE is a program subroutine to select a part of the message, store it and create a corresponding reference message. If the identity of a recipient of the message is not contained in the data file, then the filter's DEFAULT program subroutine may pass the message on for delivery without change.
More complex policies may be implemented in the rule set 3 by means of instructions in the rule set database to execute particular filter program subroutines under specified conditions. For example, an instruction may be stored in the rule set 3 to reference all messages addressed to a particular destination you.there@that-server.bt.co.uk, but only if the message size exceeds 10kbytes and there is at least one attachment included in the message. An appropriate instruction may be as follows:
you.there@that-server.bt.co.uk
{SIZE: > 10k | | ATTACHMENTS: > 0}MAIL_BY_REFERENCE {}DEFAULT
The designations "SIZE:" and "ATTACHMENTS:" may refer to predefined functions included in the computer program implementing the functionality of the filter 2, designed respectively to determine the size of the received message, for example by counting the bytes, and to determine the number and type of body parts making up the received message, for example by analysing the message headers. In the event that the conditional statement within brackets { ... } is true, the MAIL BY REFERENCE program is to be executed to reference a part or parts of the received message, otherwise to execute a DEFAULT program - to deliver the message intact, for example.
If required, instructions held within a rule set database may become quite complex under this scheme. For example:
{SIZE: > 10k | | ATTACHMENTS: = 1 | | RECIPIENTS: > 5}; MAIL_BY_REFERENCE
{DESTINATION_DOMAIN:bt.com}MAIL_BY_REFERENCE_USER {ATTACHMENTS: > 1 }MAlL_BY_REFERENCE_ATTACHMENTS {}DEFAULT
This rule would reference any message of size greater than 1 0 kbytes, conveying a single attachment and bound for more than 5 destinations. Conditionally, messages bound for the domain "bt.com", would only be referenced in respect of particular users, defined elsewhere in the rule set for example. Failing that, if the message included more than one attachment, then each would be referenced in the text portion of the reference message. The DEFAULT behaviour would be carried out by the filter if none of these requirements were met. Advantageously, a message filter may be located at an early stage in the transmission path of a message, at the originating mail appliance for example, so that any portion due to be filtered out of an electronic mail system by the filter may be unbound from the message, stored and referenced close to its source rather than be passed through a significant portion of the mail system. With reference to Figure 3, a flow diagram is provided showing the operation of a message filter 2 wherein messages are being sent from sources within the domain of a mail appliance 1 incorporating the filter 2. To begin, at STEP 301 , the filter 2 receives a message to be sent from within the domain. At STEP 302 the filter 2 interrogates the rule set 3 to determine the tests to be performed on the received message, expressed for example using the scheme described above. In the example of Figure 3, the tests defined by the rule set 3 begin at STEP 303 with a determination by the filter 2 of the size of the message to be sent. At STEP 304, the filter 2 compares the message size from STEP 303 with a threshold size, 100 Kbytes for example, as determined by the rule set 3. If the size does not exceed the threshold then the filter proceeds to STEP 310 to determine the type of data being conveyed by the message. At STEP 31 1 , the filter 2 tests for a multi-media data type attachment. If the message data type is found not to be multi-media, then the filter proceeds to STEP 320 to determine the number of intended destinations of the message within the domain of the mail appliance 1 . At STEP 321 , the filter 2 compares the number of destinations from STEP 320 with a threshold determined by the rule set 3. If the number is found to exceed the threshold, 20 destinations for example, then at STEP 350 the message is passed on to the next stage of transit; to the incoming mail box (5) associated with each destination if within the domain of the mail appliance 1 or, if external, sent over the network to the next message transfer stage en route to another mail appliance or mail system.
If, at STEP 304, the message was found to exceed the threshold size for the mail appliance 1 according to the rule set 3, then at STEP 340 the filter 2 proceeds to select a part of the message, in this example an attachment to the message, and to store the selected part in a store 6 appropriate to the type of data conveyed by the message. The selected part may, in general, include the whole of the message, or one or more body parts selected from the message. Optionally the selected part or parts include header information. At STEP 341 , the filter 2 creates a reference message containing a reference to the location and identity of the stored part of the message in the store 6. At STEP 342 the filter 2 sends the reference message to the or each intended destination of the message. For destinations within the domain of the mail appliance 1 , STEP 342 may involve the filter 2 communicating with the mailbox 5 and depositing the reference message in the incoming mail box associated with each nominated destination. In this embodiment, any message part of multi-media data type detected at STEP 31 1 is also stored and referenced by steps 340 to 342, though a video server, for example, may then be selected within the store 6 at STEP 340 if the data type was found to be 'video' . If the number of intended destinations within the domain of the appliance
1 is found to exceed the mail appliance threshold, at STEP 321 , according to the rule set 3, then at STEP 330 the filter 2 determines the total message storage space required to deliver the message to the incoming mail box associated with each nominated destination within the domain. At STEP 331 the filter 2 compares the total storage space required with a threshold level for the mail appliance as determined by the rule set 3. The threshold may be an absolute limit, 3 Mbytes for example, or it may be set by a determination of available mailbox 5 storage space. If, at STEP 331 , the threshold is exceeded, then at STEP 340 a part of the message is selected and extracted and a single copy stored in a store 6. STEP 341 creates a reference message in respect of that stored part and STEP 342 sends the reference message to each intended destination. It is also possible, if required at STEP 342 according to the rule set 3, to send reference messages only to intended destinations within the domain of the mail appliance 1 , the original message being sent in full to destinations outside the domain without referencing. A filter designed to support a large mail user community with a large message throughput may be adapted to rapid operation in a fast processing environment whereas a filter adapted to run on a lap-top PC in support of a single roving mail user may be satisfactorily implemented on a much smaller scale, although offering similar features. Correspondingly, the associated rule set 3 may be adapted to the filter's environment, establishing thresholds for message analysis taking account, for example, of the volume of storage space available to the mail appliance 1 , the processing capability of the filter, the number of users within the domain, the expected number of messages incoming to or outgoing from the domain and the communications bandwidth available to and from the mail appliance 1 . Available storage space may be automatically monitored so that thresholds relating to message size and number of recipients, for example, may be adjusted dynamically.
With reference to Figure 4, a flow diagram is provided showing the operation of a message filter 2 in respect of messages being received by the mail appliance 1 from outside the domain of the appliance, each message being bound for a mail destination within the domain. At STEP 401 an incoming message is received by the filter 2. At STEP 402 the filter 2 interrogates the rule set 3 to determine the tests to be performed in respect of messages incoming to the mail appliance 1 . Specifically in this example, the tests so determined begin at STEP 403 with a test to establish whether the message being received by the appliance
1 and hence by the filter 2 is of the conventional type, that is, all parts of the incoming message are being conveyed and delivered to the appliance 1 without referencing, or whether the message is a reference message containing a reference to a part of the message stored elsewhere and not conveyed to the appliance 1 . If at STEP 403 the message is found to be of the conventional type, then the filter determines, at STEP 410, the size of the message. At STEP 41 1 the filter 2 compares the size from STEP 410 with a threshold size, 100 Kbytes for example, as determined by the rule set 3. If the size is below the threshold then the filter proceeds to determine, at STEP 420, the number of intended destinations of the message located within the domain of the mail appliance 1 . At STEP 421 , the filter
2 compares the number of destinations from STEP 420 with a threshold number, 20 for example, as determined by the rule set 3 for the appliance 1 . If the number is below the threshold then at STEP 450 the filter communicates with the mailbox 5 of the appliance 1 and deposits the message in the incoming mail box associated with each nominated destination.
If, at STEP 41 1 , the message size is found to exceed the threshold, then at STEP 440 the filter extracts a part of the message and stores it in an appropriate 'remote' storage device. The size threshold used at STEP 41 1 may, for example, indicate the amount of 'local' storage available within the store 6 of the appliance 1 which, if exceeded by the message size, or if a threat is perceived of a number of messages arriving of such a size, then 'remote' storage is selected at STEP 440 to protect the appliance against actual or potential overload. A 'remote' component of the store 6 may be provided for such a purpose. At STEP 441 a reference message is created in respect of the stored part of the message, containing a reference to the location of the stored part, and the reference message is delivered, at STEP 450, to the incoming mail box associated with each nominated destination. If, at STEP 421 , the filter determines that the number of intended destinations within the domain is in excess of the threshold for the appliance 1 , 20 for example, then a determination is made, at STEP 430, of the total storage space required to deliver the message to each of the nominated destinations, calculated in this example by multiplying the number of nominated destinations within the domain from STEP 420 by the size of the message from STEP 410. At STEP 431 the filter 2 compares the space calculated at STEP 430 with a threshold as determined by the rule set 3, an absolute value of 3 Mbytes for example, or the available storage space in the mailbox 5. If the total size exceeds the threshold, then at STEP 440 a part of the message is extracted, as before, and stored 'remotely' . A reference message is created at STEP 441 and delivered at STEP 450 to the incoming mail box associated with each nominated destination within the domain. Below the threshold for total storage, at STEP 431 , the message is delivered intact to each nominated destination (STEP 450).
If, at STEP 403 in Figure 4, the filter 2 finds that a reference message has been received by the mail appliance 1 , then further processing steps are carried out by the filter 2 according to the policy expressed by the rule set 3 in respect of reference messages. Preferably, in this embodiment of the invention, the steps are demonstrated by the flow diagram of Figure 5. Referring to Figure 5, the filter 2 firstly determines, at STEP 501 , the location of the stored part or parts of the message from the reference or references contained in the reference message, and the size of those stored parts. If necessary, within STEP 501 , the filter 2 may send a signal to the referenced store to obtain information about the size of stored parts. At STEP 502, if it is possible for the filter 2 to determine from the reference that the message part is stored on an overseas server, then, in the interests of economy of cost of access and potential time to transfer the message part, for example, the filter 2 may arrange, at STEP 570, to transfer the stored message part to a more local store, for example the store 6 of the mail appliance 1 . This policy may prove particularly advantageous if a number of destinations within the domain are nominated to receive the message and each is likely to require access to the stored message part.
Having moved the stored message part to a more local store at STEP 570, the filter 2 proceeds at STEP 571 to amend the reference message to reference the newly stored part. The same policy, as enacted by steps 570 and 571 , may be applied if the filter 2 determines at STEP 510 and 51 1 that, whereas at STEP 502 the store was not overseas, the store is nevertheless inaccessible from one or more of the nominated message destinations in the domain of the mail appliance 1 . In that event, the filter 2 may arrange, at steps 570 and 571 respectively, to transfer the stored part to a store that is accessible from all the nominated destinations, the store 6 of the mail appliance 1 for example, and amend the reference message accordingly.
The next step, in this embodiment, STEP 520, is to determine whether or not the total size of the message, including stored parts, exceeds a threshold size, 100 Kbytes for example, as determined by the rule set 3. If STEP 520 finds that the threshold size is exceeded, then at STEP 580 the filter 2 communicates with the mailbox 5 of the appliance 1 and deposits only the reference message in the incoming mail box associated with each nominated destination. If at STEP 520 the message size does not exceed the threshold, then at STEP 530 the filter 2 proceeds to determine the number of intended destinations of the message within the domain of the mail appliance 1 . At STEP 531 the filter 2 compares the number determined from STEP 530 with a threshold, 20 for example, as determined by the rule set 3 for the appliance 1 . If the threshold is exceeded then at STEP 580 the filter 2 communicates with the mailbox 5 of the appliance 1 and deposits only the reference message in the incoming mail box associated with each nominated destination.
If, at STEP 531 , the number of destinations is found to be below the threshold, then at STEP 540 the filter 2 proceeds to determine the total storage space required in the mailbox 5 to deliver the full message in conventional format - that is, the stored part or parts included as a part of each copy of the message to be delivered - to each of the nominated destinations in the domain. At STEP 541 the filter 2 compares the total storage space required with a threshold, an absolute value of 3 Mbytes for example, as determined by the rule set 3 for the mail appliance 1 , or the actual storage capacity available in the mailbox 5 at the time. If the required space is found to exceed the available storage capacity in the mailbox 5, for example, then at STEP 580 only the reference message is delivered to the incoming mail box associated with each nominated destination. If the required space is found at STEP 541 to be below the threshold, and if sufficient storage capacity is available, the option is available, at STEP 550, for a nominated destination to receive the message in either a referenced format, or in full as a conventional message, the stored part or parts being included as part of the message to be delivered to that destination. STEP 550 determines the preference of each nominated recipient for conventional or reference-type messages. A preference for reference messages at STEP 550 results, at STEP 580 in only the reference message being delivered to the incoming mail box associated with that destination. However, to satisfy a preference at STEP 550 by a particular destination for conventional message formats, the filter 2 first obtains, at STEP 560, the stored part or parts of the message from the referenced store. At STEP 561 the filter 2 then reassembles a message comprising any body parts of the reference message along with the stored part or parts retrieved at STEP 560 from the store, encoded to the applicable message standard and including an appropriate header or headers. At STEP 580 the full message is then deposited in the incoming mail box associated with that destination.
A message filter according to particular embodiments of the invention may be introduced into any one of a variety of different mail system types, be they implemented in the form of a mail appliance as described above, or using conventional mail servers. A conventional mail server or a mail appliance may be adapted to include a message filter according to preferred embodiments of the invention by means of a controlling computer program, written, for example, in the 'C or "C + + " programming languages, and installed onto a controlling computer within the mail system, the mail server for example. Alternatively, in the case of a mail appliance, the functionality provided by the filter may be logically contained within the entity that is the mail appliance, although the controlling software may be physically distributed across one or more computing platforms. In either implementation, the controlling program may be arranged to interface with component parts of a mail system or mail appliance by generating standard protocols such as SMTP, FTP, HTTP, SNMP and IMAP4, appropriate to the component being addressed by the control program. In this way a message filter according to preferred embodiments of the invention may communicate with, for example, a message store to deposit a reference message bound for a particular destination, or a more general store for storing or retrieving attachments. Preferably, a message filter is linked to a store comprising a Lotus Notes server ("Lotus Notes" is a trade mark of Lotus Development Corporation) on which a Lotus Notes mailbox and a document database is provided. The Lotus Notes server is chosen for its accessibility from destinations of messages being processed by the filter. Lotus Notes allows groups of users to interact and share information that can be of a highly unstructured nature. In particular, it provides a document database server which stores, and manages multi-user access to semi- structured data, including text, images, audio and video. The filter may store, in the Lotus Notes mailbox, a copy of a received message which, as a result of tests performed by the filter, is to be transferred "by reference". Controlling software installed on the Lotus Notes server, optionally implemented within Lotus Notes itself and forming part of the functionality of the filter, then analyses the stored message, selects and copies that part or those parts to be referenced, which may include the whole of the stored message, and creates WEB pages in the document database provided on the Lotus Notes server or to be stored elsewhere, incorporating the selected part or parts and/or including appropriate HTML links to them within the pages. The controlling software on the Notes server then signals a message within the filter indicating the URL(s) of the created WEB pages together with information extracted from the message headers required to identify the intended destinations of the message and any other information, as required. From this information the filter is able to create a reference message including the URL(s) and to forward it to each of the one or more intended destinations, either by way of an individual copy to each destination or, if bound for more than one destination, alternatively as a single copy addressed to multiple destinations. In the event that a reference message is lost or, for some reason, does not reach an intended destination, the filter may create another reference message from the information held within the Lotus Notes mailbox on the Lotus Notes server and attempt to sent it.
Any thresholds or other filtering actions defined for the filter 2 according to the rule set 3 may be arranged to apply only in respect of a single user or group of users within the domain of the mail appliance 1 or mail system, or in respect of a user or group of users of another mail appliance or mail system. The rule set 3 may set different thresholds or filtering actions in respect of messages to or from different users or groups of users. If the mail appliance 1 serves a domain comprising a single user, then the rule set 3 will, naturally, define actions of the filter 3 in respect of messages outgoing or incoming to that user. However, the rule set 3 in such a case may also take account of specific sources or destinations outside of the domain of the appliance 1 in respect of messages incoming to or outgoing from the single user in the domain of the appliance 1 . Preferably in embodiments of the filter, to prevent the accumulation of old message parts stored in a store 6, a date of expiration may be specified by the filter 2 and communicated to the store 6 at the time of storing the message part according to a pre-determined policy defined by the rule set 3 for the filter 2. Under store management procedures, the date of expiration of a stored message part is monitored and, when the expiration date arrives, the stored part is automatically archived and/or deleted from the store. The date of expiration may be also be included by the filter 2 in the corresponding reference message forwarded to each intended destination so that a recipient at each destination is informed of the date before which the stored message part is to be read or copied if it is not to become unavailable.
Other possible embodiments of a filter of the present invention may be implemented involving further means of delivery of reference messages to intended destinations and recipients. For example, the filter may be arranged to assemble a synthesised voice reference message indicating the location of a separately stored part of a message, initiating a process of delivery of the voice reference message by means, for example, of a conventional fixed or mobile telephone call or voicemail message. The reference may alternatively be assembled and delivered as a facsimile message, or as a radio pager message to a pager with an alphanumeric display or voice delivery means, or by any other means.
A filter according to embodiments of the invention may also be involved as a stepping stone in passing a message from one mail system to another mail system, for example as the first point of receipt in a network of internal company mail systems for messages received from outside the company. If required, such a filter may be configured to recognise an intended destination mail system to which a message received by the filter is to be sent, and to apply a policy defined by an appropriate rule set to such messages based upon information held or obtained relating to the identified target mail system or as determined by overall company policy.

Claims

1 . A message filter arranged, in use, to transfer electronic mail messages, the filter comprising: means to receive a message to be transferred; a rule set defining at least one test to be performed; and storing means connected, in use, to a store; the filter further comprising: testing means to perform a test as determined by the rule set; selecting means arranged, in dependence upon the result of the test, to select a part of the received message, the storing means being arranged to store that selected part in the store; referencing means to assemble a reference message including a reference to the stored part of the message; and forwarding means to forward the reference message to an intended destination.
2. A message filter as in Claim 1 , wherein the at least one test to be performed includes identifying the resources available within a mail system to receive messages, determining the resources required to receive the message to be transferred and comparing the resources available with the resources required.
3. A message filter as in Claim 1 or Claim 2, wherein the at least one test to be performed includes a test to determine the size of a part of the received message and to compare the determined size with a pre-determined threshold.
4. A message filter as in any one of Claims 1 to 3, wherein the at least one test to be performed includes a test to determine the number of intended destinations of the received message and to compare the determined number with a pre-determined threshold.
5. A message filter as in any one of Claims 1 to 4, wherein the at least one test to be performed includes a test to determine whether or not the data conveyed by a part of the received message is of a pre-determined type.
6. A message filter as in any one of the preceding claims, wherein the part of the message to be stored is an attachment of the message.
7. A message filter as in any one of the preceding claims, wherein the part of the message to be stored includes information contained in a header of the message.
8. A message filter as in any one of the preceding claims, wherein the part of the message to be stored is the whole of the received message.
9. A message filter as in any one of the preceding claims, wherein the store is a distributed data store and the reference to a stored part of the received message comprises an identification of the location of the stored part of the message in the distributed data store.
10. A message filter as in any one of the preceding claims, wherein the store is located on a server connected to the Internet and the reference to a stored part of the received message comprises the Internet Universal Resource Locator (URL) of the stored part of the message.
1 1 . A message filter arranged, in use, to receive reference messages, the filter comprising: means to receive a reference message, the reference message including a respective identifier for each of one or more intended destinations and including a reference to a stored message part; a rule set defining at least one test to be performed; and storing means connected, in use, to a store; the filter further comprising: testing means to perform a test as defined by the rule set; message assembly means arranged, in dependence upon the result of the test, to assemble a message to be sent; and forwarding means to forward the message to be sent to an intended destination of the reference message.
1 2. A message filter as in Claim 1 1 , wherein the assembly means are arranged to retrieve the message part referenced by the received reference message and, in dependence upon the result of the test, to assemble a message to be sent including the message part.
1 3. A message filter as in Claim 1 1 , wherein the assembly means are arranged to retrieve the message part referenced by the received reference message, said storing means are arranged to store the message part in the store and the assembly means are further arranged to assemble a message to be sent including a reference to the retrieved message part stored in the store.
14. A method of transferring electronic mail messages, comprising: receiving a message to be transferred, the message including a respective identifier for one or more intended destinations; performing a pre-determined test; and, in dependence upon the result of said pre-determined test: selecting a part of the message and storing the selected part in a store; assembling a reference message, the reference message including a reference to the stored part of the message; and forwarding the reference message to an intended destination of the received message.
1 5. A method of transferring electronic mail messages, comprising: receiving a message to be transferred, the message including a respective identifier for one or more intended destinations and including a reference to a stored message part; performing a pre-determined test; and, in dependence upon the result of said pre-determined test: assembling a message to be delivered; and forwarding the message to be delivered to an intended destination of the received message.
1 6. A method of transferring electronic mail messages as in Claim 1 5, including, in dependence upon the result of said pre-determined test, retrieving the stored message part referenced by the received message and including the retrieved message part in the message to be delivered.
1 7. A method of transferring electronic mail messages as in Claim 1 5, including, in dependence upon the result of said pre-determined test: retrieving the stored message part referenced by the received message; storing the retrieved message part in a store; and including a reference to the stored retrieved message part in the message to be delivered.
1 8. An electronic mail system including a message filter arranged to analyse electronic mail messages, the filter comprising: means to receive a message to be analysed; a rule set defining at least one test to be performed; and storing means connected, in use, to a store; the filter further comprising: testing means to perform a test as determined by the rule set; selecting means arranged, in dependence upon the result of the test, to select a part of the received message, the storing means being arranged to store the selected part in the store; referencing means to assemble a reference message including a reference to the stored part of the message; and forwarding means to forward the reference message to an intended destination.
PCT/GB1998/002696 1997-09-16 1998-09-08 Messaging system WO1999014909A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
AU88801/98A AU8880198A (en) 1997-09-16 1998-09-08 Messaging system

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
EP97307200.2 1997-09-16
EP97307200 1997-09-16

Publications (1)

Publication Number Publication Date
WO1999014909A1 true WO1999014909A1 (en) 1999-03-25

Family

ID=8229513

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/GB1998/002696 WO1999014909A1 (en) 1997-09-16 1998-09-08 Messaging system

Country Status (2)

Country Link
AU (1) AU8880198A (en)
WO (1) WO1999014909A1 (en)

Cited By (26)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1176535A2 (en) * 2000-07-26 2002-01-30 Canon Kabushiki Kaisha Communicating apparatus and communicating method
WO2002021790A2 (en) * 2000-09-07 2002-03-14 Axis Mobile Ltd. E-mail proxy
GB2367707A (en) * 2000-06-28 2002-04-10 Neil Lennox Munro Internet activated telephone alert
WO2002043414A2 (en) * 2000-11-22 2002-05-30 Nokia Corporation Multimedia messaging services
WO2002062026A1 (en) * 2001-01-29 2002-08-08 Siemens Aktiengesellschaft Message transfer device and method for transferring messages
EP1235396A1 (en) * 2000-09-26 2002-08-28 Interlex Inc. System and method for using e-mail as advertisement medium
WO2002082226A2 (en) * 2001-04-09 2002-10-17 United States Postal Service System, method, and article of manufacture for filtering mail items based upon recipient preference
WO2002100063A1 (en) * 2001-06-01 2002-12-12 Siemens Aktiengesellschaft Method for handling a message with a multimedia reference
EP1280039A2 (en) * 2001-07-26 2003-01-29 Networks Associates Technology, Inc. Detecting e-mail propagated malware
EP1286292A2 (en) * 2001-08-21 2003-02-26 Matsushita Electric Industrial Co., Ltd. Method and system for data distribution
FR2830096A1 (en) * 2001-09-21 2003-03-28 France Telecom Sending of content from servers to terminals, uses association of reference code and content to allow selection of content for pushing to terminals
WO2003105425A1 (en) * 2002-06-07 2003-12-18 Siemens Aktiengesellschaft Transmission of mms messages with the conversion of data types and/or data formats
EP1412866A1 (en) * 2001-06-29 2004-04-28 IP Unity Unified messaging with separate media component storage
WO2005027003A1 (en) * 2003-09-17 2005-03-24 Koninklijke Philips Electronics N.V. Method and device for providing address information for data transmission
FR2877114A1 (en) * 2004-10-22 2006-04-28 Bruno Decarpigny Message e.g. instant message, managing method for e.g. Internet, involves transmitting message comprising object with originator terminal authentication unit and content with access information of server, to destination terminal by server
EP1341091A4 (en) * 2000-12-06 2008-04-16 Ntt Docomo Inc Apparatus and method for distributing content
EP1931090A1 (en) * 2006-12-06 2008-06-11 Research In Motion Limited Method and system for communicating a message attachment
WO2009002951A1 (en) * 2007-06-25 2008-12-31 Dialog Science, Inc. System and method for generating an electronic communication
US7801960B2 (en) 2000-08-31 2010-09-21 Clearswift Limited Monitoring electronic mail message digests
US8122344B2 (en) 2000-03-01 2012-02-21 Research In Motion Limited System and method for rapid document conversion
US8301179B2 (en) 2006-12-06 2012-10-30 Research In Motion Limited Method and system for communicating a message attachment
US8583731B1 (en) 2006-11-17 2013-11-12 Open Invention Network Llc System and method for analyzing and filtering journaled electronic mail
US8799183B2 (en) 2001-04-09 2014-08-05 United States Postal Service System and method for predelivery notifcation using mail image
US9767496B2 (en) 2001-04-09 2017-09-19 United States Postal Service System and method for predelivery notification using mail image
US10346891B2 (en) 2001-04-09 2019-07-09 United States Postal Service System and method for predelivery notification using mail image
US10674325B1 (en) 1999-11-05 2020-06-02 Conversant Wireless Licensing S.a r.l Multimedia messaging service

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP3590936B2 (en) * 2001-10-06 2004-11-17 テラス テクノロジーズ,インコーポレイテッド E-mail service system having dynamic IP filtering module and dynamic IP address filtering method

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0720333A2 (en) * 1994-11-30 1996-07-03 AT&T Corp. Message filtering techniques
US5548789A (en) * 1991-01-24 1996-08-20 Canon Kabushiki Kaisha Message communication processing apparatus for selectively converting storing and transmitting messages of different lengths
US5606693A (en) * 1991-10-02 1997-02-25 International Business Machines Corporation Distributed database management over a network

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5548789A (en) * 1991-01-24 1996-08-20 Canon Kabushiki Kaisha Message communication processing apparatus for selectively converting storing and transmitting messages of different lengths
US5606693A (en) * 1991-10-02 1997-02-25 International Business Machines Corporation Distributed database management over a network
EP0720333A2 (en) * 1994-11-30 1996-07-03 AT&T Corp. Message filtering techniques

Non-Patent Citations (7)

* Cited by examiner, † Cited by third party
Title
"IS YOUR NETWORK READY FOR NOTES? HEADS-UP DESIGN AND CLOSE ATTENTION TO TRAFFIC FLOW CAN KEEP THE WORLD'S BEST-SELLING GROUPWARE FROM BRINGING THE ENTERPRISE TO ITS KNEES", DATA COMMUNICATIONS, vol. 24, no. 5, 1 April 1995 (1995-04-01), pages 83 - 86, 88, 90, 92, XP000501583 *
"METHODOLOGY FOR MAIL FILTRATION PROBES", IBM TECHNICAL DISCLOSURE BULLETIN, vol. 34, no. 9, 1 February 1992 (1992-02-01), pages 372, XP000301914 *
BLUM C ET AL: "THE GLOBAL STORE SERVER - A MULTIMEDIA TELESERVICE COMPONENT", MULTIMEDIA TRANSPORT AND TELESERVICES. INTERNATIONAL COST 237 WORKS PROCEEDINGS, VIENNA, NOV. 13 - 15, 1994, 13 November 1994 (1994-11-13), HUTCHISON D;DANTHINE A; LEOPOLD H; COULSON G (EDS ), pages 35 - 46, XP000585293 *
BOGEN M ET AL: "W3GATE - A WEB ACCESS FOR OUTSIDERS", COMPUTER NETWORKS AND ISDN SYSTEMS, vol. 28, no. 14, November 1996 (1996-11-01), pages 1979 - 1990, XP000630956 *
CARRIER S ET AL: "PRACTICAL MULTIMEDIA ELECTRONIC MAIL ON X.400", IEEE MULTIMEDIA, vol. 2, no. 4, 21 December 1995 (1995-12-21), pages 12 - 23, XP000542075 *
GRIESMER S J ET AL: "EVOLUTION OF MESSAGING STANDARDS", AT & T TECHNICAL JOURNAL, vol. 73, no. 3, 1 May 1994 (1994-05-01), pages 21 - 45, XP000452252 *
THIMM H ET AL: "A MAIL-BASED TELESERVICE ARCHITECTURE FOR ARCHIVING AND RETRIEVING DYNAMICALLY COMPOSABLE MULTIMEDIA DOCUMENTS", MULTIMEDIA TRANSPORT AND TELESERVICES. INTERNATIONAL COST 237 WORKS PROCEEDINGS, VIENNA, NOV. 13 - 15, 1994, 13 November 1994 (1994-11-13), HUTCHISON D;DANTHINE A; LEOPOLD H; COULSON G (EDS ), pages 14 - 34, XP000585292 *

Cited By (43)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10674325B1 (en) 1999-11-05 2020-06-02 Conversant Wireless Licensing S.a r.l Multimedia messaging service
US8839098B2 (en) 2000-03-01 2014-09-16 Blackberry Limited System and method for rapid document conversion
US8122344B2 (en) 2000-03-01 2012-02-21 Research In Motion Limited System and method for rapid document conversion
GB2367707A (en) * 2000-06-28 2002-04-10 Neil Lennox Munro Internet activated telephone alert
EP1176535A3 (en) * 2000-07-26 2004-01-21 Canon Kabushiki Kaisha Communicating apparatus and communicating method
EP1176535A2 (en) * 2000-07-26 2002-01-30 Canon Kabushiki Kaisha Communicating apparatus and communicating method
US7801960B2 (en) 2000-08-31 2010-09-21 Clearswift Limited Monitoring electronic mail message digests
US8156191B2 (en) 2000-09-07 2012-04-10 Research In Motion Limited E-mail proxy
WO2002021790A3 (en) * 2000-09-07 2002-11-07 Celltrex Ltd E-mail proxy
US7856476B2 (en) 2000-09-07 2010-12-21 Tip Communications, Llc E-mail proxy
US10397158B2 (en) 2000-09-07 2019-08-27 Blackberry Limited E-mail proxy
US9577970B2 (en) 2000-09-07 2017-02-21 Blackberry Limited E-mail Proxy
WO2002021790A2 (en) * 2000-09-07 2002-03-14 Axis Mobile Ltd. E-mail proxy
EP1235396A4 (en) * 2000-09-26 2004-01-07 Interlex Inc System and method for using e-mail as advertisement medium
EP1235396A1 (en) * 2000-09-26 2002-08-28 Interlex Inc. System and method for using e-mail as advertisement medium
WO2002043414A3 (en) * 2000-11-22 2002-09-12 Nokia Corp Multimedia messaging services
WO2002043414A2 (en) * 2000-11-22 2002-05-30 Nokia Corporation Multimedia messaging services
EP1341091A4 (en) * 2000-12-06 2008-04-16 Ntt Docomo Inc Apparatus and method for distributing content
WO2002062026A1 (en) * 2001-01-29 2002-08-08 Siemens Aktiengesellschaft Message transfer device and method for transferring messages
US9767496B2 (en) 2001-04-09 2017-09-19 United States Postal Service System and method for predelivery notification using mail image
US10346891B2 (en) 2001-04-09 2019-07-09 United States Postal Service System and method for predelivery notification using mail image
WO2002082226A3 (en) * 2001-04-09 2003-05-01 Us Postal Service System, method, and article of manufacture for filtering mail items based upon recipient preference
US8799183B2 (en) 2001-04-09 2014-08-05 United States Postal Service System and method for predelivery notifcation using mail image
WO2002082226A2 (en) * 2001-04-09 2002-10-17 United States Postal Service System, method, and article of manufacture for filtering mail items based upon recipient preference
WO2002100063A1 (en) * 2001-06-01 2002-12-12 Siemens Aktiengesellschaft Method for handling a message with a multimedia reference
EP1412866A1 (en) * 2001-06-29 2004-04-28 IP Unity Unified messaging with separate media component storage
EP1412866A4 (en) * 2001-06-29 2006-04-26 Ip Unity Unified messaging with separate media component storage
EP1280039A2 (en) * 2001-07-26 2003-01-29 Networks Associates Technology, Inc. Detecting e-mail propagated malware
EP1280039A3 (en) * 2001-07-26 2005-08-17 Networks Associates Technology, Inc. Detecting e-mail propagated malware
EP1286292A2 (en) * 2001-08-21 2003-02-26 Matsushita Electric Industrial Co., Ltd. Method and system for data distribution
EP1286292A3 (en) * 2001-08-21 2004-05-12 Matsushita Electric Industrial Co., Ltd. Method and system for data distribution
FR2830096A1 (en) * 2001-09-21 2003-03-28 France Telecom Sending of content from servers to terminals, uses association of reference code and content to allow selection of content for pushing to terminals
WO2003036888A1 (en) * 2001-09-21 2003-05-01 France Telecom Method for sending content to at least a terminal and servers therefor
WO2003105425A1 (en) * 2002-06-07 2003-12-18 Siemens Aktiengesellschaft Transmission of mms messages with the conversion of data types and/or data formats
JP2010257465A (en) * 2002-06-07 2010-11-11 Siemens Ag Transmission of mms message with conversion of file type and/or file format, and subscriber terminal
CN1659839B (en) * 2002-06-07 2010-09-29 西门子公司 Method and system for data transmission
US8731097B2 (en) 2002-06-07 2014-05-20 Siemens Aktiengesellschaft Transmission of mms messages with the conversion of data types and/or data formats
WO2005027003A1 (en) * 2003-09-17 2005-03-24 Koninklijke Philips Electronics N.V. Method and device for providing address information for data transmission
FR2877114A1 (en) * 2004-10-22 2006-04-28 Bruno Decarpigny Message e.g. instant message, managing method for e.g. Internet, involves transmitting message comprising object with originator terminal authentication unit and content with access information of server, to destination terminal by server
US8583731B1 (en) 2006-11-17 2013-11-12 Open Invention Network Llc System and method for analyzing and filtering journaled electronic mail
US8301179B2 (en) 2006-12-06 2012-10-30 Research In Motion Limited Method and system for communicating a message attachment
EP1931090A1 (en) * 2006-12-06 2008-06-11 Research In Motion Limited Method and system for communicating a message attachment
WO2009002951A1 (en) * 2007-06-25 2008-12-31 Dialog Science, Inc. System and method for generating an electronic communication

Also Published As

Publication number Publication date
AU8880198A (en) 1999-04-05

Similar Documents

Publication Publication Date Title
WO1999014909A1 (en) Messaging system
US6088720A (en) Self-cleaning and forwarding feature for electronic mailboxes
Gralla How the Internet works
US6779022B1 (en) Server that obtains information from multiple sources, filters using client identities, and dispatches to both hardwired and wireless clients
US8316090B2 (en) Systems and methods for communicating logic in e-mail messages
US6404762B1 (en) Universal messaging system providing integrated voice, data and fax messaging services to pc/web-based clients, including a session manager for maintaining a session between a messaging platform and the web-based clients
US6330589B1 (en) System and method for using a client database to manage conversation threads generated from email or news messages
US7546351B1 (en) Methods and systems for filtering, sorting, and dispatching messages to wired and wireless devices
US20070180035A1 (en) E-mail attachment selectable download
US20020120693A1 (en) E-mail conversion service
US20040249895A1 (en) Method for rejecting SPAM email and for authenticating source addresses in email servers
US8935344B2 (en) Systems and methods for message personalization
WO2003100639A1 (en) System and method for message sender validation
US20040221048A1 (en) Email archive system
US7634543B1 (en) Method of controlling access to network resources referenced in electronic mail messages
WO2008126067A1 (en) A messaging system and method
US20050086527A1 (en) System and method for tracking distribution of digital content
US20020026481A1 (en) Electronic mail system and electronic mail delivery method
US7383306B2 (en) System and method for selectively increasing message transaction costs
US7490128B1 (en) Unsolicited message rejecting communications processor
US20070124383A1 (en) Multiple mail reducer
EP2003831A1 (en) Network service for user-controlled allocation of data items
US7673058B1 (en) Unsolicited message intercepting communications processor
US7716351B1 (en) Unsolicited message diverting communications processor
CA2328548A1 (en) Privacy system

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AL AM AT AU AZ BA BB BG BR BY CA CH CN CU CZ DE DK EE ES FI GB GE GH GM HR HU ID IL IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT UA UG US UZ VN YU ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): GH GM KE LS MW SD SZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
121 Ep: the epo has been informed by wipo that ep was designated in this application
WWE Wipo information: entry into national phase

Ref document number: 09180759

Country of ref document: US

NENP Non-entry into the national phase

Ref country code: KR

REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

122 Ep: pct application non-entry in european phase
NENP Non-entry into the national phase

Ref country code: CA