US20180302446A1 - Centralized Validation of Email Senders Via EHLO Name and IP Address Targeting - Google Patents

Centralized Validation of Email Senders Via EHLO Name and IP Address Targeting Download PDF

Info

Publication number
US20180302446A1
US20180302446A1 US16/012,616 US201816012616A US2018302446A1 US 20180302446 A1 US20180302446 A1 US 20180302446A1 US 201816012616 A US201816012616 A US 201816012616A US 2018302446 A1 US2018302446 A1 US 2018302446A1
Authority
US
United States
Prior art keywords
email
domain
delivering
dns
database
Prior art date
Legal status (The legal status 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 status listed.)
Granted
Application number
US16/012,616
Other versions
US10122765B1 (en
Inventor
Peter Martin Goldstein
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Valimail Inc
Original Assignee
Valimail Inc
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 Valimail Inc filed Critical Valimail Inc
Priority to US16/012,616 priority Critical patent/US10122765B1/en
Assigned to VALIMAIL INC. reassignment VALIMAIL INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: GOLDSTEIN, PETER MARTIN
Publication of US20180302446A1 publication Critical patent/US20180302446A1/en
Application granted granted Critical
Publication of US10122765B1 publication Critical patent/US10122765B1/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/20Network architectures or network communication protocols for network security for managing network security; network security policies in general
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L61/00Network arrangements, protocols or services for addressing or naming
    • H04L61/45Network directories; Name-to-address mapping
    • H04L61/4505Network directories; Name-to-address mapping using standardised directories; using standardised directory access protocols
    • H04L61/4511Network directories; Name-to-address mapping using standardised directories; using standardised directory access protocols using domain name system [DNS]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/50Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
    • G06F21/55Detecting local intrusion or implementing counter-measures
    • G06F21/56Computer malware detection or handling, e.g. anti-virus arrangements
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/60Protecting data
    • G06F21/62Protecting access to data via a platform, e.g. using keys or access control rules
    • G06F21/6218Protecting access to data via a platform, e.g. using keys or access control rules to a system of files or objects, e.g. local or distributed file system or database
    • 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/04Real-time or near real-time messaging, e.g. instant messaging [IM]
    • 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
    • H04L61/1511
    • H04L61/304
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/02Network architectures or network communication protocols for network security for separating internal from external traffic, e.g. firewalls
    • H04L63/0227Filtering policies
    • H04L63/0236Filtering by address, protocol, port number or service, e.g. IP-address or URL
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/08Network architectures or network communication protocols for network security for authentication of entities
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/12Applying verification of the received information
    • H04L63/126Applying verification of the received information the source of the received data
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/14Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/14Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic
    • H04L63/1441Countermeasures against malicious traffic
    • H04L63/145Countermeasures against malicious traffic the attack involving the propagation of malware through the network, e.g. viruses, trojans or worms
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/14Network architectures or network communication protocols for network security for detecting or protecting against malicious traffic
    • H04L63/1441Countermeasures against malicious traffic
    • H04L63/1483Countermeasures against malicious traffic service impersonation, e.g. phishing, pharming or web spoofing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L2101/00Indexing scheme associated with group H04L61/00
    • H04L2101/30Types of network names
    • H04L2101/33Types of network names containing protocol addresses or telephone numbers

Definitions

  • the disclosure generally relates to the field of electronic messaging, and specifically to centralized validation of email senders via EHLO name and IP address targeting.
  • the actual originator of a message may be validated against the message's purported identity in order to eliminate fraudulent messages.
  • fraudulent messages may include “phishing” emails that purport to be from a particular sender but in fact have a spoofed sender address and are sent from a malicious entity that may wish to perform some fraudulent activity against the recipient (e.g., steal personal information).
  • One approach to this validation problem is to enable the owner of the sending identity to create a set of rules defining which computers are allowed to relay emails to the recipient's email server.
  • Sender Policy Framework SPF
  • a sending identity publishes these SPF rules via the Domain Name System (DNS) such that a receiving mail server may be able to access them in order to validate the sender's identity of received messages.
  • DNS Domain Name System
  • a mailing list server may be asked to forward a message from an original sender, however, the mailing list server is not identified by the original sender as a valid sender. It is simply not feasible for receiving systems to check more than a few such rules when validating a message, even though a complete rule set might require hundreds or even thousands of rules.
  • SPF also includes tight limits on the number of Domain Name System (DNS) lookups that are allowed, in order to limit the burden on receiving systems, but this comes at the cost of failing to validate some legitimate messages.
  • DNS Domain Name System
  • Other techniques like Sender Rewriting Scheme (SRS), replace the original sender with an intermediate identity that can be validated with a more restricted rule set. While this minimizes the burden on the receiving system, it does not validate the message against the originator's identify.
  • SRS Sender Rewriting Scheme
  • systems and methods may comprise reframing the authentication questions around email from the network or IP level to the sending organization level, utilizing the ability of the existing Sender Policy Framework (SPF) protocol to encode network information available from the SMTP connection into a targeted domain name, and combining that with a custom DNS system backed by a database that maps that network information to a list of known organizations.
  • SPF Sender Policy Framework
  • systems and methods allow domain managers to define a set of organizations that are able to send email on their behalf without any additional work, such as manual lookup of SPF records for authorized organizations, modification of DNS TXT records for the domain, etc. It also allows domain manager to authorize any number of sending organizations, and frees the domain manager of the need to track changes to the SPF configuration for authorized senders.
  • systems and methods may comprise a Sender Policy Framework (SPF) which may be the protocol by which the owners of a domain can define a set of rules (known as directives) in a DNS TXT record designating which mail servers can deliver emails originating from that domain.
  • SPF Sender Policy Framework
  • Receiving mail servers evaluate those rules and, based on the IP address of the delivering server, determine whether the message in question is allowed to originate from that domain.
  • systems and methods may utilize two features of SPF.
  • the ‘include’ mechanism by which an SPF record can reference a target domain where an additional DNS SPF record is defined, and include the rules defined in this references record into the evaluated rule set.
  • the macro system by which request-specific values such as the IP address and EHLO name associated with the SMTP connection can be interpolated into the target domain.
  • an SPF record may be constructed for the domain that incorporates an ‘include’ directive that uses SPF macros to encode the name of the domain for which an email is being authorized, as well as the EHLO name and/or IP address of the SMTP connection into a target domain name.
  • the target domain name may be constructed so as to be in a DNS zone managed by the targeted SPF DNS resolver—the DNS system responsible for mapping network information to a list of known organizations.
  • the targeted SPF DNS resolver may be responsible for responding to DNS queries to target domains. It may also be responsible for maintaining an accurate and up-to-date mapping of network information to known organizations, which may involve combining public information such as domain registration records, public DNS entries, and curated information.
  • systems and methods for enhancing sender policy framework may advance the art of authenticating email, by reducing the overall complexity and maintenance burden exposed to a domain manager and removing existing limitations of the state of the art systems for providing similar authentication.
  • the methods may not require any changes to the systems receiving email, and may be compatible with the existing and extensive base of installed software.
  • FIG. 1 illustrates an example system capable of validating email senders through intermediaries via EHLO name and IP address targeting according to an embodiment.
  • FIG. 2 is an interaction diagram and flow chart illustrating an exemplary process for creation of an email domain validation record for use with a third party delivering organization according to one embodiment.
  • FIG. 3 is an interaction diagram and flow chart illustrating an exemplary process for resolution of an email domain validation record using DNS according to one embodiment.
  • FIG. 4 is a block diagram illustrating components of an example machine able to read instructions from a machine-readable medium and execute them in a processor (or controller).
  • a DNS server receives from a receiving email system, a DNS query for an email domain stored at the DNS server, the DNS query including identifying information of a sender of an email, and the email identifying itself as being from the email domain.
  • the DNS server extracts the identifying information of the email sender from the DNS query, and identifies one of a plurality of delivering organizations from the identifying information.
  • the DNS server determines whether the identified delivering organization is authorized to deliver email on behalf of the email domain.
  • the DNS server In response to determining that the identified delivering organization is authorized to deliver email on behalf of the email domain, the DNS server generates a target validation record based on the identity of the authorized delivering organization and the email domain, the target validation record including one or more rules indicating to the receiving email system that the delivering organization is an authorized sender of email for the email domain, and sends the target validation record to the receiving email system in response to the DNS query.
  • a sending email system is configured to create an email domain validation record to include in a DNS record of an email domain, the email domain validation record to be parsed by a receiving email system when receiving an email from the target domain, and indicating to the receiving email system whether the sender of an email is an authorized sender for the email domain.
  • the sending email system composes the email domain validation record to include a target domain, the target domain being a domain distinct from the email domain, causing the receiving email system, when parsing the email domain validation record, to submit a second request for a validation record to the target domain.
  • the sending email system also composes the email domain validation record to include one or more macro statements specifying identifying information, the macro statements causing the receiving email system, when parsing the email domain validation record, to include identifying information of the sender of the email in the second request.
  • the sending email system is configured to publish this created email domain validation record as a DNS record of the email domain.
  • Sender Policy Framework is a powerful tool for authenticating email, but as used today it has some substantial limitations that make it difficult to configure, and impose significant limitations on the number of services that can, in practice, be authenticated to deliver email for a given email domain.
  • systems and methods may provide a method by which email domain owners can support a) configuration of SPF authentication of their email domains in terms of services, not networking primitives and b) configuration of an unlimited number of these services.
  • FIG. 1 illustrates an example system 100 capable of validating email senders through intermediaries via EHLO name and IP address targeting according to an embodiment.
  • the system 100 includes a network 150 , one or more client devices 160 , authorizing DNS server 130 , domain owner DNS server 140 , a domain owner system 110 , a delivering email system 115 , and a receiving email system 120 .
  • the illustrated system 100 includes the elements shown in FIG. 1 , in other embodiments the system 100 may include different elements. Furthermore, the functionalities of each element may be distributed differently among the elements in other embodiments.
  • the network 150 which can be wired, wireless, or a combination thereof, enables communications among the client devices 160 , the DNS systems 130 / 140 , domain owner system 110 , and third party system 120 , and may include the Internet, a LAN, VLAN (e.g., with VPN), WAN, or other network.
  • the network 150 uses standard communications technologies and/or protocols, such as Hypertext transfer Protocol (HTTP), Transmission Control Protocol/Internet Protocol (TCP/IP), Uniform Resource Locators (URLs), and the Domain Name System (DNS).
  • HTTP Hypertext transfer Protocol
  • TCP/IP Transmission Control Protocol/Internet Protocol
  • URLs Uniform Resource Locators
  • DNS Domain Name System
  • the entities can use custom and/or dedicated data communications technologies instead of, or in addition to, the ones described above.
  • the domain owner system 110 includes one more computing systems of a particular domain (e.g., examplecorp.com), which may be configured similarly to the computing system described with reference to FIG. 4 .
  • a particular domain e.g., examplecorp.com
  • the domain owner system 110 includes a rule creator 111 that generates validation rules to allow receiving email systems, such as receiving email system 120 , to verify the authenticity of emails that indicate the domain of the domain owner system 110 as the sender of the email.
  • a receiving email system 120 may check these validation rules to see if the email was in fact legitimately sent from the domain owner system 110 .
  • the rule indicates an Internet Protocol (IP) address of the domain owner system 110 , such that the receiving email system 120 verifies whether the email was received from the IP address indicated in the rule.
  • IP Internet Protocol
  • These rules may be automatically generated based on the detected network characteristics (e.g., detected IP address of the sending email system, domain name information) or may be received by the rule creator 111 from an administrator through a user interface. Once the rules are generated, the rule creator 111 publishes the rules in a publically accessible location. This publically accessible location is a trusted location where only the domain owner for the domain of the domain owner system 110 can publish. Any receiving email system 120 may then access this public location to retrieve the rules. In one embodiment, the public location is the Domain Name System (DNS). Thus, these rules may be stored in an email domain verification record 141 on domain owner DNS server 140 . In one embodiment, the rules are Sender Policy Framework (SPF) rules (which are documented in RFC 4408 and 7208 and incorporated by reference herein).
  • SPF Sender Policy Framework
  • the delivering email system 115 sends email on behalf of the domain owner system 110 .
  • the delivering email system 115 comprises one or more computing systems, which may be configured similarly to the computing system described with reference to FIG. 4 .
  • the delivering email system 115 may be a mailing list server, a bulk mailer provider that sends emails on behalf of a domain, a transactional email system managed by a third party that sends emails on behalf of a domain, or a security system that scans emails on behalf of a domain.
  • the delivering email system 115 may send the email instead of the domain owner system 110 so that the delivering email system 115 may provide additional processing or functionality to the email.
  • the delivering email system 115 includes an email sender 116 to send emails.
  • the email sender 116 uses standard mail protocols, such as Simple Mail Transfer Protocol (SMTP).
  • SMTP supports various features.
  • SMTP indicates that the sending email system may send a HELO or extended HELO (EHLO) message to the receiving email system.
  • This HELO/EHLO message includes an identifier of the sending email system (e.g., a domain name), and in the case of an EHLO message, may include additional identifiers indicating the supported extensions and features of the sending email system.
  • the validation rules associated with the domain owner system 110 and which may be stored as an email domain validation record 141 are modified such that they may accommodate the authentication of the delivering email system 115 .
  • the receiving email system 120 is an email system that receives one or more emails from the delivering email system 115 .
  • the receiving email system 120 comprises one or more computing systems, which may be configured similarly to the computing system described with reference to FIG. 4 .
  • the receiving email system 120 includes an email receiver 122 to receive emails.
  • the email receiver 122 uses standard mail protocols, such as Simple Mail Transfer Protocol (SMTP).
  • SMTP Simple Mail Transfer Protocol
  • the receiving email system 120 comprises an email authenticator 121 to validate the identity of the sender of any received emails to ensure that the email is not fraudulent.
  • the email authenticator 121 may look up any associated email domain validation record associated with either the identification provided by the server from which the email was received (e.g., via a HELO command), or the domain indicated in the Return-Path address of the email (e.g., “gmail.com”), or via some other identifier.
  • the email authenticator 121 determines whether the information identified from the email, such as the sender's IP address, matches or is allowed by any of the rules indicated in any one of the associated email domain validation records. If a match is found in the rules, then the email authenticator 121 determines that the email message is likely to be valid and is from the purported sender and not from a fraudulent source.
  • the rules indicated in the email domain validation records are SPF rules.
  • An SPF rule may indicate an IP addresses, such that the email authenticator 121 may verify whether the IP address indicated in the SPF rule matches the IP address or other identifying information of the server that sent the email to the receiving email system 120 .
  • An SPF rule may also indicate another domain, in which case the email authenticator 121 may look up the SPF rule record for that other domain to see if any rules in that record match the identifying information of the server that sent the email.
  • SPF rules support macros, which are special placeholder indicators that the email authenticator 121 substitutes with data that is determined dynamically at the time of receipt of the email.
  • the email authenticator 121 may expand a macro such as “% ⁇ d ⁇ ” which is indicated in the rule to the Return-Path domain of the email (e.g., “acme.com”). Additional macro commands are described in further detail in the SPF RFCs 7208 and 4408.
  • the DNS servers 130 and 140 store DNS records for use in a DNS system.
  • Each DNS server may comprise one or more computing systems such as the computing system described with reference to FIG. 4 .
  • Each DNS server may store multiple DNS records for a particular domain, such an A record, MX record, and so on, as known in the art.
  • a particular domain such as A record, MX record, and so on
  • the records as illustrated in FIG. 1 are separated into multiple entries and are on multiple servers, in other embodiments the records are combined into fewer entries, a single server, a single entry, or some other combination.
  • each domain may have multiple records.
  • domain owner DNS server 140 includes an email domain validation record 141 .
  • This email domain validation record 141 may include one or more rules that allow a receiving email system 120 to validate the authenticity of an email that it has received.
  • the email domain validation record 141 may indicate an IP address or other identifier for the sender associated with a domain, such that the receiving email system 120 may be able to verify that the IP address (or other identifier) of the sender of the email corresponds to the domain indicated in the email (e.g., an email from “acmebank.com” is actually from Acme Bank).
  • the email domain validation record 141 may include a rule with a separate domain.
  • the DNS records for this separate domain may exist elsewhere, such as on authorizing DNS server 130 .
  • this rule with the separate domain also includes one or more macros, that when parsed by the receiving email system 120 , cause the receiving email system 120 to substitute the macros with additional information identifying the server from which the receiving email system 120 received the email, or other identifying information regarding the email.
  • this information includes any identifiers in an EHLO message from the server from which the receiving email system 120 received the email, as well as the IP address of the same server.
  • the rule may indicate a domain with macro of “% ⁇ i ⁇ ._ip.verifier.com”.
  • the macro “% ⁇ i ⁇ ” may be replaced by the IP address of the server that sent the email to the receiving email system 120 (e.g., this could be the delivering email system 115 ), and the receiving email system 120 queries for the DNS records of the domain “verifier.com,” and passes the IP address to the DNS server that may provide the DNS record in question.
  • the DNS records for this separate domain may reside at (or may be queried at) authorizing DNS server 130 .
  • the authorizing DNS server 130 includes a deliverer/IP store 131 that stores information regarding delivering email systems and their associated IP addresses and EHLO information.
  • the authorizing DNS server 130 also includes a deliverer/record store that stores rules authenticating various delivering email systems.
  • the authorizing DNS server 130 also includes an authorized deliverers list 132 that indicates the authorized delivering email systems for various domains.
  • the domain information is received by the authorizing DNS server 130 from the receiving email system 120 in a DNS query.
  • the authorizing DNS server 130 includes an authorization evaluator 135 that determines whether the server indicated in the identifying information is authorized to send emails on behalf of the domain that is indicated in the identifying information.
  • the domain is indicated from the EHLO information that is passed to the authorizing DNS server 130 (via the use of the macro), and the identifying information for the server is passed via an IP address.
  • the authorization evaluator 135 accesses the deliverer/IP store 131 to determine the identity of the delivering email system 115 associated with the identifying information. If such information is found, the authorization evaluator accesses the authorized deliverers list 132 to determine whether that delivering email system is an authorized delivery agent for the domain indicated in the identifying information of the DNS query.
  • the authorizing DNS server 130 includes a target record constructor 133 that constructs a set of rules using the deliverer/record store 134 as a response (to transmit) to the receiving email system 130 .
  • This set of constructed rules indicates that the delivering email system (e.g., the delivering email system 115 ) that sent the email is a valid sender for the domain indicated in the email.
  • the receiving email system 120 may then use the information in the response to verify that the delivering email system is a valid sender, and allow this email to be received by its intended recipient. Otherwise, if the delivering email system was indicated not to be valid according to the response, then the receiving email system 120 may instead discard the email or flag it.
  • the client device 160 may be used to view emails that are received an authenticated by the receiving email system 120 .
  • the client device 160 may comprise a computing system such as the computing system described with reference to FIG. 4 .
  • the client device 160 includes an email client 165 to interface with the receiving email system 120 .
  • the email client 165 may use standard email protocols, such as Post Office Protocol 3 (POP3), Internet Message Access Protocol (IMAP), Messaging Application Programming Interface (MAPI), SMTP, and so on, in order to communicate with the receiving email system 120 .
  • POP3 Post Office Protocol 3
  • IMAP Internet Message Access Protocol
  • MAPI Messaging Application Programming Interface
  • SMTP Short Message Transfer Protocol
  • the email client 165 may receive the email but also receive an indication that the email is suspected to be fraudulent or suspicious.
  • a domain owner is able to utilize the services of other third party delivering organizations and their delivering email systems in order to send emails and still have these emails be validated by receiving email systems 120 as being authentic.
  • a DNS server may, in a centralized location, construct a simple set of rules depending on the identifying information received from a receiving email system 120 for the delivering email system 115 which sent the email.
  • the receiving email system 120 does not need to query a large number of DNS records that may be present in rules in an email domain validation record. This increases performance and simplifies the management of sending emails via third party agents, while still providing security and preventing fraudulent or suspicious messages from being received. Additional details regarding the systems and processes described above are described with reference to FIGS. 2-3 .
  • FIG. 2 is an interaction diagram and flow chart illustrating an exemplary process for creation of an email domain validation record for use with a third party delivering organization according to one embodiment.
  • FIG. 2 attributes the operations in process to the indicated elements. However, some or all of the steps may be performed by other elements. In addition, some embodiments may perform the operations in parallel, perform the operations in different orders, or perform different operations. Also, it is noted that in one example embodiment the steps and/or modules may be embodied as instructions, e.g., instructions 424 , that may be executed by the processor 402 described with respect to FIG. 4 .
  • an email domain shall refer to any domain that a receiving email system 120 may use as the ‘domain’ when evaluating SPF for an inbound email message. Typically, this will be the domain found in the Return-Path for the message.
  • the domain owner system 110 may configure the DNS record for the email domain. This may involve creating (or generating) 210 an email domain validation record 141 (which may be an SPF record) for use with the email domain.
  • the record indicates that a particular sender is a valid sender for an email from the email domain.
  • the record is an SPF record and is constructed so that it may incorporate a specific “include” directive.
  • the include directive may indicate a targeted SPF domain specification, which indicates another domain, such that some or all of the SPF authentication decision for a message is deferred to the SPF record found at the other domain.
  • the record includes a separate domain which is separately queried to determine the final SPF authentication information.
  • the targeted SPF domain specification in the email domain validation record 141 may be configured to dynamically change behavior for an email message based on the SMTP connection attributes for that message. This change may be accomplished by causing the receiving server to use the SMTP connection attributes and email domain to build a custom domain name which, when resolved, yields a targeted SPF record that applies to the message being processed.
  • the targeted SPF domain specification may comprise three properties. First, it may be constructed such that the eventual authority for any domain name resolved from the targeted SPF domain specification is a targeted DNS SPF resolver (e.g., authorizing DNS server 130 ).
  • a targeted DNS SPF resolver e.g., authorizing DNS server 130 .
  • the DNS record containing the targeted SPF domain specification may be hidden behind one or more DNS CNAME or NS records referring to other domains, and not managed by the targeted DNS SPF resolver. This allows for redirection or masking of the eventual DNS query target. In other words, the other domains may need to be queried by a receiving email system before the final DNS query target is determined.
  • the targeted SPF domain specification may cause a receiving email system 120 to capture the EHLO name and/or the IP address for the SMTP connection. These values may be captured using the SPF macro system.
  • the % ⁇ h ⁇ macro can be used to capture the EHLO name
  • the % ⁇ i ⁇ or % ⁇ p ⁇ macros can be used to the capture the IP address or the validated domain name of the IP address.
  • the domain owner system 110 may configure the targeted SPF domain specification to also cause the receiving email system 120 to capture the local part of the sender address or the complete sender address with either the % ⁇ l ⁇ and/or % ⁇ s ⁇ macros, and encode the resulting values into the targeted SPF domain specification.
  • one or more of the optional transformers described in the SPF macro language may be applied in the targeted SPF domain specification.
  • the uppercase variants % ⁇ H ⁇ , % ⁇ I ⁇ , % ⁇ P ⁇ , % ⁇ L ⁇ , or % ⁇ S ⁇ may be used instead, so that the result is URL encoded.
  • the targeted SPF domain specification may be constructed in such a way that the SMTP connection attributes can be parsed unambiguously from the resulting domain, which can actually be accomplished for real world systems.
  • the targeted DNS SPF resolver e.g. authorizing DNS server 130
  • email domain is ‘emaildomain.com’.
  • both the EHLO name and the IP address are captured.
  • LDH Letters-Digits-Hyphen
  • FQDN fully qualified domain names
  • FQDN fully qualified domain names
  • these fields may be separated by the domain owner system 110 when creating the targeted SPF domain specification with labels that contain non-LDH characters such as ‘_’. Since an IP address can only consist of digits (IPv4) or digits and the letters a-f (IPv6), the labels comprising the IP address cannot contain ‘_’ either. Thus, labels containing ‘_’ may be used as separators for these values as well.
  • one targeted SPF domain specification that meets the requirements within the context of the example is: ‘% ⁇ i ⁇ ._ipaddr.% ⁇ h ⁇ ._ehlo.emaildomain.com._tspf.resolver.com’. Any domain name interpolated during the SPF process from this domain spec will be rooted in ‘resolver.com’ (the rightmost domain indicated). It includes both the EHLO name and IP address in the domain name. Furthermore, the use of labels containing ‘_’ supports non-ambiguous parsing of the SMTP attributes from such a domain name.
  • the email domain validation record 141 should then have an SPF rule that has an include directive that refers to a targeted SPF domain specification as described above.
  • the email domain validation record 141 may be published 215 as a DNS TXT record for the email domain (e.g., at domain owner DNS server 140 ). This will allow it to be queried by any server that receives email that indicates this domain.
  • FIG. 3 is an interaction diagram and flow chart illustrating an exemplary process for resolution of an email domain validation record using DNS according to one embodiment.
  • FIG. 3 attributes the operations in process to the indicated elements. However, some or all of the steps may be performed by other elements. In addition, some embodiments may perform the operations in parallel, perform the operations in different orders, or perform different operations. Also, it is noted that in one example embodiment the steps and/or modules may be embodied as instructions, e.g., instructions 424 , that may be executed by the processor 402 described with respect to FIG. 4 . Note that the processes described here do not necessarily require any additional modification or configuration of the receiving email system 120 . Instead, so long as the receiving email system 120 supports SPF or a similar sender authentication scheme, it does not need to be modified.
  • the receiving email system 120 receives 310 an email with a return path corresponding to a particular email domain.
  • the receiving email system 120 may attempt to authenticate this email message (e.g., using SPF).
  • the receiving email system 120 may first query 315 DNS for any email validation records for the email domain. These may be SPF records.
  • the domain owner DNS server 140 may return the an email domain validation record 141 in a response 282 that the owner of the email domain has published as described with reference to FIG. 2 .
  • the receiving email system 120 parses the email validation record, and generates 320 a target domain query. This process may include evaluating the include directive with the target domain SPF specification in the returned DNS record using values for the current SMTP connection (e.g., EHLO, IP address), and interpolating these values into the target domain SPF specification to construct the target domain.
  • the receiving email system 120 may evaluate this into ““123.123.123._ipaddr.deliveringdomain.com._ehlo.emaildomain.com._tspf.resolver.com’ assuming that 123.123.123.123 is the IP address of the sender, emaildomain.com is the domain of the original sender, and deliveringdomain.com is the domain name indicated in the EHLO message for the sender.
  • the receiving email system 120 queries 325 the DNS with the target domain.
  • This query may be responded to by the authorizing DNS server 130 (which may be an authoritative server for the target domain).
  • the authorizing DNS server 130 extracts 340 the identifying information from the query. This identifying information may include the EHLO name and IP address, and may be parsed from the target domain query.
  • the authorizing DNS server 130 may also parse the local part of the Return-Path address from target domain of the query, either as a stand-alone value or as part of an encoded complete sender address.
  • the authorizing DNS server 130 uses the identifying information that is extracted from the query to identify 345 the delivering organization.
  • the delivering organization is the owner of the delivering email system 115 , which may not be part of the email domain.
  • the authorizing DNS server 130 includes a deliverer/IP store 131 that associates the identifying information extracted from the query with delivering organizations such that network specific information associated with an email message's SMTP connection (e.g., EHLO name and/or sending server IP address) may be associated with the higher-level abstraction of a delivering organization.
  • network specific information associated with an email message's SMTP connection e.g., EHLO name and/or sending server IP address
  • Some examples of common delivering organizations are third party senders contracted to send email by the email domain owner, a mailing list that is relaying a message originating from the email domain to a number of receiving addresses, or a forwarding system that is designed to alias one receiver address to another. This set of examples should not be considered exhaustive, and the list should be considered non-limiting.
  • access to the header information of a substantial (i.e., statistically significant) corpus of email may allow the authorizing DNS server 130 or other entity to construct the deliverer/IP store 131 by use of information found in the email headers (specifically the ‘Received’ and ‘Authentication-Results’ headers).
  • information found in the email headers specifically the ‘Received’ and ‘Authentication-Results’ headers.
  • domain registration records especially the information stored in the WHOIS database, can be useful for building this mapping for the deliverer/IP store 131 .
  • the inbound stream of DNS queries received by the authorizing DNS server 130 can be used as a source of EHLO names and IP addresses that require investigation.
  • EHLO Name, IP Address For a complete database all (EHLO Name, IP Address) combinations originating from legitimate email should map to a known delivering organization. Any inbound data that cannot be mapped to a known delivering organization may generally indicate a) missing legitimate values in the database or b) a source email that is fraudulent. This ‘miss’ can thus serve as a source of information to fill in gaps in the database or a source of threat information.
  • the authorizing DNS server 130 can determine 350 whether the delivering organization is authorized to deliver email for the email domain indicated in the query for the target domain.
  • the authorizing DNS server 130 allows any identified delivering organization to deliver email for any email domain.
  • the mapping of email domain to authorized delivering organization could be stored in an authorized deliverers list 132 , or made available via a web API, and the authorizing DNS server 130 accesses the list or API to determine whether the delivering organization is authorized.
  • the local part of the Return-Path address may have been encoded in the query of the target domain either as a standalone value, or as part of the sender address.
  • the authorizing DNS server 130 uses the local part of the email address in combination with the email domain to determine whether a delivering organization is authorized to deliver a particular message. For example, a delivering organization may be authorized to send mail on behalf of a “newsletter@acme.com” but not on behalf of a return path address with a local part indicating an email address of an employee at acme.com.
  • the authorizing DNS server 130 If the delivering organization is authorized to deliver email for the email domain, then the authorizing DNS server 130 generates 355 a target validation record (which may be an SPF record) based on the delivering organization and the email domain. To construct this record, the authorizing DNS server 130 may query a deliverer/record store 134 that includes a map of delivering organizations to target validation records.
  • a target validation record which may be an SPF record
  • email validation record For each delivering organization, there may exist some hypothetical email validation record that would allow email from servers used by that delivering organization (e.g., the delivering email system 115 ), and deny email originating anywhere else. This should be true for any delivering organization that has a properly configured email domain validation record (e.g., an SPF record), as the existing email domain validation record for the delivering organization may be used.
  • a properly configured email domain validation record e.g., an SPF record
  • the authorizing DNS server 130 may be able to build such a record given sufficient knowledge of the underlying network configuration.
  • the authorizing DNS server 130 creates and stores the email domain validation records for delivering organizations and/or email domains that are not otherwise made available by the delivering organization.
  • the deliverer/record store 134 also associates the email domain and/or the local path as either a replacement or a supplement to the association of the delivering organization with the target validation record.
  • the deliverer/record store 134 also associates the email domain and/or the local path as either a replacement or a supplement to the association of the delivering organization with the target validation record.
  • existing email domain validation records may be an important source of information to construct the deliverer/record store 134 .
  • the existing records for the delivering organization may be used to get a list of directives.
  • a manual survey of the delivering organizations can also be a good source of this information.
  • additional methods may also be feasible, as is the use of combinations of sources. The sources listed here should be considered non-limiting.
  • the authorizing DNS server 130 may use polling mechanisms to update the deliverer/record store 134 , while in other embodiments.
  • polling mechanism would be a software component on the authorizing DNS server 130 that executes DNS queries on a regular (e.g. daily) basis to detect updates to DNS records published by known senders. Those updates could then be incorporated by the authorizing DNS server 130 into the database.
  • the authorizing DNS server 130 After generating the target validation record, the authorizing DNS server 130 transmits 360 the record back to the receiving mail system 120 as a response to the original query.
  • the receiving mail system 120 authenticates 330 the email message using the received target validation record.
  • the system described here may be configured to use the ‘a’, ‘mx’, or ‘exists’ mechanisms that are part of SPF. If one of these mechanisms is used, the behavior of the email domain owner may be largely unchanged—the ‘a’, ‘mx’, or ‘exists’ mechanism may be simply substituted for the ‘include’ mechanism in this case.
  • the behavior of the authorizing DNS server 130 is mostly unchanged, except for its return values.
  • the authorizing DNS server 130 may return an NXDOMAIN code.
  • the authorizing DNS server 130 may match the IP address against the target validation record. If the IP address does not match the record, then the authorizing DNS server 130 may return an NXDOMAIN. Alternately, if the IP address is found to match, then the authorizing DNS server 130 may return an A, MX, or A record that includes the IP address.
  • the authorizing DNS server 130 is used as a remote SPF auditing tool. SPF resolution occurs on the receiving email system 120 , and as such the results of that evaluation may not generally be available to external auditing systems unless special software is installed. If the targeted SPF domain specification has been structured to include both the EHLO name and IP address, the authorizing DNS server 130 may be invoked at least once for each (EHLO name, IP address) combination from which a message is delivered. With this information the resolver can mirror the SPF evaluation carried out by the receiving email system 120 and log the corresponding result.
  • FIG. 4 is a block diagram illustrating components of an example machine able to read instructions from a machine-readable medium and execute them in a processor (or controller). Specifically, FIG. 4 shows a diagrammatic representation of a machine in the example form of a computer system 400 .
  • the computer system 400 can be used to execute instructions 424 (e.g., program code or software) for causing the machine to perform any one or more of the methodologies (or processes) described herein.
  • the machine operates as a standalone device or a connected (e.g., networked) device that connects to other machines. In a networked deployment, the machine may operate in the capacity of a server machine or a client machine in a server-client network environment, or as a peer machine in a peer-to-peer (or distributed) network environment.
  • the machine may be a server computer, a client computer, a personal computer (PC), a tablet PC, a set-top box (STB), a smartphone, an internet of things (IoT) appliance, a network router, switch or bridge, or any machine capable of executing instructions 424 (sequential or otherwise) that specify actions to be taken by that machine.
  • PC personal computer
  • tablet PC tablet PC
  • STB set-top box
  • smartphone an internet of things (IoT) appliance
  • IoT internet of things
  • network router switch or bridge
  • the example computer system 400 includes one or more processing units (generally processor 402 ).
  • the processor 402 is, for example, a central processing unit (CPU), a graphics processing unit (GPU), a digital signal processor (DSP), a controller, a state machine, one or more application specific integrated circuits (ASICs), one or more radio-frequency integrated circuits (RFICs), or any combination of these.
  • the computer system 400 also includes a main memory 404 .
  • the computer system may include a storage unit 416 .
  • the processor 402 , memory 404 and the storage unit 416 communicate via a bus 408 .
  • the computer system 406 400 can include a static memory 406 , a display driver 410 (e.g., to drive a plasma display panel (PDP), a liquid crystal display (LCD), or a projector).
  • the computer system 400 may also include alphanumeric input device 412 (e.g., a keyboard), a cursor control device 414 (e.g., a mouse, a trackball, a joystick, a motion sensor, or other pointing instrument), a signal generation device 418 (e.g., a speaker), and a network interface device 420 , which also are configured to communicate via the bus 408 .
  • the storage unit 416 includes a machine-readable medium 422 on which is stored instructions 424 (e.g., software) embodying any one or more of the methodologies or functions described herein.
  • the instructions 424 may also reside, completely or at least partially, within the main memory 404 or within the processor 402 (e.g., within a processor's cache memory) during execution thereof by the computer system 400 , the main memory 404 and the processor 402 also constituting machine-readable media.
  • the instructions 424 may be transmitted or received over a network 426 via the network interface device 420 .
  • machine-readable medium 422 is shown in an example embodiment to be a single medium, the term “machine-readable medium” should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, or associated caches and servers) able to store the instructions 424 .
  • the term “machine-readable medium” shall also be taken to include any medium that is capable of storing instructions 424 for execution by the machine and that cause the machine to perform any one or more of the methodologies disclosed herein.
  • the term “machine-readable medium” includes, but not be limited to, data repositories in the form of solid-state memories, optical media, and magnetic media.
  • a domain owner is able to utilize the services of other third party delivering organizations and their delivering email systems in order to send emails and still have these emails be validated by receiving email systems as being authentic.
  • a DNS server may, in a centralized location, generate a simple set of rules depending on the identifying information received from a receiving email system for the delivering email system which sent the email.
  • the receiving email system does not need to query a large number of DNS records that may be present in rules in an email domain validation record. This increases performance and simplifies the management of sending emails via third party agents, while still providing security and preventing fraudulent or suspicious messages from being received.
  • Modules may constitute either software modules (e.g., code embodied on a machine-readable medium or in a transmission signal) or hardware modules.
  • a hardware module is tangible unit capable of performing certain operations and may be configured or arranged in a certain manner.
  • one or more computer systems e.g., a standalone, client or server computer system
  • one or more hardware modules of a computer system e.g., a processor or a group of processors
  • software e.g., an application or application portion
  • a hardware module may be implemented mechanically or electronically.
  • a hardware module may comprise dedicated circuitry or logic that is permanently configured (e.g., as a special-purpose processor, such as a field programmable gate array (FPGA) or an application-specific integrated circuit (ASIC)) to perform certain operations.
  • a hardware module may also comprise programmable logic or circuitry (e.g., as encompassed within a general-purpose processor or other programmable processor) that is temporarily configured by software to perform certain operations. It will be appreciated that the decision to implement a hardware module mechanically, in dedicated and permanently configured circuitry, or in temporarily configured circuitry (e.g., configured by software) may be driven by cost and time considerations.
  • processors may be temporarily configured (e.g., by software) or permanently configured to perform the relevant operations. Whether temporarily or permanently configured, such processors may constitute processor-implemented modules that operate to perform one or more operations or functions.
  • the modules referred to herein may, in some example embodiments, comprise processor-implemented modules.
  • the one or more processors may also operate to support performance of the relevant operations in a “cloud computing” environment or as a “software as a service” (SaaS). For example, at least some of the operations may be performed by a group of computers (as examples of machines including processors), these operations being accessible via a network (e.g., the Internet) and via one or more appropriate interfaces (e.g., application program interfaces (APIs).)
  • SaaS software as a service
  • the performance of certain of the operations may be distributed among the one or more processors, not only residing within a single machine, but deployed across a number of machines.
  • the one or more processors or processor-implemented modules may be located in a single geographic location (e.g., within a home environment, an office environment, or a server farm). In other example embodiments, the one or more processors or processor-implemented modules may be distributed across a number of geographic locations.
  • any reference to “one embodiment” or “an embodiment” means that a particular element, feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment.
  • the appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment.
  • Coupled and “connected” along with their derivatives.
  • some embodiments may be described using the term “coupled” to indicate that two or more elements are in direct physical or electrical contact.
  • the term “coupled,” however, may also mean that two or more elements are not in direct contact with each other, but yet still co-operate or interact with each other.
  • the embodiments are not limited in this context.
  • the terms “comprises,” “comprising,” “includes,” “including,” “has,” “having” or any other variation thereof, are intended to cover a non-exclusive inclusion.
  • a process, method, article, or apparatus that comprises a list of elements is not necessarily limited to only those elements but may include other elements not expressly listed or inherent to such process, method, article, or apparatus.
  • “or” refers to an inclusive or and not to an exclusive or. For example, a condition A or B is satisfied by any one of the following: A is true (or present) and B is false (or not present), A is false (or not present) and B is true (or present), and both A and B are true (or present).

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Hardware Design (AREA)
  • General Engineering & Computer Science (AREA)
  • Computing Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • General Health & Medical Sciences (AREA)
  • Health & Medical Sciences (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Virology (AREA)
  • Databases & Information Systems (AREA)
  • Bioethics (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

A DNS server receives from a receiving email system, a DNS query for an email domain stored at the DNS server, the DNS query including identifying information of a sender of an email. The DNS server extracts the identifying information of the email sender from the DNS query and identifies one of a plurality of delivering organizations from the information. The DNS server determines whether the identified delivering organization is authorized to deliver email on behalf of the email domain. In response to determining that the identified delivering organization is authorized to deliver email on behalf of the email domain, the DNS server generates a target validation record based on the identity of the authorized delivering organization and the email domain, the target validation record including one or more rules indicating to the receiving email system whether the delivering organization is an authorized sender of email for the email domain.

Description

    CROSS REFERENCE TO RELATED APPLICATIONS
  • This application is a continuation application of U.S. application Ser. No. 15/663,771, filed Jul. 30, 2017, which is a continuation U.S. application Ser. No. 15/175,031, filed Jun. 6, 2016, which is a continuation of International Application No. PCT/US2016/015796, filed on Jan. 29, 2016, which claims the benefit of U.S. Provisional Application No. 62/116,409, filed on Feb. 14, 2015, all of which are hereby incorporated by reference in their entirety.
  • BACKGROUND Field of Art
  • The disclosure generally relates to the field of electronic messaging, and specifically to centralized validation of email senders via EHLO name and IP address targeting.
  • Description of Art
  • In distributed messaging systems like email, the actual originator of a message may be validated against the message's purported identity in order to eliminate fraudulent messages. Examples of such fraudulent messages may include “phishing” emails that purport to be from a particular sender but in fact have a spoofed sender address and are sent from a malicious entity that may wish to perform some fraudulent activity against the recipient (e.g., steal personal information). One approach to this validation problem is to enable the owner of the sending identity to create a set of rules defining which computers are allowed to relay emails to the recipient's email server. Sender Policy Framework (SPF) is the standard implementation of this approach for email. A sending identity publishes these SPF rules via the Domain Name System (DNS) such that a receiving mail server may be able to access them in order to validate the sender's identity of received messages.
  • While this approach can be effective, it places substantial burdens on the receiving system and introduces challenges with the use of valid intermediaries (e.g. mailing lists, ‘lifetime’ email accounts). For example, a mailing list server may be asked to forward a message from an original sender, however, the mailing list server is not identified by the original sender as a valid sender. It is simply not feasible for receiving systems to check more than a few such rules when validating a message, even though a complete rule set might require hundreds or even thousands of rules.
  • SPF also includes tight limits on the number of Domain Name System (DNS) lookups that are allowed, in order to limit the burden on receiving systems, but this comes at the cost of failing to validate some legitimate messages. Other techniques, like Sender Rewriting Scheme (SRS), replace the original sender with an intermediate identity that can be validated with a more restricted rule set. While this minimizes the burden on the receiving system, it does not validate the message against the originator's identify.
  • Hence, what is lacking is an ability to allow the definition of arbitrarily large and complex rule sets for sender identity verification, without unduly burdening receiving systems, and which is compatible and interoperable with existing frameworks.
  • SUMMARY
  • In some embodiments, systems and methods may comprise reframing the authentication questions around email from the network or IP level to the sending organization level, utilizing the ability of the existing Sender Policy Framework (SPF) protocol to encode network information available from the SMTP connection into a targeted domain name, and combining that with a custom DNS system backed by a database that maps that network information to a list of known organizations.
  • In some embodiments, systems and methods allow domain managers to define a set of organizations that are able to send email on their behalf without any additional work, such as manual lookup of SPF records for authorized organizations, modification of DNS TXT records for the domain, etc. It also allows domain manager to authorize any number of sending organizations, and frees the domain manager of the need to track changes to the SPF configuration for authorized senders.
  • In some embodiments, systems and methods may comprise a Sender Policy Framework (SPF) which may be the protocol by which the owners of a domain can define a set of rules (known as directives) in a DNS TXT record designating which mail servers can deliver emails originating from that domain. Receiving mail servers evaluate those rules and, based on the IP address of the delivering server, determine whether the message in question is allowed to originate from that domain.
  • In some embodiments, systems and methods may utilize two features of SPF. First, the ‘include’ mechanism, by which an SPF record can reference a target domain where an additional DNS SPF record is defined, and include the rules defined in this references record into the evaluated rule set. Second, the macro system by which request-specific values such as the IP address and EHLO name associated with the SMTP connection can be interpolated into the target domain.
  • In some embodiments, when configuring a domain, an SPF record may be constructed for the domain that incorporates an ‘include’ directive that uses SPF macros to encode the name of the domain for which an email is being authorized, as well as the EHLO name and/or IP address of the SMTP connection into a target domain name. The target domain name may be constructed so as to be in a DNS zone managed by the targeted SPF DNS resolver—the DNS system responsible for mapping network information to a list of known organizations.
  • In further embodiments, the targeted SPF DNS resolver may be responsible for responding to DNS queries to target domains. It may also be responsible for maintaining an accurate and up-to-date mapping of network information to known organizations, which may involve combining public information such as domain registration records, public DNS entries, and curated information.
  • In further embodiments, systems and methods for enhancing sender policy framework (SPF) may advance the art of authenticating email, by reducing the overall complexity and maintenance burden exposed to a domain manager and removing existing limitations of the state of the art systems for providing similar authentication. In addition, the methods may not require any changes to the systems receiving email, and may be compatible with the existing and extensive base of installed software.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • The disclosed embodiments have advantages and features which will be more readily apparent from the detailed description, the appended claims, and the accompanying figures (or drawings). A brief introduction of the figures is below.
  • FIG. 1 illustrates an example system capable of validating email senders through intermediaries via EHLO name and IP address targeting according to an embodiment.
  • FIG. 2 is an interaction diagram and flow chart illustrating an exemplary process for creation of an email domain validation record for use with a third party delivering organization according to one embodiment.
  • FIG. 3 is an interaction diagram and flow chart illustrating an exemplary process for resolution of an email domain validation record using DNS according to one embodiment.
  • FIG. 4 is a block diagram illustrating components of an example machine able to read instructions from a machine-readable medium and execute them in a processor (or controller).
  • DETAILED DESCRIPTION
  • The Figures (FIGS.) and the following description relate to preferred embodiments by way of illustration only. It should be noted that from the following discussion, alternative embodiments of the structures and methods disclosed herein will be readily recognized as viable alternatives that may be employed without departing from the principles of what is claimed.
  • Reference will now be made in detail to several embodiments, examples of which are illustrated in the accompanying figures. It is noted that wherever practicable similar or like reference numbers may be used in the figures and may indicate similar or like functionality. The figures depict embodiments of the disclosed system (or method) for purposes of illustration only. One skilled in the art will readily recognize from the following description that alternative embodiments of the structures and methods illustrated herein may be employed without departing from the principles described herein.
  • Configuration Overview
  • Disclosed by way of example embodiments is a system and process capable of validating email senders through intermediaries via EHLO name and IP address targeting. In an embodiment, a DNS server receives from a receiving email system, a DNS query for an email domain stored at the DNS server, the DNS query including identifying information of a sender of an email, and the email identifying itself as being from the email domain. The DNS server extracts the identifying information of the email sender from the DNS query, and identifies one of a plurality of delivering organizations from the identifying information. The DNS server determines whether the identified delivering organization is authorized to deliver email on behalf of the email domain. In response to determining that the identified delivering organization is authorized to deliver email on behalf of the email domain, the DNS server generates a target validation record based on the identity of the authorized delivering organization and the email domain, the target validation record including one or more rules indicating to the receiving email system that the delivering organization is an authorized sender of email for the email domain, and sends the target validation record to the receiving email system in response to the DNS query.
  • In one embodiment, a sending email system is configured to create an email domain validation record to include in a DNS record of an email domain, the email domain validation record to be parsed by a receiving email system when receiving an email from the target domain, and indicating to the receiving email system whether the sender of an email is an authorized sender for the email domain. To create the email domain validation record, the sending email system composes the email domain validation record to include a target domain, the target domain being a domain distinct from the email domain, causing the receiving email system, when parsing the email domain validation record, to submit a second request for a validation record to the target domain. The sending email system also composes the email domain validation record to include one or more macro statements specifying identifying information, the macro statements causing the receiving email system, when parsing the email domain validation record, to include identifying information of the sender of the email in the second request. The sending email system is configured to publish this created email domain validation record as a DNS record of the email domain.
  • Introduction
  • Sender Policy Framework (SPF) is a powerful tool for authenticating email, but as used today it has some substantial limitations that make it difficult to configure, and impose significant limitations on the number of services that can, in practice, be authenticated to deliver email for a given email domain. In some embodiments, systems and methods may provide a method by which email domain owners can support a) configuration of SPF authentication of their email domains in terms of services, not networking primitives and b) configuration of an unlimited number of these services.
  • Example Key Delegation System
  • FIG. 1 illustrates an example system 100 capable of validating email senders through intermediaries via EHLO name and IP address targeting according to an embodiment. The system 100 includes a network 150, one or more client devices 160, authorizing DNS server 130, domain owner DNS server 140, a domain owner system 110, a delivering email system 115, and a receiving email system 120. Although the illustrated system 100 includes the elements shown in FIG. 1, in other embodiments the system 100 may include different elements. Furthermore, the functionalities of each element may be distributed differently among the elements in other embodiments.
  • The network 150, which can be wired, wireless, or a combination thereof, enables communications among the client devices 160, the DNS systems 130/140, domain owner system 110, and third party system 120, and may include the Internet, a LAN, VLAN (e.g., with VPN), WAN, or other network. In one embodiment, the network 150 uses standard communications technologies and/or protocols, such as Hypertext transfer Protocol (HTTP), Transmission Control Protocol/Internet Protocol (TCP/IP), Uniform Resource Locators (URLs), and the Domain Name System (DNS). In another embodiment, the entities can use custom and/or dedicated data communications technologies instead of, or in addition to, the ones described above.
  • The domain owner system 110 includes one more computing systems of a particular domain (e.g., examplecorp.com), which may be configured similarly to the computing system described with reference to FIG. 4.
  • In one embodiment, the domain owner system 110 includes a rule creator 111 that generates validation rules to allow receiving email systems, such as receiving email system 120, to verify the authenticity of emails that indicate the domain of the domain owner system 110 as the sender of the email. When a receiving email system 120 receives such an email, it may check these validation rules to see if the email was in fact legitimately sent from the domain owner system 110. In one embodiment, the rule indicates an Internet Protocol (IP) address of the domain owner system 110, such that the receiving email system 120 verifies whether the email was received from the IP address indicated in the rule.
  • These rules may be automatically generated based on the detected network characteristics (e.g., detected IP address of the sending email system, domain name information) or may be received by the rule creator 111 from an administrator through a user interface. Once the rules are generated, the rule creator 111 publishes the rules in a publically accessible location. This publically accessible location is a trusted location where only the domain owner for the domain of the domain owner system 110 can publish. Any receiving email system 120 may then access this public location to retrieve the rules. In one embodiment, the public location is the Domain Name System (DNS). Thus, these rules may be stored in an email domain verification record 141 on domain owner DNS server 140. In one embodiment, the rules are Sender Policy Framework (SPF) rules (which are documented in RFC 4408 and 7208 and incorporated by reference herein).
  • The delivering email system 115 sends email on behalf of the domain owner system 110. The delivering email system 115 comprises one or more computing systems, which may be configured similarly to the computing system described with reference to FIG. 4. As an example, the delivering email system 115 may be a mailing list server, a bulk mailer provider that sends emails on behalf of a domain, a transactional email system managed by a third party that sends emails on behalf of a domain, or a security system that scans emails on behalf of a domain. The delivering email system 115 may send the email instead of the domain owner system 110 so that the delivering email system 115 may provide additional processing or functionality to the email.
  • The delivering email system 115 includes an email sender 116 to send emails. In one embodiment, the email sender 116 uses standard mail protocols, such as Simple Mail Transfer Protocol (SMTP). SMTP supports various features. In particular, when a sending email system communicates with a receiving email system, SMTP indicates that the sending email system may send a HELO or extended HELO (EHLO) message to the receiving email system. This HELO/EHLO message includes an identifier of the sending email system (e.g., a domain name), and in the case of an EHLO message, may include additional identifiers indicating the supported extensions and features of the sending email system.
  • When forwarding or otherwise transferring messages or emails that were originally sent by the domain owner system 110, the validation rules associated with the domain owner system 110 and which may be stored as an email domain validation record 141 are modified such that they may accommodate the authentication of the delivering email system 115.
  • The receiving email system 120 is an email system that receives one or more emails from the delivering email system 115. The receiving email system 120 comprises one or more computing systems, which may be configured similarly to the computing system described with reference to FIG. 4.
  • The receiving email system 120 includes an email receiver 122 to receive emails. In one embodiment, the email receiver 122 uses standard mail protocols, such as Simple Mail Transfer Protocol (SMTP).
  • The receiving email system 120 comprises an email authenticator 121 to validate the identity of the sender of any received emails to ensure that the email is not fraudulent. Upon receiving an email, the email authenticator 121 may look up any associated email domain validation record associated with either the identification provided by the server from which the email was received (e.g., via a HELO command), or the domain indicated in the Return-Path address of the email (e.g., “gmail.com”), or via some other identifier. The email authenticator 121 determines whether the information identified from the email, such as the sender's IP address, matches or is allowed by any of the rules indicated in any one of the associated email domain validation records. If a match is found in the rules, then the email authenticator 121 determines that the email message is likely to be valid and is from the purported sender and not from a fraudulent source.
  • In one embodiment, the rules indicated in the email domain validation records are SPF rules. An SPF rule may indicate an IP addresses, such that the email authenticator 121 may verify whether the IP address indicated in the SPF rule matches the IP address or other identifying information of the server that sent the email to the receiving email system 120. An SPF rule may also indicate another domain, in which case the email authenticator 121 may look up the SPF rule record for that other domain to see if any rules in that record match the identifying information of the server that sent the email. Additionally, in some cases, SPF rules support macros, which are special placeholder indicators that the email authenticator 121 substitutes with data that is determined dynamically at the time of receipt of the email. For example, the email authenticator 121 may expand a macro such as “%{d}” which is indicated in the rule to the Return-Path domain of the email (e.g., “acme.com”). Additional macro commands are described in further detail in the SPF RFCs 7208 and 4408.
  • The DNS servers 130 and 140 store DNS records for use in a DNS system. Each DNS server may comprise one or more computing systems such as the computing system described with reference to FIG. 4.
  • Each DNS server may store multiple DNS records for a particular domain, such an A record, MX record, and so on, as known in the art. Although the records as illustrated in FIG. 1 are separated into multiple entries and are on multiple servers, in other embodiments the records are combined into fewer entries, a single server, a single entry, or some other combination. Furthermore, although a certain number of records for each domain are illustrated in FIG. 1, in other embodiments each domain may have multiple records.
  • As illustrated in FIG. 1, domain owner DNS server 140 includes an email domain validation record 141. This email domain validation record 141 may include one or more rules that allow a receiving email system 120 to validate the authenticity of an email that it has received. As described above, the email domain validation record 141 may indicate an IP address or other identifier for the sender associated with a domain, such that the receiving email system 120 may be able to verify that the IP address (or other identifier) of the sender of the email corresponds to the domain indicated in the email (e.g., an email from “acmebank.com” is actually from Acme Bank). However, such a simple rule may be disadvantageous in the case where a third party delivering email system 115 is used to send mail on behalf of a sending email system or domain owner. This is because the rule in the email domain validation record 141 may not indicate that the delivering email system 115 is a valid sender for a particular domain.
  • Instead, the email domain validation record 141 may include a rule with a separate domain. The DNS records for this separate domain may exist elsewhere, such as on authorizing DNS server 130. Furthermore, this rule with the separate domain also includes one or more macros, that when parsed by the receiving email system 120, cause the receiving email system 120 to substitute the macros with additional information identifying the server from which the receiving email system 120 received the email, or other identifying information regarding the email. In one embodiment, this information includes any identifiers in an EHLO message from the server from which the receiving email system 120 received the email, as well as the IP address of the same server. Once the rule is parsed, the receiving email system 120 is caused by the rule to query the DNS records of the separate domain indicated in the rule. For example, the rule may indicate a domain with macro of “%{i}._ip.verifier.com”. After expansion, the macro “%{i}” may be replaced by the IP address of the server that sent the email to the receiving email system 120 (e.g., this could be the delivering email system 115), and the receiving email system 120 queries for the DNS records of the domain “verifier.com,” and passes the IP address to the DNS server that may provide the DNS record in question.
  • The DNS records for this separate domain may reside at (or may be queried at) authorizing DNS server 130. The authorizing DNS server 130 includes a deliverer/IP store 131 that stores information regarding delivering email systems and their associated IP addresses and EHLO information. The authorizing DNS server 130 also includes a deliverer/record store that stores rules authenticating various delivering email systems. The authorizing DNS server 130 also includes an authorized deliverers list 132 that indicates the authorized delivering email systems for various domains.
  • The domain information, with the macros replaced by the identifying information of the server that sent the email as described above, is received by the authorizing DNS server 130 from the receiving email system 120 in a DNS query. The authorizing DNS server 130 includes an authorization evaluator 135 that determines whether the server indicated in the identifying information is authorized to send emails on behalf of the domain that is indicated in the identifying information. In one embodiment, the domain is indicated from the EHLO information that is passed to the authorizing DNS server 130 (via the use of the macro), and the identifying information for the server is passed via an IP address. The authorization evaluator 135 accesses the deliverer/IP store 131 to determine the identity of the delivering email system 115 associated with the identifying information. If such information is found, the authorization evaluator accesses the authorized deliverers list 132 to determine whether that delivering email system is an authorized delivery agent for the domain indicated in the identifying information of the DNS query.
  • If so, the authorizing DNS server 130 includes a target record constructor 133 that constructs a set of rules using the deliverer/record store 134 as a response (to transmit) to the receiving email system 130. This set of constructed rules indicates that the delivering email system (e.g., the delivering email system 115) that sent the email is a valid sender for the domain indicated in the email. The receiving email system 120 may then use the information in the response to verify that the delivering email system is a valid sender, and allow this email to be received by its intended recipient. Otherwise, if the delivering email system was indicated not to be valid according to the response, then the receiving email system 120 may instead discard the email or flag it.
  • The client device 160 may be used to view emails that are received an authenticated by the receiving email system 120. The client device 160 may comprise a computing system such as the computing system described with reference to FIG. 4.
  • Specifically, the client device 160 includes an email client 165 to interface with the receiving email system 120. The email client 165 may use standard email protocols, such as Post Office Protocol 3 (POP3), Internet Message Access Protocol (IMAP), Messaging Application Programming Interface (MAPI), SMTP, and so on, in order to communicate with the receiving email system 120. In one embodiment, if an email is not properly authenticated by the receiving email system 120, the email client 165 does not receive the email. In other embodiments, the email client 165 may receive the email but also receive an indication that the email is suspected to be fraudulent or suspicious.
  • Using the system 100 described above, a domain owner is able to utilize the services of other third party delivering organizations and their delivering email systems in order to send emails and still have these emails be validated by receiving email systems 120 as being authentic. Instead of updating a variety of email domain validation records, a DNS server may, in a centralized location, construct a simple set of rules depending on the identifying information received from a receiving email system 120 for the delivering email system 115 which sent the email. Furthermore, the receiving email system 120 does not need to query a large number of DNS records that may be present in rules in an email domain validation record. This increases performance and simplifies the management of sending emails via third party agents, while still providing security and preventing fraudulent or suspicious messages from being received. Additional details regarding the systems and processes described above are described with reference to FIGS. 2-3.
  • Example Interaction Diagram for Email Domain Validation Record Creation
  • FIG. 2 is an interaction diagram and flow chart illustrating an exemplary process for creation of an email domain validation record for use with a third party delivering organization according to one embodiment. In one embodiment, FIG. 2 attributes the operations in process to the indicated elements. However, some or all of the steps may be performed by other elements. In addition, some embodiments may perform the operations in parallel, perform the operations in different orders, or perform different operations. Also, it is noted that in one example embodiment the steps and/or modules may be embodied as instructions, e.g., instructions 424, that may be executed by the processor 402 described with respect to FIG. 4.
  • For the purposes of this discussion, an email domain shall refer to any domain that a receiving email system 120 may use as the ‘domain’ when evaluating SPF for an inbound email message. Typically, this will be the domain found in the Return-Path for the message.
  • The domain owner system 110, which is the email domain owner, or a designated party, may configure the DNS record for the email domain. This may involve creating (or generating) 210 an email domain validation record 141 (which may be an SPF record) for use with the email domain. The record indicates that a particular sender is a valid sender for an email from the email domain. In one embodiment, the record is an SPF record and is constructed so that it may incorporate a specific “include” directive. The include directive may indicate a targeted SPF domain specification, which indicates another domain, such that some or all of the SPF authentication decision for a message is deferred to the SPF record found at the other domain. In other words, as described above, the record includes a separate domain which is separately queried to determine the final SPF authentication information.
  • In one embodiment, the targeted SPF domain specification in the email domain validation record 141 may be configured to dynamically change behavior for an email message based on the SMTP connection attributes for that message. This change may be accomplished by causing the receiving server to use the SMTP connection attributes and email domain to build a custom domain name which, when resolved, yields a targeted SPF record that applies to the message being processed.
  • To accomplish this, in one embodiment, the targeted SPF domain specification may comprise three properties. First, it may be constructed such that the eventual authority for any domain name resolved from the targeted SPF domain specification is a targeted DNS SPF resolver (e.g., authorizing DNS server 130).
  • This may be accomplished by ensuring that the targeted domain specification eventually resolves to a subdomain of one or more particular fixed domains. In some implementations the DNS record containing the targeted SPF domain specification may be hidden behind one or more DNS CNAME or NS records referring to other domains, and not managed by the targeted DNS SPF resolver. This allows for redirection or masking of the eventual DNS query target. In other words, the other domains may need to be queried by a receiving email system before the final DNS query target is determined.
  • Second, the targeted SPF domain specification may cause a receiving email system 120 to capture the EHLO name and/or the IP address for the SMTP connection. These values may be captured using the SPF macro system. The %{h} macro can be used to capture the EHLO name, and the %{i} or %{p} macros can be used to the capture the IP address or the validated domain name of the IP address. In some embodiments, the domain owner system 110 may configure the targeted SPF domain specification to also cause the receiving email system 120 to capture the local part of the sender address or the complete sender address with either the %{l} and/or %{s} macros, and encode the resulting values into the targeted SPF domain specification.
  • Depending on the exact configuration of the system, one or more of the optional transformers described in the SPF macro language may be applied in the targeted SPF domain specification. Similarly, the uppercase variants %{H}, %{I}, %{P}, %{L}, or %{S} may be used instead, so that the result is URL encoded.
  • Third, the targeted SPF domain specification may be constructed in such a way that the SMTP connection attributes can be parsed unambiguously from the resulting domain, which can actually be accomplished for real world systems.
  • To demonstrate this, a format for the targeted SPF domain specification that meets these three requirements may be constructed. For example, assume that the targeted DNS SPF resolver (e.g. authorizing DNS server 130) responds to all DNS TXT queries in the zone defined by the domain ‘resolver.com’. Also assume that the email domain is ‘emaildomain.com’. Finally, assume that both the EHLO name and the IP address are captured.
  • In this case the Letters-Digits-Hyphen (LDH) rules for hostnames may be used. These rules include the restriction that fully qualified domain names (FQDN) can only contain ASCII letters, numbers, or the hyphen character. More generally domains, including those used in SPF record lookups, do not need to meet this restriction. As both the EHLO name and the email domain are required to be FQDNs, these fields may be separated by the domain owner system 110 when creating the targeted SPF domain specification with labels that contain non-LDH characters such as ‘_’. Since an IP address can only consist of digits (IPv4) or digits and the letters a-f (IPv6), the labels comprising the IP address cannot contain ‘_’ either. Thus, labels containing ‘_’ may be used as separators for these values as well.
  • Combining all of the above, one targeted SPF domain specification that meets the requirements within the context of the example is: ‘%{i}._ipaddr.%{h}._ehlo.emaildomain.com._tspf.resolver.com’. Any domain name interpolated during the SPF process from this domain spec will be rooted in ‘resolver.com’ (the rightmost domain indicated). It includes both the EHLO name and IP address in the domain name. Furthermore, the use of labels containing ‘_’ supports non-ambiguous parsing of the SMTP attributes from such a domain name.
  • Note that there are a large number of potential formats that meet these requirements, and this particular example should be considered non-limiting.
  • The email domain validation record 141 should then have an SPF rule that has an include directive that refers to a targeted SPF domain specification as described above. A simple, non-limiting example of such a record that uses the example targeted SPF domain specification described above would be ‘v=spf1 include:%{i}._ipaddr.%{h}._ehlo.emaildomain.com._tspf.resolver.com’. Again, while this record is realistic for our example, it should be considered non-limiting. Note that “v” refers to the SPF version, and the include directive indicates that the domain indicated is a valid sender for the email domain.
  • Once the email domain validation record 141 is constructed, it may be published 215 as a DNS TXT record for the email domain (e.g., at domain owner DNS server 140). This will allow it to be queried by any server that receives email that indicates this domain.
  • Example Interaction Diagram for Email Verification Rule Resolution
  • FIG. 3 is an interaction diagram and flow chart illustrating an exemplary process for resolution of an email domain validation record using DNS according to one embodiment. In one embodiment, FIG. 3 attributes the operations in process to the indicated elements. However, some or all of the steps may be performed by other elements. In addition, some embodiments may perform the operations in parallel, perform the operations in different orders, or perform different operations. Also, it is noted that in one example embodiment the steps and/or modules may be embodied as instructions, e.g., instructions 424, that may be executed by the processor 402 described with respect to FIG. 4. Note that the processes described here do not necessarily require any additional modification or configuration of the receiving email system 120. Instead, so long as the receiving email system 120 supports SPF or a similar sender authentication scheme, it does not need to be modified.
  • Initially, the receiving email system 120 receives 310 an email with a return path corresponding to a particular email domain. The receiving email system 120 may attempt to authenticate this email message (e.g., using SPF). The receiving email system 120 may first query 315 DNS for any email validation records for the email domain. These may be SPF records. The domain owner DNS server 140 may return the an email domain validation record 141 in a response 282 that the owner of the email domain has published as described with reference to FIG. 2.
  • The receiving email system 120 parses the email validation record, and generates 320 a target domain query. This process may include evaluating the include directive with the target domain SPF specification in the returned DNS record using values for the current SMTP connection (e.g., EHLO, IP address), and interpolating these values into the target domain SPF specification to construct the target domain. For example, if the record indicates a rule of ‘%{i}._ipaddr.%{h}._ehlo.emaildomain.com._tspf.resolver.com’, the receiving email system 120 may evaluate this into ““123.123.123.123._ipaddr.deliveringdomain.com._ehlo.emaildomain.com._tspf.resolver.com’ assuming that 123.123.123.123 is the IP address of the sender, emaildomain.com is the domain of the original sender, and deliveringdomain.com is the domain name indicated in the EHLO message for the sender.
  • The receiving email system 120 then queries 325 the DNS with the target domain. This query may be responded to by the authorizing DNS server 130 (which may be an authoritative server for the target domain). The authorizing DNS server 130 extracts 340 the identifying information from the query. This identifying information may include the EHLO name and IP address, and may be parsed from the target domain query. In one embodiment, the authorizing DNS server 130 may also parse the local part of the Return-Path address from target domain of the query, either as a stand-alone value or as part of an encoded complete sender address.
  • In one embodiment, the authorizing DNS server 130 also extracts the email domain from the target domain query (if it has been included in the query via a macro). If the email domain is present and, if the authorizing DNS server 130 is configured to only process requests for a limited set of domains, then the domain owner DNS server 130 can determine if the email domain is known. In this case the authorizing DNS server 130 may return a default SPF record if the email domain is not known. The returned record is likely to be a record that does not pass any IP address—an example would be “v=spf1 ˜all”.
  • The authorizing DNS server 130 uses the identifying information that is extracted from the query to identify 345 the delivering organization. The delivering organization is the owner of the delivering email system 115, which may not be part of the email domain. The authorizing DNS server 130 includes a deliverer/IP store 131 that associates the identifying information extracted from the query with delivering organizations such that network specific information associated with an email message's SMTP connection (e.g., EHLO name and/or sending server IP address) may be associated with the higher-level abstraction of a delivering organization.
  • Some examples of common delivering organizations are third party senders contracted to send email by the email domain owner, a mailing list that is relaying a message originating from the email domain to a number of receiving addresses, or a forwarding system that is designed to alias one receiver address to another. This set of examples should not be considered exhaustive, and the list should be considered non-limiting.
  • In one embodiment, access to the header information of a substantial (i.e., statistically significant) corpus of email (100s of millions of messages or more) may allow the authorizing DNS server 130 or other entity to construct the deliverer/IP store 131 by use of information found in the email headers (specifically the ‘Received’ and ‘Authentication-Results’ headers). In other embodiments, one could survey a list of delivering organizations, and combine the results into a suitable deliverer/IP store 131. In further embodiments, domain registration records, especially the information stored in the WHOIS database, can be useful for building this mapping for the deliverer/IP store 131. These example methods should be considered non-limiting, and the process described herein does not preclude the use of other methods or the combination of multiple methods for the construction of the deliverer/IP store 131.
  • In further embodiments, the inbound stream of DNS queries received by the authorizing DNS server 130 can be used as a source of EHLO names and IP addresses that require investigation. For a complete database all (EHLO Name, IP Address) combinations originating from legitimate email should map to a known delivering organization. Any inbound data that cannot be mapped to a known delivering organization may generally indicate a) missing legitimate values in the database or b) a source email that is fraudulent. This ‘miss’ can thus serve as a source of information to fill in gaps in the database or a source of threat information.
  • Once the request has been mapped to a delivering organization, in one embodiment the authorizing DNS server 130 may determine 348 if the delivering organization is a known one. If not, then a default record may be returned, such as some variation on an SPF record that fails all IP addresses. For example, ‘v=spf1 ˜all’, would be a likely choice.
  • Assuming that the delivering organization is known, then the authorizing DNS server 130 can determine 350 whether the delivering organization is authorized to deliver email for the email domain indicated in the query for the target domain. In one embodiment, the authorizing DNS server 130 allows any identified delivering organization to deliver email for any email domain. In another embodiment, the mapping of email domain to authorized delivering organization could be stored in an authorized deliverers list 132, or made available via a web API, and the authorizing DNS server 130 accesses the list or API to determine whether the delivering organization is authorized.
  • If the identified delivering organization is not found to be authorized for the email domain, then the authorizing DNS server 130 may return a default record. In general this may be a record denying delivery for all IP addresses (e.g. ‘v=spf1 ˜all’).
  • As described above, in one embodiment, the local part of the Return-Path address may have been encoded in the query of the target domain either as a standalone value, or as part of the sender address. In these embodiments, the authorizing DNS server 130 uses the local part of the email address in combination with the email domain to determine whether a delivering organization is authorized to deliver a particular message. For example, a delivering organization may be authorized to send mail on behalf of a “newsletter@acme.com” but not on behalf of a return path address with a local part indicating an email address of an employee at acme.com.
  • If the delivering organization is authorized to deliver email for the email domain, then the authorizing DNS server 130 generates 355 a target validation record (which may be an SPF record) based on the delivering organization and the email domain. To construct this record, the authorizing DNS server 130 may query a deliverer/record store 134 that includes a map of delivering organizations to target validation records.
  • For each delivering organization, there may exist some hypothetical email validation record that would allow email from servers used by that delivering organization (e.g., the delivering email system 115), and deny email originating anywhere else. This should be true for any delivering organization that has a properly configured email domain validation record (e.g., an SPF record), as the existing email domain validation record for the delivering organization may be used.
  • Even if a delivering organization does not have a properly configured email domain validation record, the authorizing DNS server 130 or administrator may be able to build such a record given sufficient knowledge of the underlying network configuration. In one embodiment, the authorizing DNS server 130 creates and stores the email domain validation records for delivering organizations and/or email domains that are not otherwise made available by the delivering organization.
  • In some embodiments, and for some configurations, the deliverer/record store 134 also associates the email domain and/or the local path as either a replacement or a supplement to the association of the delivering organization with the target validation record. As an example of when such a variation may be desirable, consider a delivering organization that subdivides its cloud of mail servers by email domain. In such circumstances it may be necessary to know the email domain, in combination with the delivering organization, to deliver the optimal target validation record.
  • In some embodiments, existing email domain validation records may be an important source of information to construct the deliverer/record store 134. For example, in the case of SPF records, the existing records for the delivering organization may be used to get a list of directives. In other embodiments, a manual survey of the delivering organizations can also be a good source of this information. In further embodiments, additional methods may also be feasible, as is the use of combinations of sources. The sources listed here should be considered non-limiting.
  • When using these or any other methods to construct the deliverer/record store 134, it may be necessary to update the data as the underlying network configuration changes with time. In some embodiments, the authorizing DNS server 130 may use polling mechanisms to update the deliverer/record store 134, while in other embodiments. A non-limiting example of such a polling mechanism would be a software component on the authorizing DNS server 130 that executes DNS queries on a regular (e.g. daily) basis to detect updates to DNS records published by known senders. Those updates could then be incorporated by the authorizing DNS server 130 into the database.
  • After generating the target validation record, the authorizing DNS server 130 transmits 360 the record back to the receiving mail system 120 as a response to the original query.
  • The receiving mail system 120 authenticates 330 the email message using the received target validation record.
  • In one embodiment, instead of instead of using the ‘include’ mechanism of SPF as described above, the system described here may be configured to use the ‘a’, ‘mx’, or ‘exists’ mechanisms that are part of SPF. If one of these mechanisms is used, the behavior of the email domain owner may be largely unchanged—the ‘a’, ‘mx’, or ‘exists’ mechanism may be simply substituted for the ‘include’ mechanism in this case.
  • Under this variation the behavior of the authorizing DNS server 130 is mostly unchanged, except for its return values. In the cases where the authorizing DNS server 130 indicates that the message is not authenticated, the authorizing DNS server 130 may return an NXDOMAIN code. And instead of returning a target validation record, the authorizing DNS server 130 may match the IP address against the target validation record. If the IP address does not match the record, then the authorizing DNS server 130 may return an NXDOMAIN. Alternately, if the IP address is found to match, then the authorizing DNS server 130 may return an A, MX, or A record that includes the IP address.
  • In one embodiment, the authorizing DNS server 130 is used as a remote SPF auditing tool. SPF resolution occurs on the receiving email system 120, and as such the results of that evaluation may not generally be available to external auditing systems unless special software is installed. If the targeted SPF domain specification has been structured to include both the EHLO name and IP address, the authorizing DNS server 130 may be invoked at least once for each (EHLO name, IP address) combination from which a message is delivered. With this information the resolver can mirror the SPF evaluation carried out by the receiving email system 120 and log the corresponding result.
  • Example Machine Architecture
  • FIG. 4 is a block diagram illustrating components of an example machine able to read instructions from a machine-readable medium and execute them in a processor (or controller). Specifically, FIG. 4 shows a diagrammatic representation of a machine in the example form of a computer system 400. The computer system 400 can be used to execute instructions 424 (e.g., program code or software) for causing the machine to perform any one or more of the methodologies (or processes) described herein. In alternative embodiments, the machine operates as a standalone device or a connected (e.g., networked) device that connects to other machines. In a networked deployment, the machine may operate in the capacity of a server machine or a client machine in a server-client network environment, or as a peer machine in a peer-to-peer (or distributed) network environment.
  • The machine may be a server computer, a client computer, a personal computer (PC), a tablet PC, a set-top box (STB), a smartphone, an internet of things (IoT) appliance, a network router, switch or bridge, or any machine capable of executing instructions 424 (sequential or otherwise) that specify actions to be taken by that machine. Further, while only a single machine is illustrated, the term “machine” shall also be taken to include any collection of machines that individually or jointly execute instructions 424 to perform any one or more of the methodologies discussed herein.
  • The example computer system 400 includes one or more processing units (generally processor 402). The processor 402 is, for example, a central processing unit (CPU), a graphics processing unit (GPU), a digital signal processor (DSP), a controller, a state machine, one or more application specific integrated circuits (ASICs), one or more radio-frequency integrated circuits (RFICs), or any combination of these. The computer system 400 also includes a main memory 404. The computer system may include a storage unit 416. The processor 402, memory 404 and the storage unit 416 communicate via a bus 408.
  • In addition, the computer system406 400 can include a static memory 406, a display driver 410 (e.g., to drive a plasma display panel (PDP), a liquid crystal display (LCD), or a projector). The computer system 400 may also include alphanumeric input device 412 (e.g., a keyboard), a cursor control device 414 (e.g., a mouse, a trackball, a joystick, a motion sensor, or other pointing instrument), a signal generation device 418 (e.g., a speaker), and a network interface device 420, which also are configured to communicate via the bus 408.
  • The storage unit 416 includes a machine-readable medium 422 on which is stored instructions 424 (e.g., software) embodying any one or more of the methodologies or functions described herein. The instructions 424 may also reside, completely or at least partially, within the main memory 404 or within the processor 402 (e.g., within a processor's cache memory) during execution thereof by the computer system 400, the main memory 404 and the processor 402 also constituting machine-readable media. The instructions 424 may be transmitted or received over a network 426 via the network interface device 420.
  • While machine-readable medium 422 is shown in an example embodiment to be a single medium, the term “machine-readable medium” should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, or associated caches and servers) able to store the instructions 424. The term “machine-readable medium” shall also be taken to include any medium that is capable of storing instructions 424 for execution by the machine and that cause the machine to perform any one or more of the methodologies disclosed herein. The term “machine-readable medium” includes, but not be limited to, data repositories in the form of solid-state memories, optical media, and magnetic media.
  • Additional Considerations
  • Using the system and processes described above, a domain owner is able to utilize the services of other third party delivering organizations and their delivering email systems in order to send emails and still have these emails be validated by receiving email systems as being authentic. Instead of updating a variety of email domain validation records, a DNS server may, in a centralized location, generate a simple set of rules depending on the identifying information received from a receiving email system for the delivering email system which sent the email. Furthermore, the receiving email system does not need to query a large number of DNS records that may be present in rules in an email domain validation record. This increases performance and simplifies the management of sending emails via third party agents, while still providing security and preventing fraudulent or suspicious messages from being received.
  • Throughout this specification, plural instances may implement components, operations, or structures described as a single instance. Although individual operations of one or more methods are illustrated and described as separate operations, one or more of the individual operations may be performed concurrently, and nothing requires that the operations be performed in the order illustrated. Structures and functionality presented as separate components in example configurations may be implemented as a combined structure or component. Similarly, structures and functionality presented as a single component may be implemented as separate components. These and other variations, modifications, additions, and improvements fall within the scope of the subject matter herein.
  • Certain embodiments are described herein as including logic or a number of components, modules, or mechanisms, for example, as illustrated in FIGS. 1-5. Modules may constitute either software modules (e.g., code embodied on a machine-readable medium or in a transmission signal) or hardware modules. A hardware module is tangible unit capable of performing certain operations and may be configured or arranged in a certain manner. In example embodiments, one or more computer systems (e.g., a standalone, client or server computer system) or one or more hardware modules of a computer system (e.g., a processor or a group of processors) may be configured by software (e.g., an application or application portion) as a hardware module that operates to perform certain operations as described herein.
  • In various embodiments, a hardware module may be implemented mechanically or electronically. For example, a hardware module may comprise dedicated circuitry or logic that is permanently configured (e.g., as a special-purpose processor, such as a field programmable gate array (FPGA) or an application-specific integrated circuit (ASIC)) to perform certain operations. A hardware module may also comprise programmable logic or circuitry (e.g., as encompassed within a general-purpose processor or other programmable processor) that is temporarily configured by software to perform certain operations. It will be appreciated that the decision to implement a hardware module mechanically, in dedicated and permanently configured circuitry, or in temporarily configured circuitry (e.g., configured by software) may be driven by cost and time considerations.
  • The various operations of example methods described herein may be performed, at least partially, by one or more processors that are temporarily configured (e.g., by software) or permanently configured to perform the relevant operations. Whether temporarily or permanently configured, such processors may constitute processor-implemented modules that operate to perform one or more operations or functions. The modules referred to herein may, in some example embodiments, comprise processor-implemented modules.
  • The one or more processors may also operate to support performance of the relevant operations in a “cloud computing” environment or as a “software as a service” (SaaS). For example, at least some of the operations may be performed by a group of computers (as examples of machines including processors), these operations being accessible via a network (e.g., the Internet) and via one or more appropriate interfaces (e.g., application program interfaces (APIs).)
  • The performance of certain of the operations may be distributed among the one or more processors, not only residing within a single machine, but deployed across a number of machines. In some example embodiments, the one or more processors or processor-implemented modules may be located in a single geographic location (e.g., within a home environment, an office environment, or a server farm). In other example embodiments, the one or more processors or processor-implemented modules may be distributed across a number of geographic locations.
  • Some portions of this specification are presented in terms of algorithms or symbolic representations of operations on data stored as bits or binary digital signals within a machine memory (e.g., a computer memory). These algorithms or symbolic representations are examples of techniques used by those of ordinary skill in the data processing arts to convey the substance of their work to others skilled in the art. As used herein, an “algorithm” is a self-consistent sequence of operations or similar processing leading to a desired result. In this context, algorithms and operations involve physical manipulation of physical quantities. Typically, but not necessarily, such quantities may take the form of electrical, magnetic, or optical signals capable of being stored, accessed, transferred, combined, compared, or otherwise manipulated by a machine. It is convenient at times, principally for reasons of common usage, to refer to such signals using words such as “data,” “content,” “bits,” “values,” “elements,” “symbols,” “characters,” “terms,” “numbers,” “numerals,” or the like. These words, however, are merely convenient labels and are to be associated with appropriate physical quantities.
  • Unless specifically stated otherwise, discussions herein using words such as “processing,” “computing,” “calculating,” “determining,” “presenting,” “displaying,” or the like may refer to actions or processes of a machine (e.g., a computer) that manipulates or transforms data represented as physical (e.g., electronic, magnetic, or optical) quantities within one or more memories (e.g., volatile memory, non-volatile memory, or a combination thereof), registers, or other machine components that receive, store, transmit, or display information.
  • As used herein any reference to “one embodiment” or “an embodiment” means that a particular element, feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment.
  • Some embodiments may be described using the expression “coupled” and “connected” along with their derivatives. For example, some embodiments may be described using the term “coupled” to indicate that two or more elements are in direct physical or electrical contact. The term “coupled,” however, may also mean that two or more elements are not in direct contact with each other, but yet still co-operate or interact with each other. The embodiments are not limited in this context.
  • As used herein, the terms “comprises,” “comprising,” “includes,” “including,” “has,” “having” or any other variation thereof, are intended to cover a non-exclusive inclusion. For example, a process, method, article, or apparatus that comprises a list of elements is not necessarily limited to only those elements but may include other elements not expressly listed or inherent to such process, method, article, or apparatus. Further, unless expressly stated to the contrary, “or” refers to an inclusive or and not to an exclusive or. For example, a condition A or B is satisfied by any one of the following: A is true (or present) and B is false (or not present), A is false (or not present) and B is true (or present), and both A and B are true (or present).
  • In addition, use of the “a” or “an” are employed to describe elements and components of the embodiments herein. This is done merely for convenience and to give a general sense of the invention. This description should be read to include one or at least one and the singular also includes the plural unless it is obvious that it is meant otherwise.
  • Upon reading this disclosure, those of skill in the art will appreciate still additional alternative structural and functional designs for a system and a process capable of validating email senders through intermediaries via EHLO name and IP address targeting. Thus, while particular embodiments and applications have been illustrated and described, it is to be understood that the disclosed embodiments are not limited to the precise construction and components disclosed herein. Various modifications, changes and variations, which will be apparent to those skilled in the art, may be made in the arrangement, operation and details of the method and apparatus disclosed herein without departing from the spirit and scope defined in the appended claims.

