Skip to content

RBLDNS Export

Marco Favero edited this page Jan 25, 2018 · 20 revisions

Ok, you have installed the RBL system and you have populated the lists. Now, you want to export them in RBLDNS formatted files. You must know what RBLDNSD is, and how the zone files work.

Well, go to contrib/rbldns and run exportdns.php with -f <file zone header> -t <list name>

By default we provide a conf.default header file. You can customize it using also these special words:

  • {rblname}: is replaced by the DNSBL name (long name of -t flag)
  • {rbltype}: is replaced by the list type (human readable version of $bl in $tables of config.php)
  • {year}: the current year
  • {date822}: the RFC822 formatted date
  • {rblname64}: the encripted base64 {rblname}
  • {hostname}: the hostname of server
  • {unixtimestamp}: the current unix timestamp

The default.conf provides a description field TXT with a URI for the result lookup (lookup.php). The lookup.php needs two GET parameters:

  • the object to query
  • the base64 encrypted long name of the list.

Hint: don't change this configuration if you don't really know what you are doing.

You can export the list via crontab. For instance:

# Run export of DNSBL every 30 minutes`
*/30 * * * * root cd /usr/local/RBL/contrib/rbldns/myrbl; ../exportdns.php -f ../conf.default -t whiteip
*/30 * * * * root cd /usr/local/RBL/contrib/rbldns/myrbl; ../exportdns.php -f ../conf.default -t spamip

But if you installed RBL Manager by RPM, you will find the systemd timer rbl-rbldns@<list name>. You can see the systemd service in /usr/lib/systemd/system/[email protected].

Enable an instance %i for each list name. For example

systemctl enable [email protected]

systemct start [email protected]

By default, the systemd service saves the lists into the folder <localinst>/RBL/contrib/rbldns/yourbl. Typically, <localinst> is /usr/share.

Probably you would store these files within a Rsync server folder to let them available to the RBLDNS host: rsync.conf

read only = yes
list = false
uid = nobody
gid = nobody
hosts allow = IP1, IP2
hosts deny = *
log file = /var/log/rsyncd.log
pid file = /run/rsyncd.pid

# Module configuration
[yourbl]
comment = Welcome ~ rbl.example.com for Your DNSBL DNSWL
path = <localinst>/RBL/contrib/rbldns/yourbl

Sorry, currently I have only tested the export of IP and domain lists. The export of networks should works too.

Clone this wiki locally