aboutsummaryrefslogtreecommitdiffstats
path: root/src/pluto
diff options
context:
space:
mode:
authorMartin Willi <martin@strongswan.org>2009-08-12 17:27:15 +0200
committerMartin Willi <martin@strongswan.org>2009-08-26 11:23:49 +0200
commit11aa7e78694463a6cfa20d8a780d37b1435a456f (patch)
treed2067abd16a54d60b5e936ae0991d45fff55f5ca /src/pluto
parentc486fa8158721653f5ed4b874e6b1baa49bf7c7c (diff)
downloadstrongswan-11aa7e78694463a6cfa20d8a780d37b1435a456f.tar.bz2
strongswan-11aa7e78694463a6cfa20d8a780d37b1435a456f.tar.xz
use a pluto specific credential builder to build pluto cert_t's
Diffstat (limited to 'src/pluto')
-rw-r--r--src/pluto/certs.c97
1 files changed, 79 insertions, 18 deletions
diff --git a/src/pluto/certs.c b/src/pluto/certs.c
index fcc9ec577..b004a5094 100644
--- a/src/pluto/certs.c
+++ b/src/pluto/certs.c
@@ -215,53 +215,114 @@ private_key_t* load_private_key(char* filename, prompt_pass_t *pass,
}
/**
- * Loads a X.509 or OpenPGP certificate
+ * currently building cert_t
*/
-bool load_cert(char *filename, const char *label, cert_t *cert)
+static cert_t *cert_builder_cert;
+
+/**
+ * builder add function
+ */
+static void add(builder_t *this, builder_part_t part, ...)
{
- bool pgp = FALSE;
- chunk_t blob = chunk_empty;
+ chunk_t blob;
+ va_list args;
- /* initialize cert struct */
- cert->type = CERT_NONE;
- cert->u.x509 = NULL;
+ va_start(args, part);
+ blob = va_arg(args, chunk_t);
+ va_end(args);
- if (load_coded_file(filename, NULL, label, &blob, &pgp))
+ switch (part)
{
- if (pgp)
+ case BUILD_BLOB_PGP:
{
pgpcert_t *pgpcert = malloc_thing(pgpcert_t);
*pgpcert = pgpcert_empty;
if (parse_pgp(blob, pgpcert))
{
- cert->type = CERT_PGP;
- cert->u.pgp = pgpcert;
- return TRUE;
+ cert_builder_cert->type = CERT_PGP;
+ cert_builder_cert->u.pgp = pgpcert;
}
else
{
plog(" error in OpenPGP certificate");
free_pgpcert(pgpcert);
- return FALSE;
}
+ break;
}
- else
+ case BUILD_BLOB_ASN1_DER:
{
x509cert_t *x509cert = malloc_thing(x509cert_t);
*x509cert = empty_x509cert;
if (parse_x509cert(blob, 0, x509cert))
{
- cert->type = CERT_X509_SIGNATURE;
- cert->u.x509 = x509cert;
- return TRUE;
+ cert_builder_cert->type = CERT_X509_SIGNATURE;
+ cert_builder_cert->u.x509 = x509cert;
}
else
{
plog(" error in X.509 certificate");
free_x509cert(x509cert);
- return FALSE;
}
+ break;
}
+ default:
+ builder_cancel(this);
+ break;
+ }
+}
+
+/**
+ * builder build function
+ */
+static void *build(builder_t *this)
+{
+ free(this);
+ if (cert_builder_cert->type == CERT_NONE)
+ {
+ return NULL;
+ }
+ return cert_builder_cert;
+}
+
+/**
+ * certificate builder in cert_t format.
+ */
+static builder_t *cert_builder(credential_type_t type, int subtype)
+{
+ builder_t *this;
+
+ if (subtype != 1)
+ {
+ return NULL;
+ }
+ this = malloc_thing(builder_t);
+ this->add = add;
+ this->build = build;
+
+ return this;
+}
+
+/**
+ * Loads a X.509 or OpenPGP certificate
+ */
+bool load_cert(char *filename, const char *label, cert_t *cert)
+{
+ cert_builder_cert = cert;
+
+ cert->type = CERT_NONE;
+ cert->u.x509 = NULL;
+ cert->u.pgp = NULL;
+
+ /* hook in builder functions to build pluto specific certificate format */
+ lib->creds->add_builder(lib->creds, CRED_PLUTO_CERT, 1,
+ (builder_constructor_t)cert_builder);
+ cert = lib->creds->create(lib->creds, CRED_PLUTO_CERT, 1,
+ BUILD_FROM_FILE, filename, BUILD_END);
+ lib->creds->remove_builder(lib->creds,
+ (builder_constructor_t)cert_builder);
+ if (cert)
+ {
+ return TRUE;
}
return FALSE;
}