README.md in truemail-0.1.4 vs README.md in truemail-0.1.5

- old
+ new

@@ -62,12 +62,14 @@ config.connection_timeout = 1 # Optional parameter. A SMTP server response timeout is equal to 2 ms by default. config.response_timeout = 1 - # Optional parameter. Total of timeout retry. It is equal to 1 by default. - config.retry_count = 2 + # Optional parameter. Total of connection attempts. It is equal to 2 by default. + # This parameter uses in mx lookup timeout error and smtp request (for cases when + # there is one mx server). + config.connection_attempts = 3 # Optional parameter. You can predefine which type of validation will be used for domains. # Available validation types: :regex, :mx, :smtp # This configuration will be used over current or default validation type parameter # All of validations for 'somedomain.com' will be processed with mx validation only @@ -89,11 +91,11 @@ => #<Truemail::Configuration:0x000055590cb17b40 @connection_timeout=1, @email_pattern=/regex_pattern/, @response_timeout=1, - @retry_count=2, + @connection_attempts=3, @validation_type_by_domain={}, @verifier_domain="somedomain.com", @verifier_email="verifier@example.com" @smtp_safe_check=true> ``` @@ -103,19 +105,19 @@ ```ruby Truemail.configuration.connection_timeout = 3 => 3 Truemail.configuration.response_timeout = 4 => 4 -Truemail.configuration.retry_count = 1 +Truemail.configuration.connection_attempts = 1 => 1 Truemail.configuration => #<Truemail::Configuration:0x000055590cb17b40 @connection_timeout=3, @email_pattern=/regex_pattern/, @response_timeout=4, - @retry_count=1, + @connection_attempts=1, @validation_type_by_domain={}, @verifier_domain="somedomain.com", @verifier_email="verifier@example.com", @smtp_safe_check=true> ``` @@ -185,12 +187,18 @@ @validation_type=:regex> ``` #### MX validation -Validation by MX records is the second validation level. It uses Regex validation before running itself. When regex validation has completed successfully then runs itself. Truemail MX validation performs strictly following the [RFC 5321](https://tools.ietf.org/html/rfc5321#section-5) standard. +Validation by MX records is the second validation level. It uses Regex validation before running itself. When regex validation has completed successfully then runs itself. +```code +[Regex validation] -> [MX validation] +``` + +Truemail MX validation performs strictly following the [RFC 5321](https://tools.ietf.org/html/rfc5321#section-5) standard. + Example of usage: ```ruby require 'truemail' @@ -204,11 +212,11 @@ @result= #<struct Truemail::Validator::Result success=true, email="email@example.com", domain="example.com", - mail_servers=["mx1.example.com", "mx2.example.com"], + mail_servers=["127.0.1.1", "127.0.1.2"], errors={}, smtp_debug=nil>, @validation_type=:mx> ``` @@ -218,10 +226,12 @@ ```code [Regex validation] -> [MX validation] -> [SMTP validation] ``` +If total count of MX servers is equal to one, ```Truemail::Smtp``` validator will use value from ```Truemail.configuration.connection_attempts``` as connection attempts. By default it's equal 2. + By default, you don't need pass with-parameter to use it. Example of usage is specified below: With ```smtp_safe_check = false``` ```ruby @@ -238,11 +248,11 @@ @result= #<struct Truemail::Validator::Result success=true, email="email@example.com", domain="example.com", - mail_servers=["mx1.example.com", "mx2.example.com"], + mail_servers=["127.0.1.1", "127.0.1.2"], errors={}, smtp_debug=nil>, @validation_type=:smtp> # SMTP validation failed @@ -250,33 +260,35 @@ @result= #<struct Truemail::Validator::Result success=false, email="email@example.com", domain="example.com", - mail_servers=["mx1.example.com", "mx2.example.com", "mx3.example.com"], + mail_servers=["127.0.1.1", "127.0.1.2"], errors={:smtp=>"smtp error"}, smtp_debug= [#<Truemail::Validate::Smtp::Request:0x0000000002d49b10 @configuration= #<Truemail::Configuration:0x0000000002d49930 @connection_timeout=2, @email_pattern=/regex_pattern/, @response_timeout=2, + @connection_attempts=2, @smtp_safe_check=false, @validation_type_by_domain={}, @verifier_domain="example.com", @verifier_email="verifier@example.com">, @email="email@example.com", - @host="mx1.example.com", + @host="127.0.1.1", + @attempts=nil, @response= #<struct Truemail::Validate::Smtp::Response port_opened=true, connection=true, helo= #<Net::SMTP::Response:0x0000000002d5aca8 @status="250", - @string="250 mx1.example.com Hello example.com\n">, + @string="250 127.0.1.1 Hello example.com\n">, mailfrom= #<Net::SMTP::Response:0x0000000002d5a618 @status="250", @string="250 OK\n">, rcptto=false, @@ -301,33 +313,35 @@ @result= #<struct Truemail::Validator::Result success=true, email="email@example.com", domain="example.com", - mail_servers=["mx1.example.com"], + mail_servers=["127.0.1.1", "127.0.1.2"], errors={}, smtp_debug= [#<Truemail::Validate::Smtp::Request:0x0000000002c95d40 @configuration= #<Truemail::Configuration:0x0000000002c95b38 @connection_timeout=2, @email_pattern=/regex_pattern/, @response_timeout=2, + @connection_attempts=2, @smtp_safe_check=true, @validation_type_by_domain={}, @verifier_domain="example.com", @verifier_email="verifier@example.com">, @email="email@example.com", - @host="mx1.example.com", + @host="127.0.1.1", + @attempts=nil, @response= #<struct Truemail::Validate::Smtp::Response port_opened=true, connection=false, helo= #<Net::SMTP::Response:0x0000000002c934c8 @status="250", - @string="250 mx1.example.com\n">, + @string="250 127.0.1.1\n">, mailfrom=false, rcptto=nil, errors={:mailfrom=>"554 5.7.1 Client host blocked\n", :connection=>"server dropped connection after response"}>>,]>, @validation_type=:smtp> @@ -336,32 +350,34 @@ @result= #<struct Truemail::Validator::Result success=false, email="email@example.com", domain="example.com", - mail_servers=["mx1.example.com", "mx2.example.com", "mx3.example.com"], + mail_servers=["127.0.1.1", "127.0.1.2"], errors={:smtp=>"smtp error"}, smtp_debug= [#<Truemail::Validate::Smtp::Request:0x0000000002d49b10 @configuration= #<Truemail::Configuration:0x0000000002d49930 @connection_timeout=2, @email_pattern=/regex_pattern/, @response_timeout=2, + @connection_attempts=2, @smtp_safe_check=true, @validation_type_by_domain={}, @verifier_domain="example.com", @verifier_email="verifier@example.com">, @email="email@example.com", - @host="mx1.example.com", + @host="127.0.1.1", + @attempts=nil, @response= #<struct Truemail::Validate::Smtp::Response port_opened=true, connection=true, helo= #<Net::SMTP::Response:0x0000000002d5aca8 @status="250", - @string="250 mx1.example.com Hello example.com\n">, + @string="250 127.0.1.1 Hello example.com\n">, mailfrom=#<Net::SMTP::Response:0x0000000002d5a618 @status="250", @string="250 OK\n">, rcptto=false, errors={:rcptto=>"550 User not found\n"}>>]>, @validation_type=:smtp> ```