aboutsummaryrefslogtreecommitdiff
path: root/external/unbound/libunbound/python/doc/examples/example5.rst
blob: 9262014bb7fd6347bab343529929958d0bc98d42 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
.. _example_resolver_only:

Resolver only
=============

This example program shows how to perform DNS resolution only.
Unbound contains two basic modules: resolver and validator.
In case, the validator is not necessary, the validator module can be turned off
using "module-config" option.
This option contains a list of module names separated by the space char. This
list determined which modules should be employed and in what order.

Source code
-----------

::

	#!/usr/bin/python
	import os
	from unbound import ub_ctx,RR_TYPE_A,RR_CLASS_IN
	
	ctx = ub_ctx()
	ctx.set_option("module-config:","iterator")
	ctx.resolvconf("/etc/resolv.conf")
	
	status, result = ctx.resolve("www.google.com", RR_TYPE_A, RR_CLASS_IN)
	if status == 0 and result.havedata:
	
	    print "Result:", result.data.address_list

.. note::
   The :meth:`unbound.ub_ctx.set_option` method must be used before the first
   resolution (i.e. before :meth:`unbound.ub_ctx.resolve` or
   :meth:`unbound.ub_ctx.resolve_async` call).