Name
Date
Size
#Lines
LOC

..--

CNAME-basedRedirectionDesignNotes.pdfHD12-May-201855.6 KiB

CREDITSH A D27-May-20151.2 KiB2420

ChangelogH A D18-Oct-2024457.6 KiB11,9979,824

FEATURESH A D10-Feb-20213.6 KiB10592

IP-BasedActions.pdfHD12-May-2018241.8 KiB

LICENSEH A D19-Aug-20141.5 KiB3124

READMEH A D18-Oct-20247.1 KiB151137

README.DNS64H A D19-Sep-20231.9 KiB5134

README.ipset.mdH A D31-Dec-20191.8 KiB6657

README.svnH A D27-May-2015656 1814

README.testsH A D03-Dec-20211.4 KiB3325

TODOH A D10-Feb-20214.5 KiB7671

control_proto_spec.txtH A D07-Aug-20132.5 KiB7164

example.confH A D18-Feb-202246 KiB1,1935

example.conf.inH A D18-Oct-202454.2 KiB1,3591,129

ietf67-design-02.odpHD07-Aug-2013323.8 KiB

ietf67-design-02.pdfHD07-Aug-2013615.4 KiB

libunbound.3H A D18-Feb-202214.8 KiB435426

libunbound.3.inH A D18-Oct-202414.8 KiB435426

requirements.txtH A D12-May-201814.9 KiB295257

unbound-anchor.8H A D18-Feb-20227.5 KiB190181

unbound-anchor.8.inH A D18-Oct-20247.5 KiB190181

unbound-checkconf.8H A D18-Feb-20221.3 KiB5344

unbound-checkconf.8.inH A D18-Oct-20241.4 KiB5748

unbound-control.8H A D18-Feb-202226.5 KiB700691

unbound-control.8.inH A D18-Oct-202431 KiB766757

unbound-host.1H A D18-Feb-20223.8 KiB119110

unbound-host.1.inH A D18-Oct-20243.8 KiB119110

unbound.8H A D18-Feb-20222.5 KiB8980

unbound.8.inH A D18-Oct-20242.5 KiB8980

unbound.conf.5H A D18-Feb-2022128.6 KiB2,7412,731

unbound.conf.5.inH A D18-Oct-2024147.4 KiB3,0543,043

unbound.doxygenH A D18-Oct-2024121.7 KiB2,7782,179

README.DNS64

1The DNS64 code was written by Viagenie, 2009, by Simon Perrault as part
2of the Ecdysis project.  The code is copyright by them, and has the BSD
3license (see the dns64/dns64.c file).
4
5To enable DNS64 functionality in Unbound, two directives in unbound.conf must
6be edited:
7
81. The "module-config" directive must start with "dns64". For example:
9
10    module-config: "dns64 validator iterator"
11
12If you're not using DNSSEC then you may remove "validator".
13
142. The "dns64-prefix" directive indicates your DNS64 prefix. For example:
15
16    dns64-prefix: 64:FF9B::/96
17
18The prefix must be a /96 or shorter.
19
20To test that things are working right, perform a query against Unbound for a
21domain name for which no AAAA record exists. You should see a AAAA record in
22the answer section. The corresponding IPv6 address will be inside the DNS64
23prefix. For example:
24
25    $ unbound -c unbound.conf
26    $ dig @localhost jazz-v4.viagenie.ca aaaa
27    [...]
28    ;; ANSWER SECTION:
29    jazz-v4.viagenie.ca.        86400   IN      AAAA    64:ff9b::ce7b:1f02
30
31
32NAT64 support was added by David Lamparter in 2022; license(s) of the
33surrounding code apply.  Note that NAT64 is closely related but functionally
34orthogonal to DNS64;  it allows Unbound to send outgoing queries to IPv4-only
35servers over IPv6 through the configured NAT64 prefix.  This allows running
36an Unbound instance on an IPv6-only host without breaking every single domain
37that only has IPv4 servers.  Whether that Unbound instance also does DNS64 is
38an independent choice.
39
40To enable NAT64 in Unbound, add to unbound.conf's "server" section:
41
42    do-nat64: yes
43
44The NAT64 prefix defaults to the DNS64 prefix, which in turn defaults to the
45standard 64:FF9B::/96 prefix.  You can reconfigure it with:
46
47    nat64-prefix: 64:FF9B::/96
48
49To test NAT64 operation, pick a domain that only has IPv4 reachability for its
50nameservers and try resolving any names in that domain.
51

