2 - Copyright (C) 2004, 2005, 2007 Internet Systems Consortium, Inc. ("ISC")
3 - Copyright (C) 2000, 2001 Internet Software Consortium.
5 - Permission to use, copy, modify, and/or distribute this software for any
6 - purpose with or without fee is hereby granted, provided that the above
7 - copyright notice and this permission notice appear in all copies.
9 - THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
10 - REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
11 - AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
12 - INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
13 - LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
14 - OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
15 - PERFORMANCE OF THIS SOFTWARE.
17 <!-- Id: lwres_getrrsetbyname.html,v 1.24 2009/07/11 01:12:46 tbox Exp -->
20 <meta http-equiv=
"Content-Type" content=
"text/html; charset=ISO-8859-1">
21 <title>lwres_getrrsetbyname
</title>
22 <meta name=
"generator" content=
"DocBook XSL Stylesheets V1.71.1">
24 <body bgcolor=
"white" text=
"black" link=
"#0000FF" vlink=
"#840084" alink=
"#0000FF"><div class=
"refentry" lang=
"en">
25 <a name=
"id2476275"></a><div class=
"titlepage"></div>
26 <div class=
"refnamediv">
28 <p>lwres_getrrsetbyname, lwres_freerrset
— retrieve DNS records
</p>
30 <div class=
"refsynopsisdiv">
32 <div class=
"funcsynopsis">
33 <pre class=
"funcsynopsisinfo">#include
<lwres/netdb.h
></pre>
34 <table border=
"0" summary=
"Function synopsis" cellspacing=
"0" cellpadding=
"0" style=
"padding-bottom: 1em">
36 <td><code class=
"funcdef">
38 <b class=
"fsfunc">lwres_getrrsetbyname
</b>(
</code></td>
39 <td>const char *
</td>
41 <var class=
"pdparam">hostname
</var>,
</td>
45 <td>unsigned int
</td>
47 <var class=
"pdparam">rdclass
</var>,
</td>
51 <td>unsigned int
</td>
53 <var class=
"pdparam">rdtype
</var>,
</td>
57 <td>unsigned int
</td>
59 <var class=
"pdparam">flags
</var>,
</td>
63 <td>struct rrsetinfo **
</td>
65 <var class=
"pdparam">res
</var><code>)
</code>;
</td>
68 <table border=
"0" summary=
"Function synopsis" cellspacing=
"0" cellpadding=
"0"><tr>
69 <td><code class=
"funcdef">
71 <b class=
"fsfunc">lwres_freerrset
</b>(
</code></td>
72 <td>struct rrsetinfo *
</td>
74 <var class=
"pdparam">rrset
</var><code>)
</code>;
</td>
78 The following structures are used:
80 <pre class=
"programlisting">
82 unsigned int rdi_length; /* length of data */
83 unsigned char *rdi_data; /* record data */
88 <pre class=
"programlisting">
90 unsigned int rri_flags; /* RRSET_VALIDATED... */
91 unsigned int rri_rdclass; /* class number */
92 unsigned int rri_rdtype; /* RR type number */
93 unsigned int rri_ttl; /* time to live */
94 unsigned int rri_nrdatas; /* size of rdatas array */
95 unsigned int rri_nsigs; /* size of sigs array */
96 char *rri_name; /* canonical name */
97 struct rdatainfo *rri_rdatas; /* individual records */
98 struct rdatainfo *rri_sigs; /* individual signatures */
104 <div class=
"refsect1" lang=
"en">
105 <a name=
"id2543414"></a><h2>DESCRIPTION
</h2>
106 <p><code class=
"function">lwres_getrrsetbyname()
</code>
107 gets a set of resource records associated with a
108 <em class=
"parameter"><code>hostname
</code></em>,
<em class=
"parameter"><code>class
</code></em>,
109 and
<em class=
"parameter"><code>type
</code></em>.
110 <em class=
"parameter"><code>hostname
</code></em> is a pointer a to
111 null-terminated string. The
<em class=
"parameter"><code>flags
</code></em> field
112 is currently unused and must be zero.
115 After a successful call to
116 <code class=
"function">lwres_getrrsetbyname()
</code>,
117 <em class=
"parameter"><code>*res
</code></em> is a pointer to an
118 <span class=
"type">rrsetinfo
</span> structure, containing a list of one or
119 more
<span class=
"type">rdatainfo
</span> structures containing resource
120 records and potentially another list of
<span class=
"type">rdatainfo
</span>
121 structures containing SIG resource records associated with those
122 records. The members
<code class=
"constant">rri_rdclass
</code> and
123 <code class=
"constant">rri_rdtype
</code> are copied from the parameters.
124 <code class=
"constant">rri_ttl
</code> and
<code class=
"constant">rri_name
</code>
125 are properties of the obtained rrset. The resource records
126 contained in
<code class=
"constant">rri_rdatas
</code> and
127 <code class=
"constant">rri_sigs
</code> are in uncompressed DNS wire
128 format. Properties of the rdataset are represented in the
129 <code class=
"constant">rri_flags
</code> bitfield. If the RRSET_VALIDATED
130 bit is set, the data has been DNSSEC validated and the
134 All of the information returned by
135 <code class=
"function">lwres_getrrsetbyname()
</code> is dynamically
136 allocated: the
<code class=
"constant">rrsetinfo
</code> and
137 <code class=
"constant">rdatainfo
</code> structures, and the canonical
138 host name strings pointed to by the
139 <code class=
"constant">rrsetinfo
</code>structure.
141 Memory allocated for the dynamically allocated structures
142 created by a successful call to
143 <code class=
"function">lwres_getrrsetbyname()
</code> is released by
144 <code class=
"function">lwres_freerrset()
</code>.
146 <em class=
"parameter"><code>rrset
</code></em> is a pointer to a
<span class=
"type">struct
147 rrset
</span> created by a call to
148 <code class=
"function">lwres_getrrsetbyname()
</code>.
152 <div class=
"refsect1" lang=
"en">
153 <a name=
"id2543526"></a><h2>RETURN VALUES
</h2>
154 <p><code class=
"function">lwres_getrrsetbyname()
</code>
155 returns zero on success, and one of the following error codes if
158 <div class=
"variablelist"><dl>
159 <dt><span class=
"term"><code class=
"constant">ERRSET_NONAME
</code></span></dt>
161 the name does not exist
163 <dt><span class=
"term"><code class=
"constant">ERRSET_NODATA
</code></span></dt>
165 the name exists, but does not have data of the desired type
167 <dt><span class=
"term"><code class=
"constant">ERRSET_NOMEMORY
</code></span></dt>
169 memory could not be allocated
171 <dt><span class=
"term"><code class=
"constant">ERRSET_INVAL
</code></span></dt>
173 a parameter is invalid
175 <dt><span class=
"term"><code class=
"constant">ERRSET_FAIL
</code></span></dt>
179 <dt><span class=
"term"><code class=
"constant"></code></span></dt>
186 <div class=
"refsect1" lang=
"en">
187 <a name=
"id2543626"></a><h2>SEE ALSO
</h2>
188 <p><span class=
"citerefentry"><span class=
"refentrytitle">lwres
</span>(
3)
</span>.