Annotation of embedaddon/ipsec-tools/src/racoon/localconf.c, revision 1.1.1.1
1.1 misho 1: /* $NetBSD: localconf.c,v 1.7 2008/12/23 14:04:42 tteras Exp $ */
2:
3: /* $KAME: localconf.c,v 1.33 2001/08/09 07:32:19 sakane Exp $ */
4:
5: /*
6: * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
7: * All rights reserved.
8: *
9: * Redistribution and use in source and binary forms, with or without
10: * modification, are permitted provided that the following conditions
11: * are met:
12: * 1. Redistributions of source code must retain the above copyright
13: * notice, this list of conditions and the following disclaimer.
14: * 2. Redistributions in binary form must reproduce the above copyright
15: * notice, this list of conditions and the following disclaimer in the
16: * documentation and/or other materials provided with the distribution.
17: * 3. Neither the name of the project nor the names of its contributors
18: * may be used to endorse or promote products derived from this software
19: * without specific prior written permission.
20: *
21: * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND
22: * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23: * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24: * ARE DISCLAIMED. IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE
25: * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26: * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27: * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28: * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29: * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30: * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31: * SUCH DAMAGE.
32: */
33:
34: #include "config.h"
35:
36: #include <sys/types.h>
37: #include <sys/param.h>
38:
39: #include <stdlib.h>
40: #include <stdio.h>
41: #include <string.h>
42: #include <errno.h>
43: #include <ctype.h>
44: #include <err.h>
45:
46: #include "var.h"
47: #include "misc.h"
48: #include "vmbuf.h"
49: #include "plog.h"
50: #include "debug.h"
51:
52: #include "localconf.h"
53: #include "algorithm.h"
54: #include "admin.h"
55: #include "privsep.h"
56: #include "isakmp_var.h"
57: #include "isakmp.h"
58: #include "ipsec_doi.h"
59: #include "grabmyaddr.h"
60: #include "vendorid.h"
61: #include "str2val.h"
62: #include "safefile.h"
63: #include "admin.h"
64: #include "gcmalloc.h"
65:
66: struct localconf *lcconf;
67:
68: static void setdefault __P((void));
69:
70: void
71: initlcconf()
72: {
73: lcconf = racoon_calloc(1, sizeof(*lcconf));
74: if (lcconf == NULL)
75: errx(1, "failed to allocate local conf.");
76:
77: setdefault();
78:
79: lcconf->racoon_conf = LC_DEFAULT_CF;
80: }
81:
82: void
83: flushlcconf()
84: {
85: int i;
86:
87: setdefault();
88: myaddr_flush();
89:
90: for (i = 0; i < LC_PATHTYPE_MAX; i++) {
91: if (lcconf->pathinfo[i]) {
92: racoon_free(lcconf->pathinfo[i]);
93: lcconf->pathinfo[i] = NULL;
94: }
95: }
96: }
97:
98: static void
99: setdefault()
100: {
101: lcconf->uid = 0;
102: lcconf->gid = 0;
103: lcconf->chroot = NULL;
104: lcconf->port_isakmp = PORT_ISAKMP;
105: lcconf->port_isakmp_natt = PORT_ISAKMP_NATT;
106: lcconf->default_af = AF_INET;
107: lcconf->pad_random = LC_DEFAULT_PAD_RANDOM;
108: lcconf->pad_randomlen = LC_DEFAULT_PAD_RANDOMLEN;
109: lcconf->pad_maxsize = LC_DEFAULT_PAD_MAXSIZE;
110: lcconf->pad_strict = LC_DEFAULT_PAD_STRICT;
111: lcconf->pad_excltail = LC_DEFAULT_PAD_EXCLTAIL;
112: lcconf->retry_counter = LC_DEFAULT_RETRY_COUNTER;
113: lcconf->retry_interval = LC_DEFAULT_RETRY_INTERVAL;
114: lcconf->count_persend = LC_DEFAULT_COUNT_PERSEND;
115: lcconf->secret_size = LC_DEFAULT_SECRETSIZE;
116: lcconf->retry_checkph1 = LC_DEFAULT_RETRY_CHECKPH1;
117: lcconf->wait_ph2complete = LC_DEFAULT_WAIT_PH2COMPLETE;
118: lcconf->strict_address = FALSE;
119: lcconf->complex_bundle = TRUE; /*XXX FALSE;*/
120: lcconf->gss_id_enc = LC_GSSENC_UTF16LE; /* Windows compatibility */
121: lcconf->natt_ka_interval = LC_DEFAULT_NATT_KA_INTERVAL;
122: lcconf->pfkey_buffer_size = LC_DEFAULT_PFKEY_BUFFER_SIZE;
123: }
124:
125: /*
126: * get PSK by string.
127: */
128: vchar_t *
129: getpskbyname(id0)
130: vchar_t *id0;
131: {
132: char *id;
133: vchar_t *key = NULL;
134:
135: id = racoon_calloc(1, 1 + id0->l - sizeof(struct ipsecdoi_id_b));
136: if (id == NULL) {
137: plog(LLV_ERROR, LOCATION, NULL,
138: "failed to get psk buffer.\n");
139: goto end;
140: }
141: memcpy(id, id0->v + sizeof(struct ipsecdoi_id_b),
142: id0->l - sizeof(struct ipsecdoi_id_b));
143: id[id0->l - sizeof(struct ipsecdoi_id_b)] = '\0';
144:
145: key = privsep_getpsk(id, id0->l - sizeof(struct ipsecdoi_id_b));
146:
147: end:
148: if (id)
149: racoon_free(id);
150: return key;
151: }
152:
153: /*
154: * get PSK by address.
155: */
156: vchar_t *
157: getpskbyaddr(remote)
158: struct sockaddr *remote;
159: {
160: vchar_t *key = NULL;
161: char addr[NI_MAXHOST], port[NI_MAXSERV];
162:
163: GETNAMEINFO(remote, addr, port);
164:
165: key = privsep_getpsk(addr, strlen(addr));
166:
167: return key;
168: }
169:
170: vchar_t *
171: getpsk(str, len)
172: const char *str;
173: const int len;
174: {
175: FILE *fp;
176: char buf[1024]; /* XXX how is variable length ? */
177: vchar_t *key = NULL;
178: char *p, *q;
179: size_t keylen;
180: char *k = NULL;
181:
182: if (safefile(lcconf->pathinfo[LC_PATHTYPE_PSK], 1) == 0)
183: fp = fopen(lcconf->pathinfo[LC_PATHTYPE_PSK], "r");
184: else
185: fp = NULL;
186: if (fp == NULL) {
187: plog(LLV_ERROR, LOCATION, NULL,
188: "failed to open pre_share_key file %s\n",
189: lcconf->pathinfo[LC_PATHTYPE_PSK]);
190: return NULL;
191: }
192:
193: while (fgets(buf, sizeof(buf), fp) != NULL) {
194: /* comment line */
195: if (buf[0] == '#')
196: continue;
197:
198: /* search the end of 1st string. */
199: for (p = buf; *p != '\0' && !isspace((int)*p); p++)
200: ;
201: if (*p == '\0')
202: continue; /* no 2nd parameter */
203: *p = '\0';
204: /* search the 1st of 2nd string. */
205: while (isspace((int)*++p))
206: ;
207: if (*p == '\0')
208: continue; /* no 2nd parameter */
209: p--;
210: if (strncmp(buf, str, len) == 0 && buf[len] == '\0') {
211: p++;
212: keylen = 0;
213: for (q = p; *q != '\0' && *q != '\n'; q++)
214: keylen++;
215: *q = '\0';
216:
217: /* fix key if hex string */
218: if (strncmp(p, "0x", 2) == 0) {
219: k = str2val(p + 2, 16, &keylen);
220: if (k == NULL) {
221: plog(LLV_ERROR, LOCATION, NULL,
222: "failed to get psk buffer.\n");
223: goto end;
224: }
225: p = k;
226: }
227:
228: key = vmalloc(keylen);
229: if (key == NULL) {
230: plog(LLV_ERROR, LOCATION, NULL,
231: "failed to allocate key buffer.\n");
232: goto end;
233: }
234: memcpy(key->v, p, key->l);
235: if (k)
236: racoon_free(k);
237: goto end;
238: }
239: }
240:
241: end:
242: fclose(fp);
243: return key;
244: }
245:
246: /*
247: * get a file name of a type specified.
248: */
249: void
250: getpathname(path, len, type, name)
251: char *path;
252: int len, type;
253: const char *name;
254: {
255: snprintf(path, len, "%s%s%s",
256: name[0] == '/' ? "" : lcconf->pathinfo[type],
257: name[0] == '/' ? "" : "/",
258: name);
259:
260: plog(LLV_DEBUG, LOCATION, NULL, "filename: %s\n", path);
261: }
262:
263: #if 0 /* DELETEIT */
264: static int lc_doi2idtype[] = {
265: -1,
266: -1,
267: LC_IDENTTYPE_FQDN,
268: LC_IDENTTYPE_USERFQDN,
269: -1,
270: -1,
271: -1,
272: -1,
273: -1,
274: LC_IDENTTYPE_CERTNAME,
275: -1,
276: LC_IDENTTYPE_KEYID,
277: };
278:
279: /*
280: * convert DOI value to idtype
281: * OUT -1 : NG
282: * other: converted.
283: */
284: int
285: doi2idtype(idtype)
286: int idtype;
287: {
288: if (ARRAYLEN(lc_doi2idtype) > idtype)
289: return lc_doi2idtype[idtype];
290: return -1;
291: }
292: #endif
293:
294: static int lc_sittype2doi[] = {
295: IPSECDOI_SIT_IDENTITY_ONLY,
296: IPSECDOI_SIT_SECRECY,
297: IPSECDOI_SIT_INTEGRITY,
298: };
299:
300: /*
301: * convert sittype to DOI value.
302: * OUT -1 : NG
303: * other: converted.
304: */
305: int
306: sittype2doi(sittype)
307: int sittype;
308: {
309: if (ARRAYLEN(lc_sittype2doi) > sittype)
310: return lc_sittype2doi[sittype];
311: return -1;
312: }
313:
314: static int lc_doitype2doi[] = {
315: IPSEC_DOI,
316: };
317:
318: /*
319: * convert doitype to DOI value.
320: * OUT -1 : NG
321: * other: converted.
322: */
323: int
324: doitype2doi(doitype)
325: int doitype;
326: {
327: if (ARRAYLEN(lc_doitype2doi) > doitype)
328: return lc_doitype2doi[doitype];
329: return -1;
330: }
331:
332:
333:
334: static void
335: saverestore_params(f)
336: int f;
337: {
338: static u_int16_t s_port_isakmp;
339:
340: /* 0: save, 1: restore */
341: if (f) {
342: lcconf->port_isakmp = s_port_isakmp;
343: } else {
344: s_port_isakmp = lcconf->port_isakmp;
345: }
346: }
347:
348: void
349: restore_params()
350: {
351: saverestore_params(1);
352: }
353:
354: void
355: save_params()
356: {
357: saverestore_params(0);
358: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>