README.ipset.md

1## Created a module to support the ipset that could add the domain's ip to a list easily.
2
3### Purposes:
4* In my case, I can't access the facebook, twitter, youtube and thousands web site for some reason. VPN is a solution. But the internet too slow whether all traffics pass through the vpn.
5So, I set up a transparent proxy to proxy the traffic which has been blocked only.
6At the final step, I need to install a dns service which would work with ipset well to launch the system.
7I did some research for this. Unfortunately, Unbound, My favorite dns service doesn't support ipset yet. So, I decided to implement it by my self and contribute the patch. It's good for me and the community.
8```
9# unbound.conf
10server:
11  ...
12  local-zone: "facebook.com" ipset
13  local-zone: "twitter.com" ipset
14  local-zone: "instagram.com" ipset
15  more social website
16
17ipset:
18  name-v4: "gfwlist"
19```
20```
21# iptables
22iptables -A PREROUTING -p tcp -m set --match-set gfwlist dst -j REDIRECT --to-ports 10800
23iptables -A OUTPUT -p tcp -m set --match-set gfwlist dst -j REDIRECT --to-ports 10800
24```
25
26* This patch could work with iptables rules to batch block the IPs.
27```
28# unbound.conf
29server:
30  ...
31  local-zone: "facebook.com" ipset
32  local-zone: "twitter.com" ipset
33  local-zone: "instagram.com" ipset
34  more social website
35
36ipset:
37  name-v4: "blacklist"
38  name-v6: "blacklist6"
39```
40```
41# iptables
42iptables -A INPUT -m set --set blacklist src -j DROP
43ip6tables -A INPUT -m set --set blacklist6 src -j DROP
44```
45
46### Notes:
47* To enable this module the root privileges is required.
48* Please create a set with ipset command first. eg. **ipset -N blacklist iphash**
49
50### How to use:
51```
52./configure --enable-ipset
53make && make install
54```
55
56### Configuration:
57```
58# unbound.conf
59server:
60  ...
61  local-zone: "example.com" ipset
62
63ipset:
64  name-v4: "blacklist"
65```
66

README.svn

1README.svn
2
3For a svn checkout:
4* configure script, aclocal.m4, as well as yacc/lex output files are
5  committed to the repository.
6* use --enable-debug flag for configure to enable dependency tracking and
7  assertions, otherwise, use make clean; make after svn update.
8
9* Note changes in the Changelog.
10* Every check-in a postcommit hook is run
11	(the postcommit hook is in the svn/unbound/hooks directory).
12	* generates commit email with your changes and comment.
13	* compiles and runs the tests (with testcode/do-tests.sh).
14	* If build errors or test errors happen
15		* Please fix your errors and commit again.
16
17* Use gnu make to compile, make or 'gmake'.
18

README.tests

1README unbound tests
2
3For a quick test that runs unit tests and state machine tests, use
4	make test
5
6There is a long test setup for unbound that needs tools installed. Use
7	make longtest
8To make and run the long tests. The results are summarized at the end.
9
10You need to have the following programs installed and in your PATH.
11* dig - from the bind-tools package. Used to send DNS queries.
12* splint (optional) - for lint test
13* doxygen (optional) - for doc completeness test
14* ldns-testns - from ldns examples. Used as DNS auth server.
15* xxd and nc (optional) - for (malformed) packet transmission.
16The optional programs are detected and can be omitted.
17
18You can also use prepared Dockerfile to run tests inside docker based on latest gcc image:
19* build container: docker build -t unbound-tester -f contrib/Dockerfile.tests .
20* run container: docker run -it --mount type=bind,source="$(pwd)",target=/usr/src/unbound --rm unbound-tester
21* configure environment: ./configure
22* run test: make test
23* run long tests: make longtest
24It is worth to mention that you need to enable [ipv6 in your docker daemon configuration](https://docs.docker.com/config/daemon/ipv6/) because some tests need ipv6 network stack.
25
26testdata/ contains the data for tests.
27testcode/ contains scripts and c code for the tests.
28
29do-tests.sh : runs all the tests in the testdata directory.
30testbed.sh : compiles on a set of (user specific) hosts and runs do-tests.
31
32Tests are run using testcode/mini_tpkg.sh.
33