US 7107314 B2
An electronic mail system includes multiple devices, on each of which a user may have an electronic mailbox. The electronic mailboxes can be synchronized, so that actions taken on one device are reflected on other devices. Each mail message is assigned a unique message identifier. When the message is read or moved from one folder to another folder, it is assigned a new message identifier. The system maintains a list of subsidiary identifiers for each message, which identifies the prior message identifiers for the message. The system identifies message identifiers that have been added since the last synchronization. During synchronization, by examining messages having a current or prior message identifier that is found in the list of subsidiary identifiers for a message having a new message identifier, the system is able to synchronize the mailboxes on the devices. Following synchronization, each synchronized device will have the same messages in the same folders, with the same message identifiers, and duplicates caused by taking the same action on two different devices are removed.
1. A method for synchronizing a plurality of electronic mail messages in a plurality of folders on a plurality of devices, wherein a current message identifier is associated with each electronic mail message, the method comprising:
determining which current message identifiers are new for the devices being synchronized since the previous synchronization;
identifying which message identifiers represent messages that should be deleted from particular folders;
removing from each device being synchronized each message having a current message identifier that represents a message that should be deleted;
for each remaining new current message identifier,
identifying a folder in which a message associated with the new message identifier is located;
adding to the identified folder on each device being synchronized on which the new message identifier is not found, a new message corresponding to the message associated with the new message identifier; and
associating with the new message the new message identifier and a list of subsidiary identifiers,
wherein a subsidiary identifier is a message identifier that had been replaced by a new current message identifier.
2. The method of
3. The method of
4. The method of
5. The method of
6. The method of
7. The method of
8. The method of
This invention relates to electronic mail systems and, more particularly, to electronic mail systems accessible from multiple devices.
Electronic mail has become an important means for communicating in business and other contexts. Users often have multiple devices for accessing electronic mail, including one or more computers and an array of wireless devices. In addition, users may have the ability to access electronic mail from devices they do not own or control. Users want to be able to access their electronic mail from any device.
With many existing electronic mail systems, electronic mail messages are downloaded to the device on which the message is read or information about the message is maintained on the device. Thus, information about a particular message may be located on multiple devices in multiple locations. A particular device may not be on the network or accessible to other devices at any given time.
These existing electronic mail systems do not provide an adequate mechanism for synchronizing the state of a user's electronic mailbox on one device with the state of the user's mailbox on another device.
The present invention permits electronic mailboxes on multiple devices to be synchronized, so that actions taken on one device are reflected on other devices. In some embodiments, this synchronization can take place across multiple devices at multiple times. Particular devices do not need to connect to all other devices.
The synchronization allows the state of each message to become consistent across multiple devices, without the need for each device to be connected at the same time or to all the other devices, and a device does not need to communicate with other devices during the process of delivering, moving, or deleting a message.
Following synchronization, a message read on one device will appear as read on other devices. Also, a message deleted or moved from one folder to another will appear as moved or deleted on the other devices.
The invention can be used to provide a fault-tolerant mail system, in which unavailable nodes are resynchronized when they become available and only messages unique to a failed node are lost in the event of a system failure. Messages already replicated on another node through the synchronization process can be regenerated.
Each mail message is assigned a unique message identifier. When the message is moved from one folder to another folder, it is assigned a new message identifier. By keeping track of new message identifiers, a list of prior message identifiers, and/or the prior identifiers for a message, actions taken on multiple devices can be synchronized.
As shown in
In this example, the user has an unread mail folder 210, a read mail folder 212, a business folder 214, a personal folder 216, and an important messages folder 218. In addition, messages can be deleted, in which case they are placed in trash folder 220. Although organized as separate “folders,” unread messages and read messages could be presented to the user in a single folder, such as an “inbox” folder. However, the system treats unread messages and read messages (which have not been moved to another folder) as existing in separate folders. Similarly, trash folder 220 need not appear as a separate folder to the user, although the system can treat deleted messages as if they exist in a separate folder.
Deleted message identifiers list 222 maintains a list of message identifiers that have been deleted. In some embodiments, message identifiers can be removed from deleted message identifiers list 222 once a synchronization involving that deleted message identifier has occurred on all the devices. Alternatively, deleted message identifiers list 222 can be pruned so that only relatively recent additions to the list are maintained. For example, once a message identifier has been in deleted message identifiers list 222 for two months, it may be removed from the list.
Message identifier log 224 maintains a list of all message identifiers known to the device, both from generating a message identifier and from learning of the message identifier following a synchronization operation. Alternatively, message identifier log 224 can be more restricted. It could, for example, maintain only a list of message identifiers that have not been deleted and/or only a list of message identifiers generated on that device. As with deleted message identifiers list 222, message identifier log 224 also can be limited to relatively current messages.
Each mail message 230 is assigned a message identifier 240. A message identifier 240 may be unique for the electronic mail system as a whole or for a particular user. In some embodiments, the message identifier is unique only for the current universe of messages. Once a message has been removed from the system or is no longer being synchronized, its message identifier can be reused.
In some embodiments, the message identifier 240 is generated using a Universal Unique Identifier (UUID) algorithm, with the message identifier including a timestamp and the IP address of the device at which the message identifier is generated. This ensures that two or more devices will not assign the same message identifier. Alternatively, other algorithms for generating a unique identifier can be used. Although depicted as a single field, the message identifier can be based on a combination of multiple fields or pieces of data.
When a message is moved from one folder to another folder, it is assigned a new message identifier. Its prior message identifier is added to a list of subsidiary identifiers 250. Optionally, the list of subsidiary identifiers for a message can be cleared if, for example, the system is fully synchronized with respect to that message, a sufficient period of time has elapsed since the last change to the message.
Message 230 b has not been read on any of the devices. Accordingly, it retains its original message identifier (the value 304) on all three devices in
Message 230 c appears only on device 202, where it has been read. Accordingly, its original message identifier (the value 306, in
Message 230 d has been moved from the read folder 212 on device 202 to the business folder 214. It remains in the read folder 212 on devices 204 and 206 with its second message identifier (the value 356). On those devices, the original message identifier (the value 308) appears as a subsidiary identifier and in the deleted message identifiers list 222. On device 202, the message identifier value 356 in
Message 230 e has been moved from the read folder on device 204 to the important messages folder 218. It remains in the read folder on device 202 and in the unread folder on device 206. This may result, for example, from devices 202 and 204 having synchronized after the message had been read from one of those devices, and without device 206 having synchronized with either device 202 or device 204 since message 230 e was read on device 202 or device 204. Accordingly, its original message identifier (the value 310) remains on device 206 in
Message 230 f has been moved from the read folder on device 202 to the business folder 214, and from the read folder on device 204 to the important messages folder 218. It is unread on device 206. As with message 230 e, message 230 f retains its original message identifier (the value 312) on device 206 in
Message 230 g has been moved from the unread folder on device 202 to the personal folder 216, and has been deleted on device 204 (that is, moved to trash folder 220). Message 230 g remains unread on device 206. Accordingly, its original message identifier (the value 314) appears on device 206 in
Message 230 h, in business folder 214 on device 204 has been copied, so that two versions now appear in business folder 214 on device 204 in
Message 230 a appears once in read folder 212, with a message identifier value 352 and the values 302 and 392 for subsidiary identifiers. The values 302 and 392 also appear in deleted message identifiers list 222. The message identifier value 392, which was created on device 206 (and therefore appeared on its message identifier log 224 before the synchronization, as shown in
Message 230 b remains in unread folder 210 because it had not been read on either device 202 or device 206. During the synchronization, its message identifier value (the value 304) appeared on both devices so no action was taken.
Message 230 c now appears in read folder 212 on both devices. It had not previously been on device 206. During the synchronization, the message identifier value (the value 354) appeared only on device 202, so message 230 c was added to device 206, along with its message identifier (the value 354) and subsidiary identifier list (containing the value 306). The value 306 is added to the deleted message identifiers list 222 for device 206, and the values 306 and 354 are added to message identifier log 224 for device 206.
Message 230 d now appears in business folder 214 on both devices. On device 206, the deleted message identifiers list 222 and message identifiers log 224 are updated. The prior message identifier value 356 for message 230 d on device 202 appears in the deleted identifiers list 222, indicating that message 230 d on device 206, which still has the message identifier value 356, should be deleted from the read folder 212.
Message 230 e now appears in read folder 212 on both devices, having been treated in an analogous manner to message 230 d.
Message 230 f now appears in the business folder 214 on both devices. Although its most recent subsidiary identifier (the value 362) had not appeared previously on device 206, its original message identifier (the value 312) had. That value appears in deleted message identifiers list 222, which allows the version in unread folder 210 on device 206 to be synchronized with the version in business folder 214 on device 202. The deleted message identifiers list 222 and the message identifier log 224 are updated so that they are the same on both devices.
Similarly, message 230 g now appears in personal folder 216 on both devices, and message 230 h now appears in business folder 214 on both devices.
Message 230 a now appears in read folder 212 on the devices; message 230 b continues to appear in unread folder 210 on the devices; message 230 c appears in read folder 212 on the devices; message 230 d appears in business folder 214 on the devices; and message 230 e appears in important messages folder 218 on the devices.
Message 230 f had been moved separately to two different folders—business folder 214 on device 202 and important messages folder 218 on device 204. Thus, with neither of these messages is the current message identifier in the deleted messages list. In this example, the message now appears in both folders on the devices.
Message 230 g has been moved separately to personal folder 216 on device 202 and to the trash folder on device 204. In this example, the trash folder is treated like any other folder, so the message appears in both folders, like message 230 f. Alternatively, if it is desired that a trashed message disappear from all other folders (or that messages moved to the trash folder and to another folder not remain in the trash folder), then the devices can check the subsidiary identifiers of messages in the trash folder against the subsidiary identifiers of messages in other folders, and remove the messages in either the trash folder or the other folders. Further variations on this arrangement are possible, with folders other than the trash folder (such as an important messages folder), or so that only messages in certain folders are removed in this manner. For example, a message moved both to a business folder and to an important messages folder could end up in just the important messages folder, while a message moved to the personal messages folder on one device, and to the business messages folder on another device, could appear in both folders. Also, a message moved from the unread folder to the read folder on one device, and from the unread folder to the read folder and then to another folder on a second device, might appear just in the other folder (that is, not in the read folder) after synchronization.
Message 230 h now appears twice in business folder 214. Once, in its original form (with message identifier value 374) and once in its copied form (with message identifier value 376). Because the copied message (with message identifier value 376) does not have the previous values in its subsidiary identifier list, it is treated as a different message.
Deleted message identifiers list 222 can take various forms and can include a variety of information. In addition to the list of message identifiers, deleted message identifiers list 222 can include, for example, information about the messages corresponding to those message identifiers. In some embodiments, deleted message identifiers list 222 includes information about the folder in which the message existed when its message identifier changed, or information about each folder in which the message existed. Similarly, the subsidiary identifier list for a message could include information about the folder in which the message existed when its message identifier changed, or information about each folder in which the message existed. The folder information could be obtained using, for example, an additional field or by assigning message identifiers so that they also identify the folder.
Optionally, by also tracking or identifying the previous folders in which a message appeared, messages moved to two (or more) different folders could be identified and one or more of the duplicates could then be deleted.
Over time, the deleted message identifiers list 222 and/or message identifier log 224 can become long in some embodiments. With some embodiments and with periodic synchronizations, the majority of the data will be the same on each node. Under these circumstances, known algorithms may be employed to provide efficient synchronization of the data sets, such as described in Andrew Tridgell, “Efficient Algorithms for Sorting and Synchronization” (Ph.D thesis, Australian National University, 2000), which is incorporated by reference. The Tridgell thesis may be found at http://samba.anu.edu.au/˜tridge/phd_thesis.pdf.
The present invention may be implemented in a variety of forms, such as in software or firmware, running on a general purpose computer or a specialized device. The code can be provided in any machine-readable medium, including magnetic or optical disk, or in memory.
While there have been shown and described examples of the present invention, it will be readily apparent to those skilled in the art that various changes and modifications may be made without departing from the scope of the invention as defined by the following claims. For example, deleted message identifiers list 222 could be omitted, with deleted message identifiers identified by determining which message identifiers are new since the previous synchronization. During the synchronization process, messages could be deleted if their current message identifier is found in the subsidiary identifier list for a message with a new message identifier. Accordingly, the invention is limited only by the following claims and equivalents thereto.