aboutsummaryrefslogtreecommitdiffstats
path: root/src/libcharon/encoding/payloads/cert_payload.c
diff options
context:
space:
mode:
authorClavister OpenSource <opensource@clavister.com>2011-11-23 08:04:52 +0100
committerClavister OpenSource <opensource@clavister.com>2012-03-20 17:30:49 +0100
commit9769b76cabbca4b97bcccfe69b6455c8c0c162ad (patch)
treefa45d88a271e532fbd5d00d64527f4e21bb10c8f /src/libcharon/encoding/payloads/cert_payload.c
parentd50152a70bb109624d05249e11dda6c28a9a6422 (diff)
downloadstrongswan-9769b76cabbca4b97bcccfe69b6455c8c0c162ad.tar.bz2
strongswan-9769b76cabbca4b97bcccfe69b6455c8c0c162ad.tar.xz
Updated the CERT payload to work for both IKEv1 and IKEv2.
Diffstat (limited to 'src/libcharon/encoding/payloads/cert_payload.c')
-rw-r--r--src/libcharon/encoding/payloads/cert_payload.c24
1 files changed, 15 insertions, 9 deletions
diff --git a/src/libcharon/encoding/payloads/cert_payload.c b/src/libcharon/encoding/payloads/cert_payload.c
index 1ef93b724..cf97e9613 100644
--- a/src/libcharon/encoding/payloads/cert_payload.c
+++ b/src/libcharon/encoding/payloads/cert_payload.c
@@ -86,6 +86,11 @@ struct private_cert_payload_t {
* TRUE if the "Hash and URL" data is invalid
*/
bool invalid_hash_and_url;
+
+ /**
+ * The payload type.
+ */
+ payload_type_t type;
};
/**
@@ -182,7 +187,7 @@ METHOD(payload_t, get_header_length, int,
METHOD(payload_t, get_type, payload_type_t,
private_cert_payload_t *this)
{
- return CERTIFICATE;
+ return this->type;
}
METHOD(payload_t, get_next_type, payload_type_t,
@@ -267,7 +272,7 @@ METHOD2(payload_t, cert_payload_t, destroy, void,
/*
* Described in header
*/
-cert_payload_t *cert_payload_create()
+cert_payload_t *cert_payload_create(payload_type_t type)
{
private_cert_payload_t *this;
@@ -291,6 +296,7 @@ cert_payload_t *cert_payload_create()
},
.next_payload = NO_PAYLOAD,
.payload_length = get_header_length(this),
+ .type = type,
);
return &this->public;
}
@@ -298,9 +304,9 @@ cert_payload_t *cert_payload_create()
/*
* Described in header
*/
-cert_payload_t *cert_payload_create_from_cert(certificate_t *cert)
+cert_payload_t *cert_payload_create_from_cert(certificate_t *cert, payload_type_t type)
{
- private_cert_payload_t *this = (private_cert_payload_t*)cert_payload_create();
+ private_cert_payload_t *this = (private_cert_payload_t*)cert_payload_create(type);
switch (cert->get_type(cert))
{
@@ -326,9 +332,9 @@ cert_payload_t *cert_payload_create_from_cert(certificate_t *cert)
/*
* Described in header
*/
-cert_payload_t *cert_payload_create_from_hash_and_url(chunk_t hash, char *url)
+cert_payload_t *cert_payload_create_from_hash_and_url(chunk_t hash, char *url, payload_type_t type)
{
- private_cert_payload_t *this = (private_cert_payload_t*)cert_payload_create();
+ private_cert_payload_t *this = (private_cert_payload_t*)cert_payload_create(type);
this->encoding = ENC_X509_HASH_AND_URL;
this->data = chunk_cat("cc", hash, chunk_create(url, strlen(url)));
@@ -339,11 +345,11 @@ cert_payload_t *cert_payload_create_from_hash_and_url(chunk_t hash, char *url)
/*
* Described in header
*/
-cert_payload_t *cert_payload_create_custom(cert_encoding_t type, chunk_t data)
+cert_payload_t *cert_payload_create_custom(cert_encoding_t encoding, chunk_t data, payload_type_t type)
{
- private_cert_payload_t *this = (private_cert_payload_t*)cert_payload_create();
+ private_cert_payload_t *this = (private_cert_payload_t*)cert_payload_create(type);
- this->encoding = type;
+ this->encoding = encoding;
this->data = data;
this->payload_length = get_header_length(this) + this->data.len;
return &this->public;