Claims (19)

What is claimed is:
1. A computer-implemented method, comprising:
receiving, at an authorizing Domain Name System (DNS) system, a redirected target domain DNS query from a receiving email system, the redirected target domain DNS query generated by the receiving email system based on parsing Sender Policy Framework (SPF) macro statements in a DNS TXT record published at a DNS server of an email domain owner system, the redirected target domain DNS query including identifying information of a delivering email system, the identifying information comprising at least one of an extended HELO (EHLO) name, and an (Internet Protocol) IP address of the delivering email system;
extracting the identifying information from the redirected target domain DNS query;
determining an identity of the delivering email system from a list of delivering organizations based on the extracted identifying information by accessing a database that associates identifying information with delivering organizations;
generating, in response to determining that the identified delivering email system is authorized to deliver email on behalf of the email domain owner system, a DNS record usable in accordance with SPF for indicating that the delivering email system is an authorized sender of email for the email domain owner system; and
transmitting the DNS record to the receiving email system.
2. The method of claim 1, wherein the database is updated by:
accessing header information of a number of authenticated and delivered emails, the number being greater than a threshold value;
generating a plurality of unique entries in the database, each entry in the database including at least one of an EHLO name and an IP address, wherein each entry also includes a delivering organization name parsed from the header information of the emails.
3. The method of claim 1, wherein the database is updated by:
accessing domain registration information of a number of email domains, the number being greater than a threshold value;
generating a plurality of unique entries in the database, each entry in the database including a domain name, IP address, and delivering organization name parsed from domain registration information of the email domains.
4. The method of claim 1, wherein determining that the identified delivering email system is authorized to deliver email on behalf of the email domain owner system further comprises:
accessing an authorization database that associates one or more authorized delivering organizations with email domains of email domain owner systems to determine whether the delivering email system is authorized to send email on behalf of the email domain owner system.
5. The method of claim 4, wherein the identifying information further includes a local part of the Return-Path address for the email, and wherein the authorization database further associates, for each email domain, one or more local parts of the Return-Path address on behalf of which the one or more delivering organizations are authorized to send email, the method further comprising:
accessing the authorization database to determine whether the delivering email system is authorized to send email on behalf of the identified local part of the Return-Path address for the email of the email domain.
6. The method of claim 1, wherein the generating the DNS record further comprises:
accessing a regularly updated records database that stores one or more DNS records for authorized delivering email systems, each of the one or more DNS records indicating that a delivering email system is an authorized sender for the email domain owner system, the regularly updated records database updated using automatic polling.
7. A non-transitory computer readable storage medium configured to store computer-readable instructions, that when executed by a processor, cause the processor to:
receive, at an authorizing Domain Name System (DNS) system, a redirected target domain DNS query from a receiving email system, the redirected target domain DNS query generated by the receiving email system based on parsing Sender Policy Framework (SPF) macro statements in a DNS TXT record published at a DNS server of an email domain owner system, the redirected target domain DNS query including identifying information of a delivering email system, the identifying information comprising at least one of an extended HELO (EHLO) name, and an (Internet Protocol) IP address of the delivering email system;
extract the identifying information from the redirected target domain DNS query;
determine an identity of the delivering email system from a list of delivering organizations based on the extracted identifying information by accessing a database that associates identifying information with delivering organizations;
generate, in response to determining that the identified delivering email system is authorized to deliver email on behalf of the email domain owner system, a DNS record that is usable in accordance with SPF for indicating that the delivering email system is an authorized sender of email for the email domain owner system; and
transmit the DNS record to the receiving email system.
8. The non-transitory computer readable storage medium of claim 7, wherein the non-transitory computer readable storage medium is configured to store further computer-readable instructions for the update of the database, that when executed by the processor, causes the processor to:
access header information of a number of authenticated and delivered emails, the number being greater than a threshold value;
generate a plurality of unique entries in the database, each entry in the database including at least one of an EHLO name and an IP address, wherein each entry also includes a delivering organization name parsed from the header information of the emails.
9. The non-transitory computer readable storage medium of claim 7, wherein the non-transitory computer readable storage medium is configured to store further computer-readable instructions for the update of the database, that when executed by the processor, causes the processor to:
access domain registration information of a number of email domains, the number being greater than a threshold value;
generate a plurality of unique entries in the database, each entry in the database including a domain name, IP address, and delivering organization name parsed from domain registration information of the email domains.
10. The non-transitory computer readable storage medium of claim 9, wherein the non-transitory computer readable storage medium is configured to store further computer-readable instructions for the determination that the identified delivering email system is authorized to deliver email on behalf of the email domain owner system, that when executed by the processor, causes the processor to:
access an authorization database that associates one or more authorized delivering organizations with email domains of email domain owner systems to determine whether the delivering email system is authorized to send email on behalf of the email domain owner system.
11. The non-transitory computer readable storage medium of claim 10, wherein the identifying information further includes a local part of the Return-Path address for the email, and wherein the authorization database further associates, for each email domain, one or more local parts of the Return-Path address on behalf of which the one or more delivering organizations are authorized to send email, and wherein the non-transitory computer readable storage medium is configured to store further computer-readable instructions, that when executed by the processor, causes the processor to:
access the authorization database to determine whether the delivering email system is authorized to send email on behalf of the identified local part of the Return-Path address for the email of the email domain.
12. The non-transitory computer readable storage medium of claim 7, wherein the non-transitory computer readable storage medium is configured to store further computer-readable instructions for the generation of the DNS record, that when executed by the processor, causes the processor to:
access a regularly updated records database that stores one or more DNS records for authorized delivering email systems, each of the one or more DNS records indicating that a delivering email system is an authorized sender for the email domain owner system, the regularly updated records database updated using automatic polling.
13. An authorizing Domain Name System (DNS) system, comprising:
an authorization evaluator that:
receives a redirected target domain DNS query from a receiving email system, the redirected target domain DNS query generated by the receiving email system based on parsing Sender Policy Framework (SPF) macro statements in a DNS TXT record published at a DNS server of an email domain owner system, the redirected target domain DNS query including identifying information of a delivering email system, the identifying information comprising at least one of an extended HELO (EHLO) name, and an (Internet Protocol) IP address of the delivering email system;
extracts the identifying information from the redirected target domain DNS query;
determines an identity of the delivering email system from a list of delivering organizations based on the extracted identifying information by accessing a database that associates identifying information with delivering organizations; and
a target record constructor that:
generates, in response to a determination that the identified delivering email system is authorized to deliver email on behalf of the email domain owner system, a DNS record that is usable in accordance with SPF for indicating that the delivering email system is an authorized sender of email for the email domain owner system; and
transmits the DNS record to the receiving email system.
14. The system of claim 13, wherein the authorizing Domain Name System (DNS) system updates the database by:
accessing header information of a number of authenticated and delivered emails, the number being greater than a threshold value;
generating a plurality of unique entries in the database, each entry in the database including at least one of an EHLO name and an IP address, wherein each entry also includes a delivering organization name parsed from the header information of the emails.
15. The system of claim 13, wherein the authorizing Domain Name System (DNS) system updates the database by:
accessing domain registration information of a number of email domains, the number being greater than a threshold value;
generating a plurality of unique entries in the database, each entry in the database including a domain name, IP address, and delivering organization name parsed from domain registration information of the email domains.
16. The system of claim 13, wherein the target record constructor further:
accesses an authorization database that associates one or more authorized delivering organizations with email domains of email domain owner systems to determine whether the delivering email system is authorized to send email on behalf of the email domain owner system.
17. The system of claim 16, wherein the identifying information further includes a local part of the Return-Path address for the email, and wherein the authorization database further associates, for each email domain, one or more local parts of the Return-Path address on behalf of which the one or more delivering organizations are authorized to send email, and wherein the target record constructor further:
accesses the authorization database to determine whether the delivering email system is authorized to send email on behalf of the identified local part of the Return-Path address for the email of the email domain.
18. The system of claim 13, wherein the target record constructor further:
accesses a regularly updated records database that stores one or more DNS records for authorized delivering email systems, each of the one or more DNS records indicating that a delivering email system is an authorized sender for the email domain owner system, the regularly updated records database updated using automatic polling.
19. The system of claim 13, wherein the DNS record includes at least one of an IP address or a non-existent domain indicator.
US16/012,616 2015-02-14 2018-06-19 Centralized validation of email senders via EHLO name and IP address targeting Active US10122765B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US16/012,616 US10122765B1 (en) 2015-02-14 2018-06-19 Centralized validation of email senders via EHLO name and IP address targeting

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US201562116409P 2015-02-14 2015-02-14
PCT/US2016/015796 WO2016130339A1 (en) 2015-02-14 2016-01-29 Centralized validation of email senders via ehlo name and ip address targeting
US15/175,031 US9762618B2 (en) 2015-02-14 2016-06-06 Centralized validation of email senders via EHLO name and IP address targeting
US15/663,771 US10257231B2 (en) 2015-02-14 2017-07-30 Centralized validation of email senders via EHLO name and IP address targeting
US16/012,616 US10122765B1 (en) 2015-02-14 2018-06-19 Centralized validation of email senders via EHLO name and IP address targeting

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US15/663,771 Continuation US10257231B2 (en) 2015-02-14 2017-07-30 Centralized validation of email senders via EHLO name and IP address targeting

