US 8135780 B2
A computer implemented method for assisting email users recognizes deviations in characteristics of emails sent from a particular source identifier or “source ID” to a user. After one or more emails having a pattern of characteristics are received, an action on subsequent emails is performed, such as warning users when the subsequent emails received from the source ID match or don't match the pattern. Characteristics from a particular source ID are determined based on whether the addressee reads the email from the source ID. Various levels of warning based on the characteristics identified and the deviation of any email from the characteristics of previous emails.
1. A computer implemented method for assisting email users, comprising:
receiving a plurality of email messages, each message addressed to at least one email user and identifying a sender identity;
recording a plurality of characteristics associated with each email sent from a sender identity;
determining whether characteristics of new emails purported to be received from the sender identity match characteristics of a plurality of previously received emails from the sender identity, the determining performed after a user views an email in the interface, and a known good pattern is established when at least a plurality emails from the sender identity share the same plurality of characteristics when the user reads the email;
presenting at least a portion of a received new email message to the user in a user interface, the user interface including a set of user actions which may be performed by the user via the user interface; and
if the characteristics in the received new email message do not match the characteristics recorded for the plurality of previously received emails from the sender identity, transforming the user interface to include an indication along with at least a portion of the message field of the email, associated with the received new email message, to the at least one email user, that the received new email message purported to be from the sender identity is not likely to be from the sender identity and enabling further actions on the received new email message in the user interface, the indication comprising a warning which includes a first greater severity when a pattern of matching a stronger characteristic is not matched and a lesser severity when a pattern of matching a weaker characteristic is not matched, and if the characteristics in the received new email message match the characteristics recorded, not transforming the user interface.
2. The computer implemented method of
3. The method of
4. The method of
5. The method of
6. The method of
7. A computer implemented method for classifying emails according to source, comprising;
receiving a plurality of email messages, each message addressed to at least one email user and identifying a sender identity;
presenting newly received emails addressed to the at least one email user in an user interface for the user, the user interface including a set of available actions;
monitoring whether a user selects to view a received email message from the sender identity in the user interface;
extracting one or more characteristics from each received email message associated with the sender identity after the user selects to view a first email message from the sender identity in the user interface;
determining whether the one or more characteristics associated with the received email selected matches one or more known good characteristics of a plurality of other messages received for the sender identity to establish a pattern of characteristics for messages a user views from the sender identity, the determining performed after a user views an email in the interface, and a known good pattern is established when at least a plurality emails from the sender identity share the same plurality of characteristics when the user reads the email; and
receiving a new email for the user from the sender identity and if the one or more characteristics of the new email do not match the pattern, transforming the user interface to include an at least a portion of the message field of the message along with an indication, associated with the new email, to the at least one email user, of whether the received email is likely to be from the sender identity and enabling an action on the email, the indication comprising a warning which includes a first greater severity when a pattern of matching a stronger characteristic is not matched and a lesser severity when a pattern of matching a weaker characteristic is not matched, and if the characteristics in the received new email message match the characteristics recorded, not transforming the user interface.
8. The computer implemented method of
9. The computer implemented method of
10. The method of
11. The method of
12. The method of
13. The computer implemented method of
14. A computer implemented method for assisting email users of an enterprise service provider email system, comprising:
receiving a plurality of email messages in the enterprise service provider email system, each message addressed to at least one email user and identifying at least one sender identity having an email address;
presenting emails addressed to the at least one email user in a user interface for the user;
gathering a plurality of identifying characteristics for the plurality of emails received at the enterprise service provider email system from an email address directed to a plurality of users in a group of users after one user in the group selects to view a first email from the email address;
establishing a pattern of identifying characteristics for emails from the at least one sender identity based on group actions;
determining whether a new received email purported to be from the sender identity and directed to the at least one email user matches the pattern of identifying characteristics associated with the at least one sender identity, the determining performed after a user views an email in the interface, and a known good pattern is established when at least three emails from the sender identity share the same plurality of characteristics when the user reads the email; and
upon the user viewing the new email, transforming the user interface to provide a portion of the message field and to visually indicate to the user that the new received email is not likely from the sender identity when identifying characteristics of the new email do not match the pattern of identifying characteristics by providing a warning which includes a first greater severity when a pattern of matching a stronger characteristic is not matched and a lesser severity when a pattern of matching a weaker characteristic is not matched, and enabling an action on the email in the user interface.
15. The computer implemented method of
16. The computer implemented method of
The most common use of the Internet is communication via electronic mail. Common forms of web-based email services are provided by Email Service Providers (ESPs) examples of which include Yahoo! Mail, Microsoft Live Mail, Google GMail, and others. Each of these providers receives a large number of messages which are inbound to the providers, many of which are phishing messages, spam messages or unsolicited bulk-email messages. These provides also receive a number of messages from legitimate institutions whose customers have provided their web-based email as the primary means of electronic communication.
Large scale ESPs can stop a limited amount of spam and phishing email using various spam detection mechanisms, including comparing the sending IP address to a list of known spammer addresses or confirming the validity of the sending IP address with a Domain Name Service (DNS) server. Though typical anti-spam applications remove a portion of incoming spam from user accounts, they do not prevent all spam from being delivered and can sometimes result in “false positives”, where legitimate mail is marked as spam.
Phishing emails are a bit more difficult to detect, as they may appear to users to be legitimate emails from reputable on-line vendors. Occasionally, these emails pass by spam filters when their pattern has not been recognized by the spam filter. Conversely, legitimate emails can sometimes be caught by spam filters. Users need to regularly check their spam folder to ensure legitimate emails are not incorrectly routed there.
Some providers allow users to “white list” email addresses using various mechanisms. For example, bulk mail routed to a user's spam or deleted items folder may be marked as “not spam” and future messages from the “from” address identified on a whitelist are then allowed to pass to the user's inbox the future.
Current systems strive to keep users safe from nefarious messages, while still allowing messages the users want to view through to the user. Users may demonstrate a pattern of reading mail from sources which might otherwise have characteristics which lead existing systems to identify them as suspicious. For example, users may consistently read emails from a banking institution having text which closely resembles phishing emails made to resemble emails from the institution.
The technology, roughly described, recognizes deviations and characteristics of emails sent from a particular source identifier or “source ID” to a user. The source ID can be user email address, a domain, or a group of Internet protocol (IP) addresses, or any manner of identifying a common source for emails. Characteristics of emails transmitted from a source ID to a particular user are determined and associated with the source ID. After one or more emails having a pattern of characteristics are received, users are warned when subsequent emails received from the source ID match or don't the pattern. Emails not matching the pattern are more likely not to be from the source ID. Characteristics from a particular source ID are determined and the acceptability of the email evaluated based on whether the addressee reads the email from the source ID. The technology can include various levels of warning based on the characteristics identified and the deviation of any email from the characteristics of previous emails.
In one embodiment, the method includes a computer implemented method for assisting email users. The method includes recording a pattern of characteristics associated with emails sent from a sender identity and determining whether characteristics of new emails received from the sender identity match the pattern. If the characteristics in any email do not match the pattern, a warning is issued. In one embodiment, the steps of determining and issuing occur when a user views an email.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used as an aid in determining the scope of the claimed subject matter.
Technology is described herein for implementing a system which recognizes deviations and characteristics of emails sent from a particular source identifier or source ID, such as a user email address, a domain, or a group of Internet protocol (IP) addresses, to a receiving user. The receiving user can utilize an web based email system, or may be a user of an application program on an individual computing device. In accordance with the technology, the characteristics of emails transmitted from a source ID to a particular user are determined and associated with the source ID. After one or more emails having certain characteristics are received, the system can indicate whether subsequent emails received from the source ID match the earlier characteristics and are thus more likely to be from the source identifier. Characteristics from a particular source ID are determined and the authenticity of the email estimated based on whether or not the addressee reads the email from the source ID. When emails are received purporting to be from the source ID do not share the same characteristics as one or more previous emails from the source, the system can warn the user that the email does not appear to be the same as pervious email from the source. The technology can include various levels of warning based on the characteristics identified and the deviation of any email from the characteristics of previous emails.
The technology is based on an assumption that email regularly read from a particular source should share characteristics with previous emails from that particular source. Deviations in emails from a particular source would indicate that the email is less likely to be from that particular source.
At step 11, a white list of source ID from which a user always wants to receive mail is checked. If the source ID is on the white list, the method simply waits for the next email to the user. In step 12, the source identity and any one or more characteristics of the email emanating from a source identity are determined. Step 12 can include determining such things as whether the email passes authentication processes Sender ID or DomainKeys Identified Mail (DKIM), or whether the email comes from the same IP address or group of IP addresses. In this case, the determination at step 12 recognizes “authentication” characteristics of the mail. However, other characteristics of the email may be recognized. Characteristics of the email may be based on text characterization of the email, where a determination of regular elements of the email message such as the particular signature one sender uses in an email, whether the particular sender uses capitalization regularly, or whether the user includes a particular form or RE line in a message, may all be used to characterize an email message at step 12. Other characteristics such as elements in the mail header including charset, encoding, or format may also be used. This preceding list should be considered examples of classes of characteristics, where the true set of characteristics is limited only by state-of-the-art text classification techniques, including spam filter feature extraction. One or more of each of the aforementioned characteristics may be determined for each email relative to the source ID of the email. A further characteristic may be the number of times a particular IP associated with a particular user is seen over time. For example, if email is consistently seen from a user over a particular period of time associated with a first IP address, and email ceases coming from that IP address over some other period of time, the system can unlearn the first IP associated with that particular user.
At step 14, a determination is made as to whether any characteristics (or set of characteristics) have been previously associated with a particular source ID For example, it may be determined that one regularly receives email from a particular source and that email always passes Sender ID. At step 14, if any one or more characteristics has already been associated with a particular source identifier, then at step 30, a determination is made for the email received at step 10 as to whether or not its characteristics match the known characteristics for the source ID. If the email matches the known characteristics, an assumption can be made that the email is likely from the same source as previous emails from the source ID and no warning need be displayed. If an email is received at step 10 purporting to be from a particular source ID which does not match the characteristics as determined at step 30, then, at step 32, when the user reads the email, at step 34 the technology will display a warning to the user indicating that the email purporting to be from a particular source does not match the characteristics of email previously seen from such source. The warning may take many forms, as disclosed in the figures below. If the user never reads the email at step 32, no action need be taken on the mail message.
Optionally, if a user never reads the email at step 32, the method of
If at step 14, no characteristics for a particular source ID have been associated with the source ID, when the user reads an email at step 16, a determination will be made at step 18 as to whether any characteristics have yet been identified for the particular source ID. Again, if the user does not read the email at step 16, no action need taken. Alternatively, the determination steps may occur before a user attempts to read the email. If at step 18, no existing characteristics have been associated with a source identifier, a initial association 36 may be created. The initial association may comprise a tracking record linking the source ID with a particular set of characteristics. The tracking record may be any manner of storing the association of characteristics with the source ID. Optimally, this may be performed by storing easily accessible records in a data structure in a database. Multiple occurrences of the same set of characteristics with respect to a source ID may result in multiple tracking records and a pattern based on the records established after some number of occurrences of the same characteristics in emails relative to the source ID is seen.
If at step 18, characteristics have been found which match source I.D., (for example, previous tracking records are found for the source ID) a determination is next made as to whether or not a pattern has established for the source ID at step 20. A pattern can result from the receipt of one or more messages having the same characteristics. For example, one may determine that a pattern exists when a user reads a minimum of 2-10 email messages from the same source ID which all pass Sender ID. In this example, the pattern is that messages from this sender should pass Sender ID. A known good record may be stored when a pattern of characteristics is seen with respect to a source ID. The pattern may be determined as a result of any frequency and occurrence of the particular characteristics relative to the source ID If no known good record exists at step 20, then a counter can be incremented for set of characteristics known for that Source ID. At step 24, when the count of the number of times the particular set of characteristics has been seen (exceeding some threshold, such as 2-10 times,) a pattern for the source ID is established at step 26. In one embodiment, the necessary count is a few as one occurrence, but advantageously, the frequency threshold is some greater number of occurrences.
In a further embodiment, as indicated at step 80, even where the user has white listed a source ID, additional authentication mechanisms like sender ID or DKIM could be taken with that information to provide a warning/affirmation 82 with each message in the absence of a pattern. Similarly, even if a particular message deviates from a known pattern, the presence of successful authentication might soften or eliminate the warning.
It should be understood that once a known good or known bad record is created, it may be eliminated or confirmed over time. For example, if a substantial number of the same pattern of characteristics is seen, the record may be made permanent. Similarly, if a pattern of characteristics is not seen for some long period of time, the records may be deleted.
In the example shown in
Any number of methods are available for determining blocks of IPs which should be associated with a source ID. In one embodiment, as soon as two IPs within the same block are “known good”, authorization of the block may be performed by first determining the entire block. In one example, a WHOIS search may be performed for all IPs blocks associated with the source IP. In another alternative, patterns in source IDs could be determined using PTR records. PTR records map IP addresses to domain names and allow determining a source ID based on the appearance of a pattern of IPs. For example, if a check of PTR records shows that a user (or group) consistently read or don't read emails from a particular domain, known good or known bad classifications may be applied to IPs resolving to the domain as a whole for that source ID. Known TLDs could be eliminated from the set of eligible such domains. In a further example, one may use a WHOIS or BGP global routing table search to identify an internet service provider (ISP), autonomous system number (ASN), or any number of unique identifiers associated with the addresses to determine blocks of IPs associated with the original IP. One or more authorization algorithms may then be applied to identify the source ID as an IP block or other grouping of IPs determined from the original IP set.
In yet another alternative, multiple domain or IP group identifiers may become part of the known good record. For example, one may associate as many unique characteristics a domain or IP group that have been authorized with the source ID record. Note that multiple identifiers can all be associated with a known good record. Where multiple identifiers are associated with a record, a weighting may be assigned to the identifiers and the weighting would allow those identifiers with a higher weighting to take precedence in indicating whether the message was known good or potentially bad.
As shown in
Users operating computers 360 d, 362 d, 364 d interact with, for example, a web-based email server 440, or a POP/IMAP server 470 to retrieve mail from the storage servers 454A-454D. An online address book 435 may be maintained for each individual user having an account with the enterprise email service 350. User 164A using computer 360 d may interact with email server 440 via web browser 404 instituting a browser process to read messages stored on any one of the stored servers. User 164 via operating computer 362 d interacts with a POP/IMAP server 470 via an email client 408 or an IMAP client 410.
To implement the methods discussed in
System 350 allows for an additional feature of the technology to be implemented. In alternative embodiments, groups of users can be culled together to provide an initial set of characteristic data for a source ID, but the initial set of data could be overridden by an individual user. For example, suppose a group of individuals consistently see email from a user having an ID of a user address email@example.com indicating that firstname.lastname@example.org always fails Sender ID, but is normally read by the group. This could result in a pattern that all mails from foo.com (or even email@example.com) should fail Sender ID. The benefit of extrapolating to the group is that further members of the group do not require as much time to learn the pattern. However, the data that mail from firstname.lastname@example.org fails Sender ID may result from the emails being sent from a forwarding address such that normally provided by any number of higher education institutions which allow their students and former students to have a redirecting email address. Other cases where this problem exists is where a user forwards a story or other message using a site which allows the user to generate emails and forward the emails directly from the site. Sharing group information with all users in the system 350 would potentially result in a situation where e mails from a particular email@example.com are attributed with incorrect characteristics for some users other than the group. This particular characteristic would present false data to the balance of any others on system 350 with whom this data is shared. Hence, group data for a source ID may provided as a starting point, but users on system 350 may be allowed to over-ride such data.
In an alternative embodiment, each of the aforementioned evaluation characteristics can be weighted so that characteristics which are strong identifiers of the source of the email can provide a greater degree of warning when deviated from. For example, users may frequently change an IP address in cases where a user has a dynamic IP assigned by a high speed Internet service with whom they normally connect. The characteristic of an email IP address associated with a user is thus a weak identifier of a characteristic of the particular user source ID Other indicators, such as whether an email address normally passes sender ID would be a stronger identifier that the email could be problematic.
In a further embodiment, in the system 350 such as that shown in
In an alternative embodiment, a validation such as that shown in
In yet another embodiment, not illustrated a warning may provide a detailed description of the characteristic or identifier which failed a pattern match, allowing for further analysis by the user or the system administrator.
The client devices and servers discussed above may be implemented in a processing device such as that described with respect to
Computer 110 typically includes a variety of computer readable media. Computer readable media can be any available media that can be accessed by computer 110 and includes both volatile and nonvolatile media, removable and non-removable media. By way of example, and not limitation, computer readable media may comprise computer storage media and communication media. Computer storage media includes both volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can accessed by computer 110. Communication media typically embodies computer readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. Combinations of the any of the above should also be included within the scope of computer readable media.
The system memory 130 includes computer storage media in the form of volatile and/or nonvolatile memory such as read only memory (ROM) 131 and random access memory (RAM) 132. A basic input/output system 133 (BIOS), containing the basic routines that help to transfer information between elements within computer 110, such as during start-up, is typically stored in ROM 131. RAM 132 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 120. By way of example, and not limitation,
The computer 110 may also include other removable/non-removable, volatile/nonvolatile computer storage media. By way of example only,
The drives and their associated computer storage media discussed above and illustrated in
The computer 110 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 180. The remote computer 180 may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to the computer 110, although only a memory storage device 181 has been illustrated in
When used in a LAN networking environment, the computer 110 is connected to the LAN 171 through a network interface or adapter 170. When used in a WAN networking environment, the computer 110 typically includes a modem 172 or other means for establishing communications over the WAN 173, such as the Internet. The modem 172, which may be internal or external, may be connected to the system bus 121 via the user input interface 160, or other appropriate mechanism. In a networked environment, program modules depicted relative to the computer 110, or portions thereof, may be stored in the remote memory storage device. By way of example, and not limitation,
The present technology provides users with a warning when email received from different sources deviates from known patterns. In the technology herein, the characteristics of mail regularly received are observed and flagged when deviated from. This is done on a per origin basis so that the “usual and customary” level of authentication form an alarm system. Such characteristics can include whether or not the email passed a sender I.D., whether or the email passes DKIM, or whether it comes from the same IP address or group of IP addresses. Basic patterns of emails can be learned. This can be broadened to include text patterns and other characteristics of a particular email. Advantageously, this is done on a per user basis
Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims.