Skip to content
This repository has been archived by the owner on May 12, 2022. It is now read-only.

Latest commit

 

History

History
183 lines (142 loc) · 8.76 KB

README.md

File metadata and controls

183 lines (142 loc) · 8.76 KB

Sign up for a SparkPost account and visit our Developer Hub for even more content.

sparkyRecipValidate

Build Status

Easy installation

Firstly ensure you have python3, pip and git. Install pipenv:

pip install pipenv

(Depending on how it was installed, you might need to type pip3 install pipenv instead).

Get the project, and install dependencies.

git clone https://github.com/tuck1s/sparkyRecipValidate.git
cd sparkyRecipValidate
pipenv install
pipenv shell

You can now type ./sparkyRecipValidate.py -h and see usage info.

Pre-requisites

Set the following environment variables. Note these are case-sensitive.

SPARKPOST_HOST (optional)
    The URL of the SparkPost API service you're using. Defaults to https://api.sparkpost.com.

SPARKPOST_API_KEY
    API key on your SparkPost account, with Recipient Validation rights.

Usage

./sparkyRecipValidate.py -h
usage: sparkyRecipValidate.py [-h] [-i INFILE | -e EMAIL] [-o OUTFILE]
                              [--skip_precheck]

Validate recipients with SparkPost. Checks a single email address, or reads
from specified input file (or stdin). Results to specified output file or
stdout (i.e. can act as a filter).

optional arguments:
  -h, --help            show this help message and exit
  -i INFILE, --infile INFILE
                        filename to read email recipients from (in .CSV
                        format)
  -e EMAIL, --email EMAIL
                        email address to validate. May carry multiple
                        addresses, comma-separated, no spaces
  -o OUTFILE, --outfile OUTFILE
                        filename to write validation results to (in .CSV
                        format)
  --skip_precheck       Skip the precheck of input file email syntax

Command-line email addresses

After setting your env variables, you can provide one or more email addresses directly on the command-line. Recipient addresses should be comma-separated with no spaces.

export SPARKPOST_HOST=api.eu.sparkpost.com
export SPARKPOST_API_KEY=<YOUR KEY HERE>
./sparkyRecipValidate.py --email [email protected],[email protected],[email protected]
Scanned input from command line, contains 3 syntactically OK and 0 bad addresses. Validating with SparkPost..
email,valid,result,reason,is_role,is_disposable,is_free,did_you_mean
[email protected],False,undeliverable,Invalid Recipient,False,False,True,
[email protected],True,risky,,False,False,False,
[email protected],False,,Invalid Domain,False,False,False,[email protected]
Done

File input / output

The program can act as a Unix-style "filter" so you can pipe / redirect input and output. Alternatively, you can use the -i and -o options to specify input and output files.

An example input file is included in the project. Progress reporting is sent to stderr, so it doesn't interfere with stdout. Here is a filter example, then displaying the output file.

The output file follows the same form as the SparkPost web application. Note that all your address results are reported, not just the rejected ones (unlike the web UI validation).

Each validation makes a single API call, so this can take a while to run.

Comfort reporting goes to stderr so you can redirect the actual output to a file.

./sparkyRecipValidate.py <valtest.csv >out.csv
Scanned input file <stdin>, contains 15 syntactically OK and 0 bad addresses. Validating with SparkPost..
Done
cat out.csv
email,valid,result,reason,is_role,is_disposable,is_free,did_you_mean
[email protected],True,valid,,True,False,True,
[email protected],True,valid,,True,False,False,
[email protected],True,valid,,False,True,True,
[email protected],True,valid,,False,True,False,
[email protected],False,,Invalid Domain,False,True,False,
[email protected],True,valid,,False,True,False,
[email protected],True,valid,,False,True,False,
[email protected],True,valid,,False,True,False,
[email protected],True,valid,,True,False,False,
[email protected],True,valid,,False,False,False,
[email protected],False,undeliverable,Invalid Recipient,False,False,True,
[email protected],True,valid,,False,False,False,[email protected]
[email protected],False,undeliverable,Invalid Recipient,False,False,True,
[email protected],True,valid,,False,False,True,
[email protected],False,,Invalid Domain,False,False,False,

Excel or csvkit may be helpful to work with these files, for example

$ ./sparkyRecipValidate.py -i valtest.csv | csvlook
Scanned input file valtest.csv, contains 15 syntactically OK and 0 bad addresses. Validating with SparkPost..
Done
| email                            | valid | result        | reason            | is_role | is_disposable | is_free | did_you_mean    |
| -------------------------------- | ----- | ------------- | ----------------- | ------- | ------------- | ------- | --------------- |
| [email protected]             |  True | valid         |                   |    True |         False |    True |                 |
| [email protected]  |  True | valid         |                   |    True |         False |   False |                 |
| [email protected]              |  True | valid         |                   |   False |          True |    True |                 |
| [email protected]         |  True | valid         |                   |   False |          True |   False |                 |
| [email protected]            | False |               | Invalid Domain    |   False |          True |   False |                 |
| [email protected]     |  True | valid         |                   |   False |          True |   False |                 |
| [email protected]              |  True | valid         |                   |   False |          True |   False |                 |
| [email protected]                  |  True | valid         |                   |   False |          True |   False |                 |
| [email protected]              |  True | valid         |                   |    True |         False |   False |                 |
| [email protected] |  True | valid         |                   |   False |         False |   False |                 |
| [email protected]                   | False | undeliverable | Invalid Recipient |   False |         False |    True |                 |
| [email protected]                   |  True | valid         |                   |   False |         False |   False | [email protected] |
| [email protected]                    | False | undeliverable | Invalid Recipient |   False |         False |    True |                 |
| [email protected]                  |  True | valid         |                   |   False |         False |    True |                 |
| [email protected]   | False |               | Invalid Domain    |   False |         False |   False |                 |

Input file email syntax check

The email syntax pre-check uses this library, runs locally, and adds minimal runtime overhead. It also reports how many addresses are in the file before API-based validation starts.

You can skip the pre-check using the command-line flag shown under "Usage". If input is coming from a stream, and therefore not seekable, the pre-check will also be skipped.

Piping in, as you might expect, not seekable:

$ cat valtest.csv | ./sparkyRecipValidate.py >result3.csv
Skipping input file syntax pre-check. Validating with SparkPost..
Done

Redirection with < is (perhaps surprisingly) seekable on many systems, and will run the pre-check unless skipped:

$ ./sparkyRecipValidate.py <valtest.csv >result2.csv
Scanned input file <stdin>, contains 15 syntactically OK and 0 bad addresses. Validating with SparkPost..
Done

Specifying the input file with -i is seekable, and will run the pre-check unless skipped:

$ ./sparkyRecipValidate.py -i valtest.csv >result2.csv
Scanned input file valtest.csv, contains 15 syntactically OK and 0 bad addresses. Validating with SparkPost..
Done

See Also

SparkPost Developer Hub

Recipient Validation

Recipient Validation SparkPost API endpoint