.TH email-validator 1 .SH NAME email-validator \- Perform basic syntax and deliverability checks on email addresses. .SH SYNOPSIS \fBemail-validator\fR [\fB\-har\fR] [\fB-i \fIFILE\fR] [\fB-o \fIFILE\fR] \fI\fR .SH INPUT .P The \fIinput\fR (default: stdin) should be a list of email addresses, one per line. Empty lines will be ignored. .SH OUTPUT .P Valid email addresses will be written to the output file (default: stdout), one per line. .SH DESCRIPTION .P Validate an email address using three techniques: .IP \[bu] 2 Ensuring that the length of local and domain parts is within the RFC-specified limits. .IP \[bu] A syntax check using a regular expression, or the full RFC 5322 grammar (see the \fB\-\-rfc5322\fR option). .IP \[bu] Confirmation of the existence of an \fIMX\fR record for the domain part of the address. This is not required; in fact many domains accept mail via an \fIA\fR record for e.g. example.com which is used in lieu of an \fIMX\fR record. This behavior can be controlled via the \fR\-\-accept\-a\fR flag. .P These checks are performed in parallel using the number of available threads. To increase the number of threads, you can pass the appropriate flag to the GHC runtime. .P This will set the number of threads to 25: .nf .B $ email-validator -i addresses.csv +RTS -N25 .SH OPTIONS .IP \fB\-\-accept-a\fR,\ \fB\-a\fR Accept an 'A' record for the domain instead of requiring an MX record (the default). .IP \fB\-\-input\fR,\ \fB\-i\fR Specify the input file containing a list of email addresses, rather than using stdin (the default). .IP \fB\-\-output\fR,\ \fB\-o\fR Specify the output file to which the good addresses will be written, rather than using stdout (the default). .IP \fB\-\-rfc5322\fR,\ \fB\-r\fR Verify addresses against RFC 5322 rather than a naive regular expression. This is much more lenient than the default. .SH BUGS .P Send bugs to michael@orlitzky.com.