aboutsummaryrefslogtreecommitdiffstats
path: root/src/libcharon/attributes/attribute_handler.h
diff options
context:
space:
mode:
authorMartin Willi <martin@revosec.ch>2014-11-04 15:53:50 +0100
committerMartin Willi <martin@revosec.ch>2015-02-20 13:34:56 +0100
commitb9be25ea394f3f18d1e7ffc22f10dfe80d67e2fa (patch)
tree28dddaedb702fb87eb2b49c1183348c05a2b7de4 /src/libcharon/attributes/attribute_handler.h
parentbc9ded9dbf39d064c3ff2239d9904566ff5888d6 (diff)
downloadstrongswan-b9be25ea394f3f18d1e7ffc22f10dfe80d67e2fa.tar.bz2
strongswan-b9be25ea394f3f18d1e7ffc22f10dfe80d67e2fa.tar.xz
attribute-handler: Pass full IKE_SA to handler backends
Diffstat (limited to 'src/libcharon/attributes/attribute_handler.h')
-rw-r--r--src/libcharon/attributes/attribute_handler.h20
1 files changed, 12 insertions, 8 deletions
diff --git a/src/libcharon/attributes/attribute_handler.h b/src/libcharon/attributes/attribute_handler.h
index bc488f6cb..3c14323a3 100644
--- a/src/libcharon/attributes/attribute_handler.h
+++ b/src/libcharon/attributes/attribute_handler.h
@@ -21,14 +21,14 @@
#ifndef ATTRIBUTE_HANDLER_H_
#define ATTRIBUTE_HANDLER_H_
+typedef struct attribute_handler_t attribute_handler_t;
+
+#include <sa/ike_sa.h>
#include <utils/chunk.h>
-#include <utils/identification.h>
#include <collections/linked_list.h>
#include "attributes.h"
-typedef struct attribute_handler_t attribute_handler_t;
-
/**
* Interface to handle configuration payload attributes.
*/
@@ -40,12 +40,12 @@ struct attribute_handler_t {
* After receiving a configuration attriubte, it is passed to each
* attribute handler until it is handled.
*
- * @param server server from which the attribute was received
+ * @param ike_sa IKE_SA under which attribute is received
* @param type type of configuration attribute to handle
* @param data associated attribute data
* @return TRUE if attribute handled
*/
- bool (*handle)(attribute_handler_t *this, identification_t *server,
+ bool (*handle)(attribute_handler_t *this, ike_sa_t *ike_sa,
configuration_attribute_type_t type, chunk_t data);
/**
@@ -54,19 +54,23 @@ struct attribute_handler_t {
* A handler that handle()d an attribute gets a call to release() when the
* connection gets closed. Depending on the implementation, this is required
* to remove the attribute.
+ *
+ * @param ike_sa IKE_SA which releases attribute
+ * @param type type of configuration attribute to release
+ * @param data associated attribute data
*/
- void (*release)(attribute_handler_t *this, identification_t *server,
+ void (*release)(attribute_handler_t *this, ike_sa_t *ike_sa,
configuration_attribute_type_t type, chunk_t data);
/**
* Enumerate attributes to request from a server.
*
- * @param server server identity to request attributes from
+ * @param ike_sa IKE_SA to request attributes for
* @param vips list of virtual IPs (host_t*) we are requesting
* @return enumerator (configuration_attribute_type_t, chunk_t)
*/
enumerator_t* (*create_attribute_enumerator)(attribute_handler_t *this,
- identification_t *server, linked_list_t *vips);
+ ike_sa_t *ike_sa, linked_list_t *vips);
};
#endif /** ATTRIBUTE_HANDLER_H_ @}*/