Publications (2)

Publication Number Publication Date
US20180302446A1 true US20180302446A1 (en) 2018-10-18
US10122765B1 US10122765B1 (en) 2018-11-06

Family

ID=56615490

Family Applications (10)

Application Number Title Priority Date Filing Date
US15/175,031 Active US9762618B2 (en) 2015-02-14 2016-06-06 Centralized validation of email senders via EHLO name and IP address targeting
US15/663,771 Active US10257231B2 (en) 2015-02-14 2017-07-30 Centralized validation of email senders via EHLO name and IP address targeting
US16/012,616 Active US10122765B1 (en) 2015-02-14 2018-06-19 Centralized validation of email senders via EHLO name and IP address targeting
US16/296,121 Active US10897485B2 (en) 2015-02-14 2019-03-07 Centralized validation of email senders via EHLO name and IP address targeting
US17/128,008 Active US11057437B2 (en) 2015-02-14 2020-12-19 Centralized validation of email senders via EHLO name and IP address targeting
US17/360,322 Active 2036-03-15 US11582263B2 (en) 2015-02-14 2021-06-28 Centralized validation of email senders via EHLO name and IP address targeting
US17/500,292 Active US11368494B2 (en) 2015-02-14 2021-10-13 Authentication of email senders via authorizing DNS server
US17/500,306 Active US11431756B2 (en) 2015-02-14 2021-10-13 Authentication of email senders via authorizing DNS server
US18/107,945 Active US11811831B2 (en) 2015-02-14 2023-02-09 Delegated domain name system responder for emails
US18/380,306 Active US12015649B2 (en) 2015-02-14 2023-10-16 Hosted email authentication

