xref: /minix3/external/bsd/bind/dist/bin/tests/dst/dst_test.c (revision 00b67f09dd46474d133c95011a48590a8e8f94c7)
1*00b67f09SDavid van Moolenbroek /*	$NetBSD: dst_test.c,v 1.7 2014/12/10 04:37:53 christos Exp $	*/
2*00b67f09SDavid van Moolenbroek 
3*00b67f09SDavid van Moolenbroek /*
4*00b67f09SDavid van Moolenbroek  * Copyright (C) 2004, 2005, 2007, 2009, 2012, 2014  Internet Systems Consortium, Inc. ("ISC")
5*00b67f09SDavid van Moolenbroek  * Copyright (C) 1999-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: dst_test.c,v 1.46 2009/09/01 00:22:25 jinmei 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 
26*00b67f09SDavid van Moolenbroek #include <unistd.h>		/* XXX */
27*00b67f09SDavid van Moolenbroek 
28*00b67f09SDavid van Moolenbroek #include <isc/buffer.h>
29*00b67f09SDavid van Moolenbroek #include <isc/entropy.h>
30*00b67f09SDavid van Moolenbroek #include <isc/mem.h>
31*00b67f09SDavid van Moolenbroek #include <isc/region.h>
32*00b67f09SDavid van Moolenbroek #include <isc/string.h>		/* Required for HP/UX (and others?) */
33*00b67f09SDavid van Moolenbroek 
34*00b67f09SDavid van Moolenbroek #include <dns/fixedname.h>
35*00b67f09SDavid van Moolenbroek #include <dns/log.h>
36*00b67f09SDavid van Moolenbroek #include <dns/name.h>
37*00b67f09SDavid van Moolenbroek #include <dns/result.h>
38*00b67f09SDavid van Moolenbroek 
39*00b67f09SDavid van Moolenbroek #include <dst/dst.h>
40*00b67f09SDavid van Moolenbroek #include <dst/result.h>
41*00b67f09SDavid van Moolenbroek 
42*00b67f09SDavid van Moolenbroek char *current;
43*00b67f09SDavid van Moolenbroek const char *tmp = "/tmp";
44*00b67f09SDavid van Moolenbroek 
45*00b67f09SDavid van Moolenbroek static void
use(dst_key_t * key,isc_mem_t * mctx)46*00b67f09SDavid van Moolenbroek use(dst_key_t *key, isc_mem_t *mctx) {
47*00b67f09SDavid van Moolenbroek 	isc_result_t ret;
48*00b67f09SDavid van Moolenbroek 	const char *data = "This is some data";
49*00b67f09SDavid van Moolenbroek 	unsigned char sig[512];
50*00b67f09SDavid van Moolenbroek 	isc_buffer_t databuf, sigbuf;
51*00b67f09SDavid van Moolenbroek 	isc_region_t datareg, sigreg;
52*00b67f09SDavid van Moolenbroek 	dst_context_t *ctx = NULL;
53*00b67f09SDavid van Moolenbroek 
54*00b67f09SDavid van Moolenbroek 	isc_buffer_init(&sigbuf, sig, sizeof(sig));
55*00b67f09SDavid van Moolenbroek 	/*
56*00b67f09SDavid van Moolenbroek 	 * Advance 1 byte for fun.
57*00b67f09SDavid van Moolenbroek 	 */
58*00b67f09SDavid van Moolenbroek 	isc_buffer_add(&sigbuf, 1);
59*00b67f09SDavid van Moolenbroek 
60*00b67f09SDavid van Moolenbroek 	isc_buffer_constinit(&databuf, data, strlen(data));
61*00b67f09SDavid van Moolenbroek 	isc_buffer_add(&databuf, strlen(data));
62*00b67f09SDavid van Moolenbroek 	isc_buffer_usedregion(&databuf, &datareg);
63*00b67f09SDavid van Moolenbroek 
64*00b67f09SDavid van Moolenbroek 	ret = dst_context_create3(key, mctx,
65*00b67f09SDavid van Moolenbroek 				  DNS_LOGCATEGORY_GENERAL, ISC_TRUE, &ctx);
66*00b67f09SDavid van Moolenbroek 	if (ret != ISC_R_SUCCESS) {
67*00b67f09SDavid van Moolenbroek 		printf("contextcreate(%d) returned: %s\n", dst_key_alg(key),
68*00b67f09SDavid van Moolenbroek 		       isc_result_totext(ret));
69*00b67f09SDavid van Moolenbroek 		return;
70*00b67f09SDavid van Moolenbroek 	}
71*00b67f09SDavid van Moolenbroek 	ret = dst_context_adddata(ctx, &datareg);
72*00b67f09SDavid van Moolenbroek 	if (ret != ISC_R_SUCCESS) {
73*00b67f09SDavid van Moolenbroek 		printf("adddata(%d) returned: %s\n", dst_key_alg(key),
74*00b67f09SDavid van Moolenbroek 		       isc_result_totext(ret));
75*00b67f09SDavid van Moolenbroek 		dst_context_destroy(&ctx);
76*00b67f09SDavid van Moolenbroek 		return;
77*00b67f09SDavid van Moolenbroek 	}
78*00b67f09SDavid van Moolenbroek 	ret = dst_context_sign(ctx, &sigbuf);
79*00b67f09SDavid van Moolenbroek 	printf("sign(%d) returned: %s\n", dst_key_alg(key),
80*00b67f09SDavid van Moolenbroek 	       isc_result_totext(ret));
81*00b67f09SDavid van Moolenbroek 	dst_context_destroy(&ctx);
82*00b67f09SDavid van Moolenbroek 
83*00b67f09SDavid van Moolenbroek 	isc_buffer_forward(&sigbuf, 1);
84*00b67f09SDavid van Moolenbroek 	isc_buffer_remainingregion(&sigbuf, &sigreg);
85*00b67f09SDavid van Moolenbroek 	ret = dst_context_create3(key, mctx,
86*00b67f09SDavid van Moolenbroek 				  DNS_LOGCATEGORY_GENERAL, ISC_FALSE, &ctx);
87*00b67f09SDavid van Moolenbroek 	if (ret != ISC_R_SUCCESS) {
88*00b67f09SDavid van Moolenbroek 		printf("contextcreate(%d) returned: %s\n", dst_key_alg(key),
89*00b67f09SDavid van Moolenbroek 		       isc_result_totext(ret));
90*00b67f09SDavid van Moolenbroek 		return;
91*00b67f09SDavid van Moolenbroek 	}
92*00b67f09SDavid van Moolenbroek 	ret = dst_context_adddata(ctx, &datareg);
93*00b67f09SDavid van Moolenbroek 	if (ret != ISC_R_SUCCESS) {
94*00b67f09SDavid van Moolenbroek 		printf("adddata(%d) returned: %s\n", dst_key_alg(key),
95*00b67f09SDavid van Moolenbroek 		       isc_result_totext(ret));
96*00b67f09SDavid van Moolenbroek 		dst_context_destroy(&ctx);
97*00b67f09SDavid van Moolenbroek 		return;
98*00b67f09SDavid van Moolenbroek 	}
99*00b67f09SDavid van Moolenbroek 	ret = dst_context_verify(ctx, &sigreg);
100*00b67f09SDavid van Moolenbroek 	printf("verify(%d) returned: %s\n", dst_key_alg(key),
101*00b67f09SDavid van Moolenbroek 	       isc_result_totext(ret));
102*00b67f09SDavid van Moolenbroek 	dst_context_destroy(&ctx);
103*00b67f09SDavid van Moolenbroek }
104*00b67f09SDavid van Moolenbroek 
105*00b67f09SDavid van Moolenbroek static void
dns(dst_key_t * key,isc_mem_t * mctx)106*00b67f09SDavid van Moolenbroek dns(dst_key_t *key, isc_mem_t *mctx) {
107*00b67f09SDavid van Moolenbroek 	unsigned char buffer1[2048];
108*00b67f09SDavid van Moolenbroek 	unsigned char buffer2[2048];
109*00b67f09SDavid van Moolenbroek 	isc_buffer_t buf1, buf2;
110*00b67f09SDavid van Moolenbroek 	isc_region_t r1, r2;
111*00b67f09SDavid van Moolenbroek 	dst_key_t *newkey = NULL;
112*00b67f09SDavid van Moolenbroek 	isc_result_t ret;
113*00b67f09SDavid van Moolenbroek 	isc_boolean_t match;
114*00b67f09SDavid van Moolenbroek 
115*00b67f09SDavid van Moolenbroek 	isc_buffer_init(&buf1, buffer1, sizeof(buffer1));
116*00b67f09SDavid van Moolenbroek 	ret = dst_key_todns(key, &buf1);
117*00b67f09SDavid van Moolenbroek 	printf("todns(%d) returned: %s\n", dst_key_alg(key),
118*00b67f09SDavid van Moolenbroek 	       isc_result_totext(ret));
119*00b67f09SDavid van Moolenbroek 	if (ret != ISC_R_SUCCESS)
120*00b67f09SDavid van Moolenbroek 		return;
121*00b67f09SDavid van Moolenbroek 	ret = dst_key_fromdns(dst_key_name(key), dns_rdataclass_in,
122*00b67f09SDavid van Moolenbroek 			      &buf1, mctx, &newkey);
123*00b67f09SDavid van Moolenbroek 	printf("fromdns(%d) returned: %s\n", dst_key_alg(key),
124*00b67f09SDavid van Moolenbroek 	       isc_result_totext(ret));
125*00b67f09SDavid van Moolenbroek 	if (ret != ISC_R_SUCCESS)
126*00b67f09SDavid van Moolenbroek 		return;
127*00b67f09SDavid van Moolenbroek 	isc_buffer_init(&buf2, buffer2, sizeof(buffer2));
128*00b67f09SDavid van Moolenbroek 	ret = dst_key_todns(newkey, &buf2);
129*00b67f09SDavid van Moolenbroek 	printf("todns2(%d) returned: %s\n", dst_key_alg(key),
130*00b67f09SDavid van Moolenbroek 	       isc_result_totext(ret));
131*00b67f09SDavid van Moolenbroek 	if (ret != ISC_R_SUCCESS)
132*00b67f09SDavid van Moolenbroek 		return;
133*00b67f09SDavid van Moolenbroek 	isc_buffer_usedregion(&buf1, &r1);
134*00b67f09SDavid van Moolenbroek 	isc_buffer_usedregion(&buf2, &r2);
135*00b67f09SDavid van Moolenbroek 	match = ISC_TF(r1.length == r2.length &&
136*00b67f09SDavid van Moolenbroek 		       memcmp(r1.base, r2.base, r1.length) == 0);
137*00b67f09SDavid van Moolenbroek 	printf("compare(%d): %s\n", dst_key_alg(key),
138*00b67f09SDavid van Moolenbroek 	       match ? "true" : "false");
139*00b67f09SDavid van Moolenbroek 	dst_key_free(&newkey);
140*00b67f09SDavid van Moolenbroek }
141*00b67f09SDavid van Moolenbroek 
142*00b67f09SDavid van Moolenbroek static void
io(dns_name_t * name,int id,int alg,int type,isc_mem_t * mctx)143*00b67f09SDavid van Moolenbroek io(dns_name_t *name, int id, int alg, int type, isc_mem_t *mctx) {
144*00b67f09SDavid van Moolenbroek 	dst_key_t *key = NULL;
145*00b67f09SDavid van Moolenbroek 	isc_result_t ret;
146*00b67f09SDavid van Moolenbroek 
147*00b67f09SDavid van Moolenbroek 	ret = dst_key_fromfile(name, id, alg, type, current, mctx, &key);
148*00b67f09SDavid van Moolenbroek 	printf("read(%d) returned: %s\n", alg, isc_result_totext(ret));
149*00b67f09SDavid van Moolenbroek 	if (ret != 0)
150*00b67f09SDavid van Moolenbroek 		return;
151*00b67f09SDavid van Moolenbroek 	ret = dst_key_tofile(key, type, tmp);
152*00b67f09SDavid van Moolenbroek 	printf("write(%d) returned: %s\n", alg, isc_result_totext(ret));
153*00b67f09SDavid van Moolenbroek 	if (ret != 0)
154*00b67f09SDavid van Moolenbroek 		return;
155*00b67f09SDavid van Moolenbroek 	use(key, mctx);
156*00b67f09SDavid van Moolenbroek 	dns(key, mctx);
157*00b67f09SDavid van Moolenbroek 	dst_key_free(&key);
158*00b67f09SDavid van Moolenbroek }
159*00b67f09SDavid van Moolenbroek 
160*00b67f09SDavid van Moolenbroek static void
dh(dns_name_t * name1,int id1,dns_name_t * name2,int id2,isc_mem_t * mctx)161*00b67f09SDavid van Moolenbroek dh(dns_name_t *name1, int id1, dns_name_t *name2, int id2, isc_mem_t *mctx) {
162*00b67f09SDavid van Moolenbroek 	dst_key_t *key1 = NULL, *key2 = NULL;
163*00b67f09SDavid van Moolenbroek 	isc_result_t ret;
164*00b67f09SDavid van Moolenbroek 	isc_buffer_t b1, b2;
165*00b67f09SDavid van Moolenbroek 	isc_region_t r1, r2;
166*00b67f09SDavid van Moolenbroek 	unsigned char array1[1024], array2[1024];
167*00b67f09SDavid van Moolenbroek 	int alg = DST_ALG_DH;
168*00b67f09SDavid van Moolenbroek 	int type = DST_TYPE_PUBLIC|DST_TYPE_PRIVATE|DST_TYPE_KEY;
169*00b67f09SDavid van Moolenbroek 
170*00b67f09SDavid van Moolenbroek 	ret = dst_key_fromfile(name1, id1, alg, type, current, mctx, &key1);
171*00b67f09SDavid van Moolenbroek 	printf("read(%d) returned: %s\n", alg, isc_result_totext(ret));
172*00b67f09SDavid van Moolenbroek 	if (ret != 0)
173*00b67f09SDavid van Moolenbroek 		return;
174*00b67f09SDavid van Moolenbroek 	ret = dst_key_fromfile(name2, id2, alg, type, current, mctx, &key2);
175*00b67f09SDavid van Moolenbroek 	printf("read(%d) returned: %s\n", alg, isc_result_totext(ret));
176*00b67f09SDavid van Moolenbroek 	if (ret != 0)
177*00b67f09SDavid van Moolenbroek 		return;
178*00b67f09SDavid van Moolenbroek 
179*00b67f09SDavid van Moolenbroek 	ret = dst_key_tofile(key1, type, tmp);
180*00b67f09SDavid van Moolenbroek 	printf("write(%d) returned: %s\n", alg, isc_result_totext(ret));
181*00b67f09SDavid van Moolenbroek 	if (ret != 0)
182*00b67f09SDavid van Moolenbroek 		return;
183*00b67f09SDavid van Moolenbroek 	ret = dst_key_tofile(key2, type, tmp);
184*00b67f09SDavid van Moolenbroek 	printf("write(%d) returned: %s\n", alg, isc_result_totext(ret));
185*00b67f09SDavid van Moolenbroek 	if (ret != 0)
186*00b67f09SDavid van Moolenbroek 		return;
187*00b67f09SDavid van Moolenbroek 
188*00b67f09SDavid van Moolenbroek 	isc_buffer_init(&b1, array1, sizeof(array1));
189*00b67f09SDavid van Moolenbroek 	ret = dst_key_computesecret(key1, key2, &b1);
190*00b67f09SDavid van Moolenbroek 	printf("computesecret() returned: %s\n", isc_result_totext(ret));
191*00b67f09SDavid van Moolenbroek 	if (ret != 0)
192*00b67f09SDavid van Moolenbroek 		return;
193*00b67f09SDavid van Moolenbroek 
194*00b67f09SDavid van Moolenbroek 	isc_buffer_init(&b2, array2, sizeof(array2));
195*00b67f09SDavid van Moolenbroek 	ret = dst_key_computesecret(key2, key1, &b2);
196*00b67f09SDavid van Moolenbroek 	printf("computesecret() returned: %s\n", isc_result_totext(ret));
197*00b67f09SDavid van Moolenbroek 	if (ret != 0)
198*00b67f09SDavid van Moolenbroek 		return;
199*00b67f09SDavid van Moolenbroek 
200*00b67f09SDavid van Moolenbroek 	isc_buffer_usedregion(&b1, &r1);
201*00b67f09SDavid van Moolenbroek 	isc_buffer_usedregion(&b2, &r2);
202*00b67f09SDavid van Moolenbroek 
203*00b67f09SDavid van Moolenbroek 	if (r1.length != r2.length || memcmp(r1.base, r2.base, r1.length) != 0)
204*00b67f09SDavid van Moolenbroek 	{
205*00b67f09SDavid van Moolenbroek 		int i;
206*00b67f09SDavid van Moolenbroek 		printf("secrets don't match\n");
207*00b67f09SDavid van Moolenbroek 		printf("secret 1: %d bytes\n", r1.length);
208*00b67f09SDavid van Moolenbroek 		for (i = 0; i < (int) r1.length; i++)
209*00b67f09SDavid van Moolenbroek 			printf("%02x ", r1.base[i]);
210*00b67f09SDavid van Moolenbroek 		printf("\n");
211*00b67f09SDavid van Moolenbroek 		printf("secret 2: %d bytes\n", r2.length);
212*00b67f09SDavid van Moolenbroek 		for (i = 0; i < (int) r2.length; i++)
213*00b67f09SDavid van Moolenbroek 			printf("%02x ", r2.base[i]);
214*00b67f09SDavid van Moolenbroek 		printf("\n");
215*00b67f09SDavid van Moolenbroek 	}
216*00b67f09SDavid van Moolenbroek 	dst_key_free(&key1);
217*00b67f09SDavid van Moolenbroek 	dst_key_free(&key2);
218*00b67f09SDavid van Moolenbroek }
219*00b67f09SDavid van Moolenbroek 
220*00b67f09SDavid van Moolenbroek static void
generate(int alg,isc_mem_t * mctx)221*00b67f09SDavid van Moolenbroek generate(int alg, isc_mem_t *mctx) {
222*00b67f09SDavid van Moolenbroek 	isc_result_t ret;
223*00b67f09SDavid van Moolenbroek 	dst_key_t *key = NULL;
224*00b67f09SDavid van Moolenbroek 
225*00b67f09SDavid van Moolenbroek 	ret = dst_key_generate(dns_rootname, alg, 512, 0, 0, 0,
226*00b67f09SDavid van Moolenbroek 			       dns_rdataclass_in, mctx, &key);
227*00b67f09SDavid van Moolenbroek 	printf("generate(%d) returned: %s\n", alg, isc_result_totext(ret));
228*00b67f09SDavid van Moolenbroek 	if (ret != ISC_R_SUCCESS)
229*00b67f09SDavid van Moolenbroek 		return;
230*00b67f09SDavid van Moolenbroek 
231*00b67f09SDavid van Moolenbroek 	if (alg != DST_ALG_DH)
232*00b67f09SDavid van Moolenbroek 		use(key, mctx);
233*00b67f09SDavid van Moolenbroek 
234*00b67f09SDavid van Moolenbroek 	dst_key_free(&key);
235*00b67f09SDavid van Moolenbroek }
236*00b67f09SDavid van Moolenbroek 
237*00b67f09SDavid van Moolenbroek int
main(void)238*00b67f09SDavid van Moolenbroek main(void) {
239*00b67f09SDavid van Moolenbroek 	isc_mem_t *mctx = NULL;
240*00b67f09SDavid van Moolenbroek 	isc_entropy_t *ectx = NULL;
241*00b67f09SDavid van Moolenbroek 	isc_buffer_t b;
242*00b67f09SDavid van Moolenbroek 	dns_fixedname_t fname;
243*00b67f09SDavid van Moolenbroek 	dns_name_t *name;
244*00b67f09SDavid van Moolenbroek 	isc_result_t result;
245*00b67f09SDavid van Moolenbroek 
246*00b67f09SDavid van Moolenbroek 	result = isc_mem_create(0, 0, &mctx);
247*00b67f09SDavid van Moolenbroek 	if (result != ISC_R_SUCCESS)
248*00b67f09SDavid van Moolenbroek 		return (1);
249*00b67f09SDavid van Moolenbroek 
250*00b67f09SDavid van Moolenbroek 	current = isc_mem_get(mctx, 256);
251*00b67f09SDavid van Moolenbroek 	if (current == NULL)
252*00b67f09SDavid van Moolenbroek 		return (1);
253*00b67f09SDavid van Moolenbroek 	if (getcwd(current, 256) == NULL) {
254*00b67f09SDavid van Moolenbroek 		perror("getcwd");
255*00b67f09SDavid van Moolenbroek 		return (1);
256*00b67f09SDavid van Moolenbroek 	}
257*00b67f09SDavid van Moolenbroek 
258*00b67f09SDavid van Moolenbroek 	dns_result_register();
259*00b67f09SDavid van Moolenbroek 
260*00b67f09SDavid van Moolenbroek 	result = isc_entropy_create(mctx, &ectx);
261*00b67f09SDavid van Moolenbroek 	if (result != ISC_R_SUCCESS)
262*00b67f09SDavid van Moolenbroek 		return (1);
263*00b67f09SDavid van Moolenbroek 	result = isc_entropy_createfilesource(ectx, "randomfile");
264*00b67f09SDavid van Moolenbroek 	if (result != ISC_R_SUCCESS)
265*00b67f09SDavid van Moolenbroek 		return (1);
266*00b67f09SDavid van Moolenbroek 	dst_lib_init(mctx, ectx, ISC_ENTROPY_BLOCKING|ISC_ENTROPY_GOODONLY);
267*00b67f09SDavid van Moolenbroek 
268*00b67f09SDavid van Moolenbroek 	dns_fixedname_init(&fname);
269*00b67f09SDavid van Moolenbroek 	name = dns_fixedname_name(&fname);
270*00b67f09SDavid van Moolenbroek 	isc_buffer_constinit(&b, "test.", 5);
271*00b67f09SDavid van Moolenbroek 	isc_buffer_add(&b, 5);
272*00b67f09SDavid van Moolenbroek 	result = dns_name_fromtext(name, &b, NULL, 0, NULL);
273*00b67f09SDavid van Moolenbroek 	if (result != ISC_R_SUCCESS)
274*00b67f09SDavid van Moolenbroek 		return (1);
275*00b67f09SDavid van Moolenbroek 	io(name, 23616, DST_ALG_DSA, DST_TYPE_PRIVATE|DST_TYPE_PUBLIC, mctx);
276*00b67f09SDavid van Moolenbroek 	io(name, 54622, DST_ALG_RSAMD5, DST_TYPE_PRIVATE|DST_TYPE_PUBLIC,
277*00b67f09SDavid van Moolenbroek 	   mctx);
278*00b67f09SDavid van Moolenbroek 
279*00b67f09SDavid van Moolenbroek 	io(name, 49667, DST_ALG_DSA, DST_TYPE_PRIVATE|DST_TYPE_PUBLIC, mctx);
280*00b67f09SDavid van Moolenbroek 	io(name, 2, DST_ALG_RSAMD5, DST_TYPE_PRIVATE|DST_TYPE_PUBLIC, mctx);
281*00b67f09SDavid van Moolenbroek 
282*00b67f09SDavid van Moolenbroek 	isc_buffer_constinit(&b, "dh.", 3);
283*00b67f09SDavid van Moolenbroek 	isc_buffer_add(&b, 3);
284*00b67f09SDavid van Moolenbroek 	result = dns_name_fromtext(name, &b, NULL, 0, NULL);
285*00b67f09SDavid van Moolenbroek 	if (result != ISC_R_SUCCESS)
286*00b67f09SDavid van Moolenbroek 		return (1);
287*00b67f09SDavid van Moolenbroek 	dh(name, 18602, name, 48957, mctx);
288*00b67f09SDavid van Moolenbroek 
289*00b67f09SDavid van Moolenbroek 	generate(DST_ALG_RSAMD5, mctx);
290*00b67f09SDavid van Moolenbroek 	generate(DST_ALG_DH, mctx);
291*00b67f09SDavid van Moolenbroek 	generate(DST_ALG_DSA, mctx);
292*00b67f09SDavid van Moolenbroek 	generate(DST_ALG_HMACMD5, mctx);
293*00b67f09SDavid van Moolenbroek 
294*00b67f09SDavid van Moolenbroek 	dst_lib_destroy();
295*00b67f09SDavid van Moolenbroek 	isc_entropy_detach(&ectx);
296*00b67f09SDavid van Moolenbroek 
297*00b67f09SDavid van Moolenbroek 	isc_mem_put(mctx, current, 256);
298*00b67f09SDavid van Moolenbroek /*	isc_mem_stats(mctx, stdout);*/
299*00b67f09SDavid van Moolenbroek 	isc_mem_destroy(&mctx);
300*00b67f09SDavid van Moolenbroek 
301*00b67f09SDavid van Moolenbroek 	return (0);
302*00b67f09SDavid van Moolenbroek }
303