summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sbin/isakmpd/policy.c34
-rw-r--r--sbin/isakmpd/policy.h6
2 files changed, 37 insertions, 3 deletions
diff --git a/sbin/isakmpd/policy.c b/sbin/isakmpd/policy.c
index f5e0670337b..f127f549882 100644
--- a/sbin/isakmpd/policy.c
+++ b/sbin/isakmpd/policy.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: policy.c,v 1.28 2001/04/09 12:34:38 ho Exp $ */
+/* $OpenBSD: policy.c,v 1.29 2001/05/31 20:21:08 angelos Exp $ */
/* $EOM: policy.c,v 1.49 2000/10/24 13:33:39 niklas Exp $ */
/*
@@ -1605,12 +1605,13 @@ keynote_cert_init (void)
void *
keynote_cert_get (u_int8_t *data, u_int32_t len)
{
- char *foo = calloc (len + 1, sizeof (char));
+ char *foo = malloc (len + 1);
if (foo == NULL)
return NULL;
memcpy (foo, data, len);
+ foo[len] = '\0';
return foo;
}
@@ -1876,3 +1877,32 @@ keynote_cert_get_key (void *scert, void *keyp)
LK (kn_remove_assertion, (keynote_sessid, sid));
return *(RSA **)keyp == NULL ? 0 : 1;
}
+
+void *
+keynote_cert_dup (void *cert)
+{
+ return strdup((char *)cert);
+}
+
+void
+keynote_serialize (void *cert, u_int8_t **data, u_int32_t *datalen)
+{
+ *datalen = strlen ((char *)cert) + 1;
+ *data = strdup (cert); /* So we allocate an extra character at the end... */
+ if (*data == NULL)
+ log_error ("keynote_serialize: malloc (%d) failed", *datalen);
+}
+
+/* From cert to printable */
+char *
+keynote_printable (void *cert)
+{
+ return strdup ((char *)cert);
+}
+
+/* From printable to cert */
+void *
+keynote_from_printable (char *cert)
+{
+ return strdup (cert);
+}
diff --git a/sbin/isakmpd/policy.h b/sbin/isakmpd/policy.h
index ad7ec86ee92..3cd005fee27 100644
--- a/sbin/isakmpd/policy.h
+++ b/sbin/isakmpd/policy.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: policy.h,v 1.7 2000/10/07 06:57:08 niklas Exp $ */
+/* $OpenBSD: policy.h,v 1.8 2001/05/31 20:21:08 angelos Exp $ */
/* $EOM: policy.h,v 1.12 2000/09/28 12:53:27 niklas Exp $ */
/*
@@ -104,4 +104,8 @@ extern int keynote_cert_obtain (u_int8_t *, size_t, void *,
extern int keynote_cert_get_subjects (void *, int *, u_int8_t ***,
u_int32_t **);
extern int keynote_cert_get_key (void *, void *);
+extern void *keynote_cert_dup (void *);
+extern void keynote_serialize (void *, u_int8_t **, u_int32_t *);
+extern char *keynote_printable (void *);
+extern void *keynote_from_printable (char *);
#endif /* _POLICY_H_ */