Family Applications Before (2)

Application Number Title Priority Date Filing Date
US15/175,031 Active US9762618B2 (en) 2015-02-14 2016-06-06 Centralized validation of email senders via EHLO name and IP address targeting
US15/663,771 Active US10257231B2 (en) 2015-02-14 2017-07-30 Centralized validation of email senders via EHLO name and IP address targeting

Family Applications After (7)

Application Number Title Priority Date Filing Date
US16/296,121 Active US10897485B2 (en) 2015-02-14 2019-03-07 Centralized validation of email senders via EHLO name and IP address targeting
US17/128,008 Active US11057437B2 (en) 2015-02-14 2020-12-19 Centralized validation of email senders via EHLO name and IP address targeting
US17/360,322 Active 2036-03-15 US11582263B2 (en) 2015-02-14 2021-06-28 Centralized validation of email senders via EHLO name and IP address targeting
US17/500,292 Active US11368494B2 (en) 2015-02-14 2021-10-13 Authentication of email senders via authorizing DNS server
US17/500,306 Active US11431756B2 (en) 2015-02-14 2021-10-13 Authentication of email senders via authorizing DNS server
US18/107,945 Active US11811831B2 (en) 2015-02-14 2023-02-09 Delegated domain name system responder for emails
US18/380,306 Active US12015649B2 (en) 2015-02-14 2023-10-16 Hosted email authentication

