1*00b67f09SDavid van Moolenbroek /* $NetBSD: keydelete.c,v 1.6 2014/12/10 04:37:54 christos Exp $ */
2*00b67f09SDavid van Moolenbroek
3*00b67f09SDavid van Moolenbroek /*
4*00b67f09SDavid van Moolenbroek * Copyright (C) 2004, 2005, 2007, 2009-2011, 2014 Internet Systems Consortium, Inc. ("ISC")
5*00b67f09SDavid van Moolenbroek * Copyright (C) 2001 Internet Software Consortium.
6*00b67f09SDavid van Moolenbroek *
7*00b67f09SDavid van Moolenbroek * Permission to use, copy, modify, and/or distribute this software for any
8*00b67f09SDavid van Moolenbroek * purpose with or without fee is hereby granted, provided that the above
9*00b67f09SDavid van Moolenbroek * copyright notice and this permission notice appear in all copies.
10*00b67f09SDavid van Moolenbroek *
11*00b67f09SDavid van Moolenbroek * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
12*00b67f09SDavid van Moolenbroek * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
13*00b67f09SDavid van Moolenbroek * AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
14*00b67f09SDavid van Moolenbroek * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
15*00b67f09SDavid van Moolenbroek * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
16*00b67f09SDavid van Moolenbroek * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
17*00b67f09SDavid van Moolenbroek * PERFORMANCE OF THIS SOFTWARE.
18*00b67f09SDavid van Moolenbroek */
19*00b67f09SDavid van Moolenbroek
20*00b67f09SDavid van Moolenbroek /* Id: keydelete.c,v 1.18 2011/01/11 23:47:13 tbox Exp */
21*00b67f09SDavid van Moolenbroek
22*00b67f09SDavid van Moolenbroek #include <config.h>
23*00b67f09SDavid van Moolenbroek
24*00b67f09SDavid van Moolenbroek #include <stdlib.h>
25*00b67f09SDavid van Moolenbroek #include <string.h>
26*00b67f09SDavid van Moolenbroek
27*00b67f09SDavid van Moolenbroek #include <isc/app.h>
28*00b67f09SDavid van Moolenbroek #include <isc/base64.h>
29*00b67f09SDavid van Moolenbroek #include <isc/entropy.h>
30*00b67f09SDavid van Moolenbroek #include <isc/hash.h>
31*00b67f09SDavid van Moolenbroek #include <isc/log.h>
32*00b67f09SDavid van Moolenbroek #include <isc/mem.h>
33*00b67f09SDavid van Moolenbroek #include <isc/sockaddr.h>
34*00b67f09SDavid van Moolenbroek #include <isc/socket.h>
35*00b67f09SDavid van Moolenbroek #include <isc/task.h>
36*00b67f09SDavid van Moolenbroek #include <isc/timer.h>
37*00b67f09SDavid van Moolenbroek #include <isc/util.h>
38*00b67f09SDavid van Moolenbroek
39*00b67f09SDavid van Moolenbroek #include <dns/dispatch.h>
40*00b67f09SDavid van Moolenbroek #include <dns/fixedname.h>
41*00b67f09SDavid van Moolenbroek #include <dns/keyvalues.h>
42*00b67f09SDavid van Moolenbroek #include <dns/message.h>
43*00b67f09SDavid van Moolenbroek #include <dns/name.h>
44*00b67f09SDavid van Moolenbroek #include <dns/request.h>
45*00b67f09SDavid van Moolenbroek #include <dns/result.h>
46*00b67f09SDavid van Moolenbroek #include <dns/tkey.h>
47*00b67f09SDavid van Moolenbroek #include <dns/tsig.h>
48*00b67f09SDavid van Moolenbroek #include <dns/view.h>
49*00b67f09SDavid van Moolenbroek
50*00b67f09SDavid van Moolenbroek #include <dst/result.h>
51*00b67f09SDavid van Moolenbroek
52*00b67f09SDavid van Moolenbroek #define CHECK(str, x) { \
53*00b67f09SDavid van Moolenbroek if ((x) != ISC_R_SUCCESS) { \
54*00b67f09SDavid van Moolenbroek fprintf(stderr, "I:%s: %s\n", (str), isc_result_totext(x)); \
55*00b67f09SDavid van Moolenbroek exit(-1); \
56*00b67f09SDavid van Moolenbroek } \
57*00b67f09SDavid van Moolenbroek }
58*00b67f09SDavid van Moolenbroek
59*00b67f09SDavid van Moolenbroek #define RUNCHECK(x) RUNTIME_CHECK((x) == ISC_R_SUCCESS)
60*00b67f09SDavid van Moolenbroek
61*00b67f09SDavid van Moolenbroek #define PORT 5300
62*00b67f09SDavid van Moolenbroek #define TIMEOUT 30
63*00b67f09SDavid van Moolenbroek
64*00b67f09SDavid van Moolenbroek static isc_mem_t *mctx;
65*00b67f09SDavid van Moolenbroek static dns_tsigkey_t *tsigkey;
66*00b67f09SDavid van Moolenbroek static dns_tsig_keyring_t *ring;
67*00b67f09SDavid van Moolenbroek static dns_requestmgr_t *requestmgr;
68*00b67f09SDavid van Moolenbroek
69*00b67f09SDavid van Moolenbroek static void
recvquery(isc_task_t * task,isc_event_t * event)70*00b67f09SDavid van Moolenbroek recvquery(isc_task_t *task, isc_event_t *event) {
71*00b67f09SDavid van Moolenbroek dns_requestevent_t *reqev = (dns_requestevent_t *)event;
72*00b67f09SDavid van Moolenbroek isc_result_t result;
73*00b67f09SDavid van Moolenbroek dns_message_t *query, *response;
74*00b67f09SDavid van Moolenbroek
75*00b67f09SDavid van Moolenbroek UNUSED(task);
76*00b67f09SDavid van Moolenbroek
77*00b67f09SDavid van Moolenbroek REQUIRE(reqev != NULL);
78*00b67f09SDavid van Moolenbroek
79*00b67f09SDavid van Moolenbroek if (reqev->result != ISC_R_SUCCESS) {
80*00b67f09SDavid van Moolenbroek fprintf(stderr, "I:request event result: %s\n",
81*00b67f09SDavid van Moolenbroek isc_result_totext(reqev->result));
82*00b67f09SDavid van Moolenbroek exit(-1);
83*00b67f09SDavid van Moolenbroek }
84*00b67f09SDavid van Moolenbroek
85*00b67f09SDavid van Moolenbroek query = reqev->ev_arg;
86*00b67f09SDavid van Moolenbroek
87*00b67f09SDavid van Moolenbroek response = NULL;
88*00b67f09SDavid van Moolenbroek result = dns_message_create(mctx, DNS_MESSAGE_INTENTPARSE, &response);
89*00b67f09SDavid van Moolenbroek CHECK("dns_message_create", result);
90*00b67f09SDavid van Moolenbroek
91*00b67f09SDavid van Moolenbroek result = dns_request_getresponse(reqev->request, response,
92*00b67f09SDavid van Moolenbroek DNS_MESSAGEPARSE_PRESERVEORDER);
93*00b67f09SDavid van Moolenbroek CHECK("dns_request_getresponse", result);
94*00b67f09SDavid van Moolenbroek
95*00b67f09SDavid van Moolenbroek if (response->rcode != dns_rcode_noerror) {
96*00b67f09SDavid van Moolenbroek result = ISC_RESULTCLASS_DNSRCODE + response->rcode;
97*00b67f09SDavid van Moolenbroek fprintf(stderr, "I:response rcode: %s\n",
98*00b67f09SDavid van Moolenbroek isc_result_totext(result));
99*00b67f09SDavid van Moolenbroek exit(-1);
100*00b67f09SDavid van Moolenbroek }
101*00b67f09SDavid van Moolenbroek
102*00b67f09SDavid van Moolenbroek result = dns_tkey_processdeleteresponse(query, response, ring);
103*00b67f09SDavid van Moolenbroek CHECK("dns_tkey_processdhresponse", result);
104*00b67f09SDavid van Moolenbroek
105*00b67f09SDavid van Moolenbroek dns_message_destroy(&query);
106*00b67f09SDavid van Moolenbroek dns_message_destroy(&response);
107*00b67f09SDavid van Moolenbroek dns_request_destroy(&reqev->request);
108*00b67f09SDavid van Moolenbroek isc_event_free(&event);
109*00b67f09SDavid van Moolenbroek isc_app_shutdown();
110*00b67f09SDavid van Moolenbroek return;
111*00b67f09SDavid van Moolenbroek }
112*00b67f09SDavid van Moolenbroek
113*00b67f09SDavid van Moolenbroek static void
sendquery(isc_task_t * task,isc_event_t * event)114*00b67f09SDavid van Moolenbroek sendquery(isc_task_t *task, isc_event_t *event) {
115*00b67f09SDavid van Moolenbroek struct in_addr inaddr;
116*00b67f09SDavid van Moolenbroek isc_sockaddr_t address;
117*00b67f09SDavid van Moolenbroek isc_result_t result;
118*00b67f09SDavid van Moolenbroek dns_message_t *query;
119*00b67f09SDavid van Moolenbroek dns_request_t *request;
120*00b67f09SDavid van Moolenbroek
121*00b67f09SDavid van Moolenbroek isc_event_free(&event);
122*00b67f09SDavid van Moolenbroek
123*00b67f09SDavid van Moolenbroek result = ISC_R_FAILURE;
124*00b67f09SDavid van Moolenbroek if (inet_pton(AF_INET, "10.53.0.1", &inaddr) != 1)
125*00b67f09SDavid van Moolenbroek CHECK("inet_pton", result);
126*00b67f09SDavid van Moolenbroek isc_sockaddr_fromin(&address, &inaddr, PORT);
127*00b67f09SDavid van Moolenbroek
128*00b67f09SDavid van Moolenbroek query = NULL;
129*00b67f09SDavid van Moolenbroek result = dns_message_create(mctx, DNS_MESSAGE_INTENTRENDER, &query);
130*00b67f09SDavid van Moolenbroek CHECK("dns_message_create", result);
131*00b67f09SDavid van Moolenbroek
132*00b67f09SDavid van Moolenbroek result = dns_tkey_builddeletequery(query, tsigkey);
133*00b67f09SDavid van Moolenbroek CHECK("dns_tkey_builddeletequery", result);
134*00b67f09SDavid van Moolenbroek
135*00b67f09SDavid van Moolenbroek request = NULL;
136*00b67f09SDavid van Moolenbroek result = dns_request_create(requestmgr, query, &address,
137*00b67f09SDavid van Moolenbroek DNS_REQUESTOPT_TCP, tsigkey, TIMEOUT,
138*00b67f09SDavid van Moolenbroek task, recvquery, query, &request);
139*00b67f09SDavid van Moolenbroek CHECK("dns_request_create", result);
140*00b67f09SDavid van Moolenbroek }
141*00b67f09SDavid van Moolenbroek
142*00b67f09SDavid van Moolenbroek int
main(int argc,char ** argv)143*00b67f09SDavid van Moolenbroek main(int argc, char **argv) {
144*00b67f09SDavid van Moolenbroek char *keyname;
145*00b67f09SDavid van Moolenbroek isc_taskmgr_t *taskmgr;
146*00b67f09SDavid van Moolenbroek isc_timermgr_t *timermgr;
147*00b67f09SDavid van Moolenbroek isc_socketmgr_t *socketmgr;
148*00b67f09SDavid van Moolenbroek isc_socket_t *sock;
149*00b67f09SDavid van Moolenbroek unsigned int attrs, attrmask;
150*00b67f09SDavid van Moolenbroek isc_sockaddr_t bind_any;
151*00b67f09SDavid van Moolenbroek dns_dispatchmgr_t *dispatchmgr;
152*00b67f09SDavid van Moolenbroek dns_dispatch_t *dispatchv4;
153*00b67f09SDavid van Moolenbroek dns_view_t *view;
154*00b67f09SDavid van Moolenbroek isc_entropy_t *ectx;
155*00b67f09SDavid van Moolenbroek dns_tkeyctx_t *tctx;
156*00b67f09SDavid van Moolenbroek dst_key_t *dstkey;
157*00b67f09SDavid van Moolenbroek isc_log_t *log;
158*00b67f09SDavid van Moolenbroek isc_logconfig_t *logconfig;
159*00b67f09SDavid van Moolenbroek isc_task_t *task;
160*00b67f09SDavid van Moolenbroek isc_result_t result;
161*00b67f09SDavid van Moolenbroek int type;
162*00b67f09SDavid van Moolenbroek
163*00b67f09SDavid van Moolenbroek RUNCHECK(isc_app_start());
164*00b67f09SDavid van Moolenbroek
165*00b67f09SDavid van Moolenbroek if (argc < 2) {
166*00b67f09SDavid van Moolenbroek fprintf(stderr, "I:no key to delete\n");
167*00b67f09SDavid van Moolenbroek exit(-1);
168*00b67f09SDavid van Moolenbroek }
169*00b67f09SDavid van Moolenbroek keyname = argv[1];
170*00b67f09SDavid van Moolenbroek
171*00b67f09SDavid van Moolenbroek dns_result_register();
172*00b67f09SDavid van Moolenbroek
173*00b67f09SDavid van Moolenbroek mctx = NULL;
174*00b67f09SDavid van Moolenbroek RUNCHECK(isc_mem_create(0, 0, &mctx));
175*00b67f09SDavid van Moolenbroek
176*00b67f09SDavid van Moolenbroek ectx = NULL;
177*00b67f09SDavid van Moolenbroek RUNCHECK(isc_entropy_create(mctx, &ectx));
178*00b67f09SDavid van Moolenbroek RUNCHECK(isc_entropy_createfilesource(ectx, "../random.data"));
179*00b67f09SDavid van Moolenbroek RUNCHECK(isc_hash_create(mctx, ectx, DNS_NAME_MAXWIRE));
180*00b67f09SDavid van Moolenbroek
181*00b67f09SDavid van Moolenbroek log = NULL;
182*00b67f09SDavid van Moolenbroek logconfig = NULL;
183*00b67f09SDavid van Moolenbroek RUNCHECK(isc_log_create(mctx, &log, &logconfig));
184*00b67f09SDavid van Moolenbroek
185*00b67f09SDavid van Moolenbroek RUNCHECK(dst_lib_init(mctx, ectx, ISC_ENTROPY_GOODONLY));
186*00b67f09SDavid van Moolenbroek
187*00b67f09SDavid van Moolenbroek taskmgr = NULL;
188*00b67f09SDavid van Moolenbroek RUNCHECK(isc_taskmgr_create(mctx, 1, 0, &taskmgr));
189*00b67f09SDavid van Moolenbroek task = NULL;
190*00b67f09SDavid van Moolenbroek RUNCHECK(isc_task_create(taskmgr, 0, &task));
191*00b67f09SDavid van Moolenbroek timermgr = NULL;
192*00b67f09SDavid van Moolenbroek RUNCHECK(isc_timermgr_create(mctx, &timermgr));
193*00b67f09SDavid van Moolenbroek socketmgr = NULL;
194*00b67f09SDavid van Moolenbroek RUNCHECK(isc_socketmgr_create(mctx, &socketmgr));
195*00b67f09SDavid van Moolenbroek dispatchmgr = NULL;
196*00b67f09SDavid van Moolenbroek RUNCHECK(dns_dispatchmgr_create(mctx, NULL, &dispatchmgr));
197*00b67f09SDavid van Moolenbroek isc_sockaddr_any(&bind_any);
198*00b67f09SDavid van Moolenbroek attrs = DNS_DISPATCHATTR_UDP |
199*00b67f09SDavid van Moolenbroek DNS_DISPATCHATTR_MAKEQUERY |
200*00b67f09SDavid van Moolenbroek DNS_DISPATCHATTR_IPV4;
201*00b67f09SDavid van Moolenbroek attrmask = DNS_DISPATCHATTR_UDP |
202*00b67f09SDavid van Moolenbroek DNS_DISPATCHATTR_TCP |
203*00b67f09SDavid van Moolenbroek DNS_DISPATCHATTR_IPV4 |
204*00b67f09SDavid van Moolenbroek DNS_DISPATCHATTR_IPV6;
205*00b67f09SDavid van Moolenbroek dispatchv4 = NULL;
206*00b67f09SDavid van Moolenbroek RUNCHECK(dns_dispatch_getudp(dispatchmgr, socketmgr, taskmgr,
207*00b67f09SDavid van Moolenbroek &bind_any, 4096, 4, 2, 3, 5,
208*00b67f09SDavid van Moolenbroek attrs, attrmask, &dispatchv4));
209*00b67f09SDavid van Moolenbroek requestmgr = NULL;
210*00b67f09SDavid van Moolenbroek RUNCHECK(dns_requestmgr_create(mctx, timermgr, socketmgr, taskmgr,
211*00b67f09SDavid van Moolenbroek dispatchmgr, dispatchv4, NULL,
212*00b67f09SDavid van Moolenbroek &requestmgr));
213*00b67f09SDavid van Moolenbroek
214*00b67f09SDavid van Moolenbroek ring = NULL;
215*00b67f09SDavid van Moolenbroek RUNCHECK(dns_tsigkeyring_create(mctx, &ring));
216*00b67f09SDavid van Moolenbroek tctx = NULL;
217*00b67f09SDavid van Moolenbroek RUNCHECK(dns_tkeyctx_create(mctx, ectx, &tctx));
218*00b67f09SDavid van Moolenbroek
219*00b67f09SDavid van Moolenbroek view = NULL;
220*00b67f09SDavid van Moolenbroek RUNCHECK(dns_view_create(mctx, 0, "_test", &view));
221*00b67f09SDavid van Moolenbroek dns_view_setkeyring(view, ring);
222*00b67f09SDavid van Moolenbroek
223*00b67f09SDavid van Moolenbroek sock = NULL;
224*00b67f09SDavid van Moolenbroek RUNCHECK(isc_socket_create(socketmgr, PF_INET, isc_sockettype_udp,
225*00b67f09SDavid van Moolenbroek &sock));
226*00b67f09SDavid van Moolenbroek
227*00b67f09SDavid van Moolenbroek RUNCHECK(isc_app_onrun(mctx, task, sendquery, NULL));
228*00b67f09SDavid van Moolenbroek
229*00b67f09SDavid van Moolenbroek dstkey = NULL;
230*00b67f09SDavid van Moolenbroek type = DST_TYPE_PUBLIC | DST_TYPE_PRIVATE | DST_TYPE_KEY;
231*00b67f09SDavid van Moolenbroek result = dst_key_fromnamedfile(keyname, NULL, type, mctx, &dstkey);
232*00b67f09SDavid van Moolenbroek CHECK("dst_key_fromnamedfile", result);
233*00b67f09SDavid van Moolenbroek result = dns_tsigkey_createfromkey(dst_key_name(dstkey),
234*00b67f09SDavid van Moolenbroek DNS_TSIG_HMACMD5_NAME,
235*00b67f09SDavid van Moolenbroek dstkey, ISC_TRUE, NULL, 0, 0,
236*00b67f09SDavid van Moolenbroek mctx, ring, &tsigkey);
237*00b67f09SDavid van Moolenbroek dst_key_free(&dstkey);
238*00b67f09SDavid van Moolenbroek CHECK("dns_tsigkey_createfromkey", result);
239*00b67f09SDavid van Moolenbroek
240*00b67f09SDavid van Moolenbroek (void)isc_app_run();
241*00b67f09SDavid van Moolenbroek
242*00b67f09SDavid van Moolenbroek dns_requestmgr_shutdown(requestmgr);
243*00b67f09SDavid van Moolenbroek dns_requestmgr_detach(&requestmgr);
244*00b67f09SDavid van Moolenbroek dns_dispatch_detach(&dispatchv4);
245*00b67f09SDavid van Moolenbroek dns_dispatchmgr_destroy(&dispatchmgr);
246*00b67f09SDavid van Moolenbroek isc_task_shutdown(task);
247*00b67f09SDavid van Moolenbroek isc_task_detach(&task);
248*00b67f09SDavid van Moolenbroek isc_taskmgr_destroy(&taskmgr);
249*00b67f09SDavid van Moolenbroek isc_socket_detach(&sock);
250*00b67f09SDavid van Moolenbroek isc_socketmgr_destroy(&socketmgr);
251*00b67f09SDavid van Moolenbroek isc_timermgr_destroy(&timermgr);
252*00b67f09SDavid van Moolenbroek
253*00b67f09SDavid van Moolenbroek dns_tsigkeyring_detach(&ring);
254*00b67f09SDavid van Moolenbroek
255*00b67f09SDavid van Moolenbroek dns_tsigkey_detach(&tsigkey);
256*00b67f09SDavid van Moolenbroek
257*00b67f09SDavid van Moolenbroek dns_tkeyctx_destroy(&tctx);
258*00b67f09SDavid van Moolenbroek
259*00b67f09SDavid van Moolenbroek dns_view_detach(&view);
260*00b67f09SDavid van Moolenbroek
261*00b67f09SDavid van Moolenbroek isc_log_destroy(&log);
262*00b67f09SDavid van Moolenbroek
263*00b67f09SDavid van Moolenbroek dst_lib_destroy();
264*00b67f09SDavid van Moolenbroek isc_hash_destroy();
265*00b67f09SDavid van Moolenbroek isc_entropy_detach(&ectx);
266*00b67f09SDavid van Moolenbroek
267*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
268*00b67f09SDavid van Moolenbroek
269*00b67f09SDavid van Moolenbroek isc_app_finish();
270*00b67f09SDavid van Moolenbroek
271*00b67f09SDavid van Moolenbroek return (0);
272*00b67f09SDavid van Moolenbroek }
273