summaryrefslogtreecommitdiff
path: root/sbin
diff options
context:
space:
mode:
Diffstat (limited to 'sbin')
-rw-r--r--sbin/isakmpd/conf.c72
1 files changed, 42 insertions, 30 deletions
diff --git a/sbin/isakmpd/conf.c b/sbin/isakmpd/conf.c
index a11970988d5..92b2bf12680 100644
--- a/sbin/isakmpd/conf.c
+++ b/sbin/isakmpd/conf.c
@@ -1,5 +1,5 @@
-/* $OpenBSD: conf.c,v 1.21 2000/10/13 13:22:01 niklas Exp $ */
-/* $EOM: conf.c,v 1.40 2000/10/13 13:04:16 ho Exp $ */
+/* $OpenBSD: conf.c,v 1.22 2000/10/16 23:28:56 niklas Exp $ */
+/* $EOM: conf.c,v 1.44 2000/10/14 08:45:18 angelos Exp $ */
/*
* Copyright (c) 1998, 1999, 2000 Niklas Hallqvist. All rights reserved.
@@ -45,6 +45,7 @@
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
+#include <errno.h>
#include "sysdep.h"
@@ -308,7 +309,7 @@ conf_parse (int trans, char *buf, size_t sz)
* For main mode:
* {DES,BLF,3DES,CAST}-{MD5,SHA}[-{DSS,RSA_SIG}]
* For quick mode:
- * QM-{ESP,AH}[-TRP]-{DES,3DES,CAST,BLF,AES}[-{MD5,SHA}][-PFS]-SUITE
+ * QM-{ESP,AH}[-TRP]-{DES,3DES,CAST,BLF,AES}[-{MD5,SHA,RIPEMD}][-PFS]-SUITE
* DH groups; currently always MODP_768 for MD5, and MODP_1024 for SHA.
*
* XXX We may want to support USE_BLOWFISH, USE_TRIPLEDES, etc...
@@ -349,13 +350,13 @@ conf_load_defaults (int tr)
"CAST_CBC", NULL };
char *dh_group[] = { "MODP_768", "MODP_1024", "MODP_1536", NULL };
char *qm_enc[] = { "DES", "3DES", "CAST", "BLOWFISH", "AES", NULL };
- char *qm_hash[] = { "HMAC_MD5", "HMAC_SHA", "NONE", NULL };
+ char *qm_hash[] = { "HMAC_MD5", "HMAC_SHA", "HMAC_RIPEMD", "NONE", NULL };
/* Abbreviations to make section names a bit shorter. */
char *mm_auth_p[] = { "", "-DSS", "-RSA_SIG", NULL };
char *mm_enc_p[] = { "DES", "BLF", "3DES", "CAST", NULL };
char *qm_enc_p[] = { "-DES", "-3DES", "-CAST", "-BLF", "-AES", NULL };
- char *qm_hash_p[] = { "-MD5", "-SHA", "", NULL };
+ char *qm_hash_p[] = { "-MD5", "-SHA", "-RIPEMD", "", NULL };
/* Helper #defines, incl abbreviations. */
#define PROTO(x) ((x) ? "AH" : "ESP")
@@ -390,8 +391,10 @@ conf_load_defaults (int tr)
sprintf (sect, "%s-%s%s", mm_enc_p[enc], mm_hash[hash],
mm_auth_p[auth]);
+#if 0
if (!conf_find_trans_xf (1, sect))
continue;
+#endif
LOG_DBG ((LOG_MISC, 40, "conf_load_defaults : main mode %s", sect));
@@ -427,8 +430,10 @@ conf_load_defaults (int tr)
strcpy (sect, tmp);
strcat (sect, "-SUITE");
+#if 0
if (!conf_find_trans_xf (2, sect))
continue;
+#endif
LOG_DBG ((LOG_MISC, 40, "conf_load_defaults : quick mode %s",
sect));
@@ -503,36 +508,43 @@ conf_reinit (void)
int fd, i, trans;
off_t sz;
char *new_conf_addr = 0;
+ struct stat sb;
- if (check_file_secrecy (conf_path, &sz))
- return;
-
- fd = open (conf_path, O_RDONLY);
- if (fd == -1)
+ if ((lstat (conf_path, &sb) == 0) || (errno != ENOENT))
{
- log_error ("conf_reinit: open (\"%s\", O_RDONLY) failed", conf_path);
- return;
- }
+ if (check_file_secrecy (conf_path, &sz))
+ return;
- new_conf_addr = malloc (sz);
- if (!new_conf_addr)
- {
- log_error ("conf_reinit: malloc (%d) failed", sz);
- goto fail;
- }
- /* XXX I assume short reads won't happen here. */
- if (read (fd, new_conf_addr, sz) != sz)
- {
- log_error ("conf_reinit: read (%d, %p, %d) failed", fd, new_conf_addr,
- sz);
- goto fail;
- }
- close (fd);
+ fd = open (conf_path, O_RDONLY);
+ if (fd == -1)
+ {
+ log_error ("conf_reinit: open (\"%s\", O_RDONLY) failed", conf_path);
+ return;
+ }
- trans = conf_begin ();
+ new_conf_addr = malloc (sz);
+ if (!new_conf_addr)
+ {
+ log_error ("conf_reinit: malloc (%d) failed", sz);
+ goto fail;
+ }
+
+ /* XXX I assume short reads won't happen here. */
+ if (read (fd, new_conf_addr, sz) != sz)
+ {
+ log_error ("conf_reinit: read (%d, %p, %d) failed",
+ fd, new_conf_addr, sz);
+ goto fail;
+ }
+ close (fd);
- /* XXX Should we not care about errors and rollback? */
- conf_parse (trans, new_conf_addr, sz);
+ trans = conf_begin ();
+
+ /* XXX Should we not care about errors and rollback? */
+ conf_parse (trans, new_conf_addr, sz);
+ }
+ else
+ trans = conf_begin ();
/* Load default configuration values. */
conf_load_defaults (trans);