Country Status (9)

Country Link
US (10) US9762618B2 (en)
EP (3) EP3256954B1 (en)
JP (1) JP6514365B2 (en)
CN (1) CN107533535B (en)
AU (1) AU2016218339B2 (en)
BR (1) BR112017017424A2 (en)
CA (1) CA2976462A1 (en)
MA (1) MA41502A (en)
WO (1) WO2016130339A1 (en)

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11038897B1 (en) 2020-01-22 2021-06-15 Valimail Inc. Interaction control list determination and device adjacency and relative topography
US11171939B1 (en) 2020-12-01 2021-11-09 Valimail Inc. Automated device discovery and workflow enrichment
EP4009583A1 (en) * 2020-12-01 2022-06-08 Valimail Inc. Automated device discovery and workflow enrichment
US11489811B1 (en) * 2021-08-31 2022-11-01 Check Point Software Technologies Ltd. On-device protected DNS
US11695745B2 (en) 2020-12-01 2023-07-04 Valimail Inc. Automated DMARC device discovery and workflow
US11743257B2 (en) 2020-01-22 2023-08-29 Valimail Inc. Automated authentication and authorization in a communication system
US11991139B2 (en) 2022-09-16 2024-05-21 Valimail Inc. Automated email protocol analyzer in a privacy-safe environment
US12069095B2 (en) 2020-01-22 2024-08-20 Valimail Inc. Automated authentication and authorization in a communication system

