Check email addresses against the austrian do-not-email list (ECG-Liste)
This package provides simple access to the austrian RTR (Rundfunk und Telekom Regulierungs-GmbH) “ECG list”, the registry of persons and companies who do not wish to receive promotional e-mail.
Typical usage looks like this:
from ecglist import ECGList e = ECGList() if not e.get_blacklist_status_code(email): send_email(email) else: print "%s does not want to receive email" % email
Set up the interface:
from ecglist import ECGList # Defaults to reading "ecg-liste.hash" in current directory blacklist = ECGList(filename="my-ecg-list.hash")
Test for an email address being in the blacklist:
"firstname.lastname@example.org" in blacklist
Get an email’s status code:
code = blacklist["email@example.com"]
code will be None if the email address was not found in the blacklist or a status code indicating the type of match otherwise.
Same, but get a human readable string instead of a status code:
status_str = blacklist.get_blacklist_status("firstname.lastname@example.org")
Note that the data file is only loaded when the first address is verified, i.e. the address verification might raise an Exception if the hash file has vanished in the meantime.
To reread the on-disk hash file or to free up the in-memory hash table, use the reread() method like so:
Service providers that send unsolicited advertising e-mail have to observe this list. Please refer to https://www.rtr.at/en/tk/E_Commerce_Gesetz for the legal background. Unfortunately, the only sample code provided by the RTR is in Perl (Boo! Hiss!), which prompted the creation of this module.
Obtaining the official blacklist
You will need to follow the steps outlined at https://www.rtr.at/en/tk/NutzenECG to obtain a copy of the current ECG list. Save the “ecg-liste.hash” you receive and configure the ECGList to access that file.
To install this module, simply:
$ pip install email-ecglist
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.