Skip to content

RBLDNS Export

Marco Favero edited this page Nov 24, 2017 · 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 save the lists into the folder <localinst>/RBL/contrib/rbldns/yourbl. Typically, <localinst> is /usr/share.

Probably you would store these files in a Rsync server folder to let them available to the RBLDNS host through Rsync: 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 lists. The export of networks or domains should works too.

Clone this wiki locally