Families Citing this family (40)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10270755B2 (en) 2011-10-03 2019-04-23 Verisign, Inc. Authenticated name resolution
US11200581B2 (en) 2018-05-10 2021-12-14 Hubspot, Inc. Multi-client service system platform
WO2018209254A1 (en) 2017-05-11 2018-11-15 Hubspot, Inc. Methods and systems for automated generation of personalized messages
US10867003B2 (en) 2014-09-15 2020-12-15 Hubspot, Inc. Method of enhancing customer relationship management content and workflow
US10404634B2 (en) * 2015-07-01 2019-09-03 Sean P. Fenlon Method for publishing and sharing content on the internet
US10447633B2 (en) * 2015-09-25 2019-10-15 Amit Gupta Method and system for optimizing and preventing failure of sender policy framework (SPF) lookups
US11082353B2 (en) * 2015-09-28 2021-08-03 Arris Enterprises Llc Domain name system response spoofing at customer premise equipment device
US10791085B2 (en) 2015-11-12 2020-09-29 Verisign, Inc. Techniques for directing a domain name service (DNS) resolution process
US10999240B1 (en) 2016-08-31 2021-05-04 Verisign, Inc. Client controlled domain name service (DNS) resolution
WO2018089619A1 (en) 2016-11-09 2018-05-17 HubSpot Inc. Methods and systems for a content development and management platform
US10904211B2 (en) 2017-01-21 2021-01-26 Verisign, Inc. Systems, devices, and methods for generating a domain name using a user interface
WO2018140975A1 (en) 2017-01-30 2018-08-02 HubSpot Inc. Platform for electronic message processing
US10587561B2 (en) * 2017-02-09 2020-03-10 Amit Gupta Method and system for optimizing and preventing failure of Sender Policy Framework (SPF) lookups by dynamically generating and returning flattened SPF records
US20180262457A1 (en) * 2017-03-09 2018-09-13 Microsoft Technology Licensing, Llc Self-debugging of electronic message bugs
US10951600B2 (en) * 2017-05-08 2021-03-16 Microsoft Technology Licensing, Llc Domain authentication
US10791086B2 (en) * 2017-11-14 2020-09-29 Cisco Technology, Inc. Transparent DNS subtree redirection inclusive of subtree owner
US11349868B2 (en) * 2018-01-18 2022-05-31 Forcepoint, LLC Detection of spoofed internally-addressed email using trusted third party's SPF records
JP6731437B2 (en) * 2018-03-20 2020-07-29 デジタルア−ツ株式会社 Information processing apparatus, information processing method, program, and recording medium
US11265332B1 (en) * 2018-05-17 2022-03-01 Securly, Inc. Managed network content monitoring and filtering system and method
EP3652902A4 (en) * 2018-05-25 2021-03-31 Binarytree.Com Inc. Message redirection protocol
US11025580B2 (en) * 2018-07-20 2021-06-01 Arnexa, Inc. Method, apparatus and product for delivery of electronic messages to electronically un-addressable entities
US11025589B1 (en) * 2018-08-31 2021-06-01 Cisco Technology, Inc Location-independent data-object name mapping
EP3854059A4 (en) * 2018-09-17 2022-06-15 Valimail Inc. Entity-separated email domain authentication for known and open sign-up domains
US11329986B2 (en) * 2018-12-05 2022-05-10 Digital Minion LLC System for centralized certification of electronic communications
US11012414B2 (en) * 2019-04-30 2021-05-18 Centripetal Networks, Inc. Methods and systems for prevention of attacks associated with the domain name system
US11012417B2 (en) 2019-04-30 2021-05-18 Centripetal Networks, Inc. Methods and systems for efficient packet filtering
US11063986B2 (en) * 2019-08-29 2021-07-13 Fraudmarc Inc. Low-latency, outbound message monitoring, control, and authentication
US11522859B2 (en) 2019-09-25 2022-12-06 Shopify Inc. Systems and methods for facilitating authentication of emails sent by 3rd parties
EP4035334B1 (en) 2019-09-25 2024-10-23 Valimail Inc. Centralized session key issuance and rotation
US11522862B2 (en) * 2019-09-25 2022-12-06 Shopify Inc. Systems and methods for a trusted entity to facilitate authentication of emails sent by 3rd parties
US11363060B2 (en) 2019-10-24 2022-06-14 Microsoft Technology Licensing, Llc Email security in a multi-tenant email service
WO2021087494A1 (en) 2019-11-03 2021-05-06 Valimail Inc. Centralized secure distribution of messages and device updates
US11388201B2 (en) * 2019-11-20 2022-07-12 Proofpoint, Inc. Systems and methods for dynamic DMARC enforcement
US11775494B2 (en) 2020-05-12 2023-10-03 Hubspot, Inc. Multi-service business platform system having entity resolution systems and methods
JP7453886B2 (en) * 2020-09-15 2024-03-21 Kddi株式会社 Detection device, detection method and detection program
US11277375B1 (en) * 2021-01-04 2022-03-15 Saudi Arabian Oil Company Sender policy framework (SPF) configuration validator and security examinator
US20230121553A1 (en) * 2021-10-14 2023-04-20 Fraudmarc Inc. Spf layering for performant message authorization assertions
US11818094B1 (en) * 2022-08-29 2023-11-14 Zixcorp Systems, Inc. Systems and methods for synchronizing hostnames and IP addresses in email systems
WO2024059209A1 (en) 2022-09-16 2024-03-21 Valimail Inc. Automated email protocol analyzer in a privacy-safe environment
CN115808612B (en) * 2023-01-30 2023-06-02 成都爱旗科技有限公司 Chip physical IP test system, method and electronic equipment

