Skip to main content

spam/scam domain blacklisting for unbound

Project description

bound pulls data from The Big Blocklist Collection and generates an unbound configuration file that refuses lookup of the selected domains.

This is useful for blocking ads and malware, in much the same way as pi-hole. You might prefer this method over pi-hole if:

  • you’re already using unbound

  • you don’t love dnsmasq (which pi-hole is based on)

  • you don’t think a DNS resolver should require a web server

  • you distrust thousands of lines of bash to make major changes to your system

If the above don’t apply to you, or you’re looking for an opinionated, ad-blocking resolver with a pretty user interface and automated installer, pi-hole is probably what you want.

Requirements

  1. a gnu/linux or *bsd operating system

  2. a working unbound installation

  3. python3.6+ (for debian-like systems: sudo apt-get install python3)

  4. python3 requests library (for debian-like systems: sudo apt-get install python3-requests)

Installation

python setup.py install

Usage

bound is intended to be used with blocklists from The Big Blocklist Collection.

Run without any options, bound will:

  1. download the latest “ticked” list from the Big Blocklist Collection

  2. download all of the blocklists listed in the “ticked” list

  3. parse, deduplicate, and assemble a list of domains from the retrieved blocklists

  4. remove any safelisted domains from the list

  5. write /etc/unbound/unbound.conf.d/blocklist.conf to configure unbound for blocking the listed domains

  6. check the unbound configuration, and exit in case of any errors

  7. restart unbound

To accomplish the above, you will probably need to run bound as the root user.

There are options that support running as a non-root user, as well as specifying the blocklist URL, an optional safelist URL, and local blocklist and safelist files.

For a description of all the options, run bound -h.

Supported File Formats

bound supports blocklists and safelists in the following formats:

one domain per line

advanbusiness.com
aoldaily.com
aolon1ine.com
applesoftupdate.com
arrowservice.net

one domain per line, with inline comments

quantummetric.com # Cydia/Bigboss
cydia.saurik.com.cdngc.net # Cydia/Bigboss
production-ultimate-assets.ratecity.com.au # NewsCorp
saber.srvcs.tumblr.com # Tumblr
fd-fp3.wg1.b.yahoo.com # Tumblr

hosts file format

127.0.0.1  0koryu0.easter.ne.jp
127.0.0.1  109-204-26-16.netconnexion.managedbroadband.co.uk
127.0.0.1  1866809.securefastserver.com
127.0.0.1  2amsports.com
127.0.0.1  4dexports.com

single-digit hosts file format

0 1app.blob.core.windows.net
0 2912a.v.fwmrm.net
0 29773.v.fwmrm.net
0 5be16.v.fwmrm.net
0 888casino.com

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bound-1.0.1.tar.gz (9.8 kB view details)

Uploaded Source

Built Distribution

bound-1.0.1-py3-none-any.whl (8.1 kB view details)

Uploaded Python 3

File details

Details for the file bound-1.0.1.tar.gz.

File metadata

  • Download URL: bound-1.0.1.tar.gz
  • Upload date:
  • Size: 9.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.4

File hashes

Hashes for bound-1.0.1.tar.gz
Algorithm Hash digest
SHA256 d1f36cbe7d7aa5f7955043db799b8f35d5d0174888bec3b711049fecafca8730
MD5 ac7595f007c87b0db99f501f5bab1e4b
BLAKE2b-256 e533a08bc17894434d7f8f999f22c0fac352ed5a836c1ee357f615174c86ea97

See more details on using hashes here.

File details

Details for the file bound-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: bound-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 8.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.4

File hashes

Hashes for bound-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ea32297c4b1698f3130129fb63e83617d24692434cf99c0a9cd74f439d13a923
MD5 30d779cf0cb5c0155c349db5c73c0f07
BLAKE2b-256 e0813631c9f410038826e5d4157f99048600bc33478988232c39c9758ee2e712

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page