3 * - simple test program, not part of the library
6 * This file is part of adns, which is Copyright (C) 1997-1999 Ian Jackson
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2, or (at your option)
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software Foundation,
20 * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
30 # define OUTPUTSTREAM stdout
35 static void failure(const char *what
, adns_status st
) {
36 fprintf(stderr
,"adns failure: %s: %s\n",what
,adns_strerror(st
));
40 static const char *defaultargv
[]= { "ns.chiark.greenend.org.uk", 0 };
42 static const adns_rrtype defaulttypes
[]= {
64 static void dumptype(adns_status ri
, const char *rrtn
, const char *fmtn
) {
65 fprintf(stdout
, "%s(%s)%s%s",
66 ri ?
"?" : rrtn
, ri ?
"?" : fmtn ? fmtn
: "-",
67 ri ?
" " : "", ri ?
adns_strerror(ri
) : "");
70 static void fdom_split(const char *fdom
, const char **dom_r
, int *qf_r
) {
74 qf
= strtoul(fdom
,&ep
,0);
75 if (*ep
!= '/') { *dom_r
= fdom
; *qf_r
= 0; }
76 else { *dom_r
= ep
+1; *qf_r
= qf
; }
79 int main(int argc
, char *const *argv
) {
83 const char *initstring
, *rrtn
, *fmtn
;
84 const char *const *fdomlist
, *domain
;
86 int len
, i
, qc
, qi
, tc
, ti
, ch
, qflags
;
88 const adns_rrtype
*types
;
92 if (argv
[0] && argv
[1] && argv
[1][0] == '/') {
93 initstring
= argv
[1]+1;
99 if (argv
[0] && argv
[1] && argv
[1][0] == ':') {
100 for (cp
= argv
[1]+1, tc
=1; (ch
= *cp
); cp
++)
102 types_a
= malloc(sizeof(*types_a
)*(tc
+1));
103 if (!types_a
) { perror("malloc types"); exit(3); }
104 for (cp
= argv
[1]+1, ti
=0; ti
<tc
; ti
++) {
105 types_a
[ti
]= strtoul(cp
,&cp
,10);
108 fputs("usage: dtest [/<initstring>] [:<typenum>,...] [<domain> ...]\n",stderr
);
121 if (argv
[0] && argv
[1]) fdomlist
= (const char *const*)argv
+1;
122 else fdomlist
= defaultargv
;
124 for (qc
=0; fdomlist
[qc
]; qc
++);
125 for (tc
=0; types
[tc
] != adns_r_none
; tc
++);
126 qus
= malloc(sizeof(qus
)*qc
*tc
);
127 if (!qus
) { perror("malloc qus"); exit(3); }
130 r
= adns_init_strcfg(&ads
,adns_if_debug
|adns_if_noautosys
,stdout
,initstring
);
132 r
= adns_init(&ads
,adns_if_debug
|adns_if_noautosys
,0);
134 if (r
) failure("init",r
);
136 for (qi
=0; qi
<qc
; qi
++) {
137 fdom_split(fdomlist
[qi
],&domain
,&qflags
);
138 for (ti
=0; ti
<tc
; ti
++) {
139 fprintf(stdout
,"%s flags %d type %d",domain
,qflags
,types
[ti
]);
140 r
= adns_submit(ads
,domain
,types
[ti
],qflags
,0,&qus
[qi
*tc
+ti
]);
141 if (r
== adns_s_unknownrrtype
) {
142 fprintf(stdout
," not implemented\n");
147 ri
= adns_rr_info(types
[ti
], &rrtn
,&fmtn
,0, 0,0);
149 dumptype(ri
,rrtn
,fmtn
);
150 fprintf(stdout
," submitted\n");
155 for (qi
=0; qi
<qc
; qi
++) {
156 fdom_split(fdomlist
[qi
],&domain
,&qflags
);
158 for (ti
=0; ti
<tc
; ti
++) {
162 r
= adns_wait(ads
,&qu
,&ans
,0);
163 if (r
) failure("wait",r
);
165 if (gettimeofday(&now
,0)) { perror("gettimeofday"); exit(3); }
167 ri
= adns_rr_info(ans
->type
, &rrtn
,&fmtn
,&len
, 0,0);
168 fprintf(stdout
, "%s flags %d type ",domain
,qflags
);
169 dumptype(ri
,rrtn
,fmtn
);
170 fprintf(stdout
, ": %s; nrrs=%d; cname=%s; owner=%s; ttl=%ld\n",
171 adns_strerror(ans
->status
),
173 ans
->cname ? ans
->cname
: "$",
174 ans
->owner ? ans
->owner
: "$",
175 (long)ans
->expires
- (long)now
.tv_sec
);
178 for (i
=0; i
<ans
->nrrs
; i
++) {
179 r
= adns_rr_info(ans
->type
, 0,0,0, ans
->rrs
.bytes
+ i
*len
, &show
);
180 if (r
) failure("info",r
);
181 fprintf(stdout
," %s\n",show
);