Family Cites Families (79)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7418504B2 (en) * 1998-10-30 2008-08-26 Virnetx, Inc. Agile network protocol for secure communications using secure domain names
US7188138B1 (en) * 1999-03-22 2007-03-06 Eric Schneider Method, product, and apparatus for resource identifier registration and aftermarket services
US7486958B2 (en) * 2001-09-05 2009-02-03 Networks In Motion, Inc. System and method for maintaining an online point-of-interest directory
US8868467B2 (en) * 2002-10-23 2014-10-21 Oleg Serebrennikov Method for performing transactional communication using a universal transaction account identifier assigned to a customer
US7072944B2 (en) * 2002-10-07 2006-07-04 Ebay Inc. Method and apparatus for authenticating electronic mail
US8595495B2 (en) * 2003-01-12 2013-11-26 Yaron Mayer System and method for secure communications
US20050021644A1 (en) * 2003-05-28 2005-01-27 Glenn Hancock Systems and methods for validating electronic communications
US6986049B2 (en) * 2003-08-26 2006-01-10 Yahoo! Inc. Method and system for authenticating a message sender using domain keys
US7313700B2 (en) * 2003-08-26 2007-12-25 Yahoo! Inc. Method and system for authenticating a message sender using domain keys
US7849142B2 (en) 2004-05-29 2010-12-07 Ironport Systems, Inc. Managing connections, messages, and directory harvest attacks at a server
US7437558B2 (en) * 2004-06-01 2008-10-14 Cisco Technology, Inc. Method and system for verifying identification of an electronic mail message
US20060004896A1 (en) 2004-06-16 2006-01-05 International Business Machines Corporation Managing unwanted/unsolicited e-mail protection using sender identity
US8738708B2 (en) * 2004-12-21 2014-05-27 Mcafee, Inc. Bounce management in a trusted communication network
US7487217B2 (en) * 2005-02-04 2009-02-03 Microsoft Corporation Network domain reputation-based spam filtering
JP5118020B2 (en) * 2005-05-05 2013-01-16 シスコ アイアンポート システムズ エルエルシー Identifying threats in electronic messages
US7917943B1 (en) * 2006-12-01 2011-03-29 Goodmail Systems, Inc. E-mail Stamping with accredited entity name
US7904520B2 (en) * 2005-06-09 2011-03-08 Trueffect, Inc. First party advertisement serving
US7987251B2 (en) * 2005-09-16 2011-07-26 Microsoft Corporation Validation of domain name control
US8078681B2 (en) * 2005-09-29 2011-12-13 Teamon Systems, Inc. System and method for provisioning an email account using mail exchange records
US8117267B2 (en) * 2005-09-29 2012-02-14 Teamon Systems, Inc. System and method for provisioning an email account using mail exchange and address records
US7467230B2 (en) * 2006-02-28 2008-12-16 Microsoft Corporation Global names zone
US8713188B2 (en) * 2007-12-13 2014-04-29 Opendns, Inc. Per-request control of DNS behavior
US20080034212A1 (en) 2006-08-07 2008-02-07 Emanuele Altieri Method and system for authenticating digital content
US8533822B2 (en) * 2006-08-23 2013-09-10 Threatstop, Inc. Method and system for propagating network policy
US8538028B2 (en) * 2006-11-20 2013-09-17 Toposis Corporation System and method for secure electronic communication services
US20080172468A1 (en) * 2007-01-15 2008-07-17 John Almeida Virtual email method for preventing delivery of unsolicited and undesired electronic messages
WO2008097869A1 (en) * 2007-02-02 2008-08-14 Iconix, Inc. Authenticating and confidence marking e-mail messages
US20080201487A1 (en) * 2007-02-16 2008-08-21 Microsoft Corporation Open dynamic domain name system
CN100502367C (en) * 2007-04-04 2009-06-17 华为技术有限公司 Method and device for saving domain name system record
US20080276318A1 (en) * 2007-05-02 2008-11-06 Brian Leung Spam detection system based on the method of delayed-verification on the purported responsible address of a message
US8126971B2 (en) * 2007-05-07 2012-02-28 Gary Stephen Shuster E-mail authentication
US10284597B2 (en) * 2007-05-07 2019-05-07 Gary Stephen Shuster E-mail authentication
WO2009047783A2 (en) * 2007-06-07 2009-04-16 Bhavin Turakhia Method and system for providing a predetermined service to a domain registrant by a dns manager
US8073912B2 (en) * 2007-07-13 2011-12-06 Michael Gregor Kaplan Sender authentication for difficult to classify email
US20090043855A1 (en) * 2007-08-08 2009-02-12 Blake Bookstaff System for providing information to originator of misdirected email
CN101217555A (en) * 2008-01-10 2008-07-09 厦门三五互联科技股份有限公司 An intelligent anti-waster and anti-virus gateway and the corresponding filtering method
US20100011420A1 (en) * 2008-07-02 2010-01-14 Barracuda Networks Inc. Operating a service on a network as a domain name system server
US7996475B2 (en) * 2008-07-03 2011-08-09 Barracuda Networks Inc Facilitating transmission of email by checking email parameters with a database of well behaved senders
US8219644B2 (en) * 2008-07-03 2012-07-10 Barracuda Networks, Inc. Requesting a service or transmitting content as a domain name system resolver
US8301743B2 (en) 2008-07-24 2012-10-30 Go Daddy Operating Company, LLC Enhanced domain name generation and registration
US8850180B2 (en) * 2008-08-29 2014-09-30 Empire Technology Development, Llc Secure data communication system
US8285798B2 (en) * 2009-04-15 2012-10-09 Ecert, Inc. System and method for the management of message policy
US8380870B2 (en) * 2009-08-05 2013-02-19 Verisign, Inc. Method and system for filtering of network traffic
EP2326057A1 (en) 2009-11-20 2011-05-25 British Telecommunications public limited company Detecting malicious behaviour on a network
US9634993B2 (en) 2010-04-01 2017-04-25 Cloudflare, Inc. Internet-based proxy service to modify internet responses
US8719900B2 (en) 2010-05-18 2014-05-06 Amazon Technologies, Inc. Validating updates to domain name system records
US8707420B2 (en) * 2010-05-21 2014-04-22 Microsoft Corporation Trusted e-mail communication in a multi-tenant environment
US9083669B2 (en) * 2010-09-10 2015-07-14 Blackberry Limited System and method for providing plurality of prioritized email domain names
US20120124369A1 (en) * 2010-11-09 2012-05-17 Jose Castejon Amenedo Secure publishing of public-key certificates
US20120215892A1 (en) * 2011-02-22 2012-08-23 Kelly Wanser System and method to customize dns replies based on connection identity
US9015469B2 (en) * 2011-07-28 2015-04-21 Cloudflare, Inc. Supporting secure sessions in a cloud-based proxy service
GB201115794D0 (en) * 2011-09-13 2011-10-26 Red Morning Ltd Handling Emails
CN102664817A (en) * 2012-02-17 2012-09-12 上海电机学院 Method and system for filtering spam
US9992155B2 (en) * 2012-03-29 2018-06-05 Hitachi Vantara Corporation DNS alias synchronization in replication topology
US8959337B2 (en) * 2012-06-25 2015-02-17 International Business Machines Corporation Digital certificate issuer-correlated digital signature verification
US20140019558A1 (en) * 2012-07-12 2014-01-16 Thinmail System and method of short domain names used for remailing to apply computations to email en route and enable private sharing of files stored in the cloud
JP6053421B2 (en) * 2012-09-21 2016-12-27 Kddi株式会社 Spam mail detection device, method and program
US20140379420A1 (en) * 2013-03-15 2014-12-25 Rocket Science LLC Methods and Systems for Finding Connections Among Subscribers to an Email Campaign
EP3000054A4 (en) * 2013-05-20 2017-04-05 Citrix Systems Inc. Methods and systems for validating multiple methods of input using a unified rule set
US9521138B2 (en) * 2013-06-14 2016-12-13 Go Daddy Operating Company, LLC System for domain control validation
US9191403B2 (en) 2014-01-07 2015-11-17 Fair Isaac Corporation Cyber security adaptive analytics threat monitoring system and method
US9300623B1 (en) * 2014-02-18 2016-03-29 Sprint Communications Company L.P. Domain name system cache integrity check
US10069787B2 (en) * 2014-04-01 2018-09-04 Cloudflare, Inc. Domain name system CNAME record management
US9009353B1 (en) 2014-04-11 2015-04-14 Cable Television Laboratories, Inc. Split network address translation
US10397407B1 (en) * 2014-04-24 2019-08-27 8X8, Inc. Apparatus and method for user configuration and reporting of virtual services
US10171318B2 (en) * 2014-10-21 2019-01-01 RiskIQ, Inc. System and method of identifying internet-facing assets
WO2016140037A1 (en) * 2015-03-05 2016-09-09 日本電信電話株式会社 Device for collecting communication destination correspondence relation, method for collecting communication destination correspondence relation, and program for collecting communication destination correspondence relation
US9641516B2 (en) * 2015-07-01 2017-05-02 International Business Machines Corporation Using resource records for digital certificate validation
US10009312B2 (en) * 2015-08-11 2018-06-26 Go Daddy Operating Company, LLC Delegating DNS records to additional providers
US10135790B2 (en) * 2015-08-25 2018-11-20 Anchorfree Inc. Secure communications with internet-enabled devices
US10447633B2 (en) * 2015-09-25 2019-10-15 Amit Gupta Method and system for optimizing and preventing failure of sender policy framework (SPF) lookups
US10673878B2 (en) * 2016-05-19 2020-06-02 International Business Machines Corporation Computer security apparatus
US10873596B1 (en) * 2016-07-31 2020-12-22 Swimlane, Inc. Cybersecurity alert, assessment, and remediation engine
US10587561B2 (en) * 2017-02-09 2020-03-10 Amit Gupta Method and system for optimizing and preventing failure of Sender Policy Framework (SPF) lookups by dynamically generating and returning flattened SPF records
US11979390B2 (en) * 2017-09-20 2024-05-07 Swoop Ip Holdings Llc Email-based authentication for account login, account creation and security for passwordless transactions
US11349868B2 (en) * 2018-01-18 2022-05-31 Forcepoint, LLC Detection of spoofed internally-addressed email using trusted third party's SPF records
AU2019326067A1 (en) * 2018-08-21 2021-04-01 Viruthagiri Thirumavalavan Domain-based isolated mailboxes
US12113768B2 (en) * 2018-10-31 2024-10-08 Hewlett Packard Enterprise Development Lp Using intent to access in discovery protocols in a network for analytics
US11343275B2 (en) * 2019-09-17 2022-05-24 Fortinet, Inc. Detecting potential domain name system (DNS) hijacking by identifying anomalous changes to DNS records

Cited By (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US11038897B1 (en) 2020-01-22 2021-06-15 Valimail Inc. Interaction control list determination and device adjacency and relative topography
WO2021150799A1 (en) * 2020-01-22 2021-07-29 Valimail Inc. Interaction control list determination and device adjacency and relative topography
US11743257B2 (en) 2020-01-22 2023-08-29 Valimail Inc. Automated authentication and authorization in a communication system
EP4094418A4 (en) * 2020-01-22 2024-03-20 Valimail Inc. Interaction control list determination and device adjacency and relative topography
US12047384B2 (en) 2020-01-22 2024-07-23 Valimail Inc. Hosted policy authorization
US12069095B2 (en) 2020-01-22 2024-08-20 Valimail Inc. Automated authentication and authorization in a communication system
US11171939B1 (en) 2020-12-01 2021-11-09 Valimail Inc. Automated device discovery and workflow enrichment
EP4009583A1 (en) * 2020-12-01 2022-06-08 Valimail Inc. Automated device discovery and workflow enrichment
US11695745B2 (en) 2020-12-01 2023-07-04 Valimail Inc. Automated DMARC device discovery and workflow
US11489811B1 (en) * 2021-08-31 2022-11-01 Check Point Software Technologies Ltd. On-device protected DNS
US11991139B2 (en) 2022-09-16 2024-05-21 Valimail Inc. Automated email protocol analyzer in a privacy-safe environment

Also Published As

Publication number Publication date
US10897485B2 (en) 2021-01-19
CN107533535A (en) 2018-01-02
EP3256954A4 (en) 2018-10-10
EP3764623B1 (en) 2023-06-28
US20210152606A1 (en) 2021-05-20
US20160315969A1 (en) 2016-10-27
US9762618B2 (en) 2017-09-12
US11368494B2 (en) 2022-06-21
EP3764623A1 (en) 2021-01-13
JP6514365B2 (en) 2019-05-15
US20220038504A1 (en) 2022-02-03
US10257231B2 (en) 2019-04-09
US20230224334A1 (en) 2023-07-13
US11811831B2 (en) 2023-11-07
US20200076855A1 (en) 2020-03-05
AU2016218339B2 (en) 2021-02-04
US20170339193A1 (en) 2017-11-23
US11057437B2 (en) 2021-07-06
BR112017017424A2 (en) 2018-04-03
US11582263B2 (en) 2023-02-14
AU2016218339A1 (en) 2017-09-07
EP3256954A1 (en) 2017-12-20
US20210329034A1 (en) 2021-10-21
EP3979087A1 (en) 2022-04-06
CA2976462A1 (en) 2016-08-18
MA41502A (en) 2017-12-19
WO2016130339A1 (en) 2016-08-18
US20220070224A1 (en) 2022-03-03
US11431756B2 (en) 2022-08-30
CN107533535B (en) 2021-06-15
JP2018508169A (en) 2018-03-22
US12015649B2 (en) 2024-06-18
EP3256954B1 (en) 2021-12-01
US10122765B1 (en) 2018-11-06
US20240089295A1 (en) 2024-03-14

Similar Documents

Publication Publication Date Title
US11368494B2 (en) Authentication of email senders via authorizing DNS server
US20220353242A1 (en) Entity-separated email domain authentication for known and open sign-up domains
US11329997B2 (en) Signed message header storing sender account authentication method
US7516184B2 (en) Method and system for a method for evaluating a message based in part on a registrar reputation
US11265397B2 (en) Systems and methods for providing secure access to shared registration systems
CN104994008A (en) E-mail anti-phishing system and method
Szalachowski et al. Short paper: on deployment of DNS-based security enhancements
Wesselius et al. Email Authentication

Legal Events

Date Code Title Description
FEPP Fee payment procedure

Free format text: ENTITY STATUS SET TO UNDISCOUNTED (ORIGINAL EVENT CODE: BIG.); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY

FEPP Fee payment procedure

Free format text: ENTITY STATUS SET TO SMALL (ORIGINAL EVENT CODE: SMAL); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY

AS Assignment

Owner name: VALIMAIL INC., CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:GOLDSTEIN, PETER MARTIN;REEL/FRAME:047185/0359

Effective date: 20160129

STCF Information on status: patent grant

Free format text: PATENTED CASE

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YR, SMALL ENTITY (ORIGINAL EVENT CODE: M2551); ENTITY STATUS OF PATENT OWNER: SMALL ENTITY

Year of fee payment: 4