]> git.ipfire.org Git - thirdparty/strongswan.git/commitdiff
Add an IMV constructor taking a set of custom TNC_IMV functions
authorMartin Willi <martin@revosec.ch>
Wed, 14 Nov 2012 11:30:19 +0000 (12:30 +0100)
committerMartin Willi <martin@revosec.ch>
Fri, 30 Nov 2012 14:48:02 +0000 (15:48 +0100)
src/libcharon/plugins/tnc_imc/tnc_imc.h
src/libcharon/plugins/tnc_imv/tnc_imv.c
src/libcharon/plugins/tnc_imv/tnc_imv.h

index ff606a822602e6fd931daa2bd882a518c3efc114..2d4607e777d1f29a829d9b5f90e2fcec5ea422e7 100644 (file)
@@ -36,8 +36,16 @@ imc_t* tnc_imc_create(char *name, char *filename);
 /**
  * Create an Integrity Measurement Collector from a set of IMC functions.
  *
- * @param name                 name of the IMC
- * @return                             instance of the imc_t interface
+ * @param name                                         name of the IMC
+ * @param initialize                           TNC_IMC_InitializePointer
+ * @param notify_connection_change     TNC_IMC_NotifyConnectionChangePointer
+ * @param begin_handshake                      TNC_IMC_BeginHandshakePointer
+ * @param receive_message                      TNC_IMC_ReceiveMessagePointer
+ * @param receive_message_long         TNC_IMC_ReceiveMessageLongPointer
+ * @param batch_ending                         TNC_IMC_BatchEndingPointer
+ * @param terminate                                    TNC_IMC_TerminatePointer
+ * @param provide_bind_function                TNC_IMC_ProvideBindFunctionPointer
+ * @return                                                     instance of the imc_t interface
  */
 imc_t* tnc_imc_create_from_functions(char *name,
                                TNC_IMC_InitializePointer initialize,
index 567756ea18c33dd5af96de4211f681f7810cca04..f7b1276eec4568070868019d7e9782cf1149c0c7 100644 (file)
@@ -311,9 +311,9 @@ METHOD(imv_t, destroy, void,
 }
 
 /**
- * Described in header.
+ * Generic constructor.
  */
-imv_t* tnc_imv_create(char *name, char *path)
+static private_tnc_imv_t* tnc_imv_create_empty(char *name)
 {
        private_tnc_imv_t *this;
 
@@ -334,6 +334,18 @@ imv_t* tnc_imv_create(char *name, char *path)
                .mutex = mutex_create(MUTEX_TYPE_DEFAULT),
        );
 
+       return this;
+}
+
+/**
+ * Described in header.
+ */
+imv_t* tnc_imv_create(char *name, char *path)
+{
+       private_tnc_imv_t *this;
+
+       this = tnc_imv_create_empty(name);
+
        this->handle = dlopen(path, RTLD_LAZY);
        if (!this->handle)
        {
@@ -381,3 +393,32 @@ imv_t* tnc_imv_create(char *name, char *path)
 
        return &this->public;
 }
+
+/**
+ * Described in header.
+ */
+imv_t* tnc_imv_create_from_functions(char *name,
+                               TNC_IMV_InitializePointer initialize,
+                               TNC_IMV_NotifyConnectionChangePointer notify_connection_change,
+                               TNC_IMV_ReceiveMessagePointer receive_message,
+                               TNC_IMV_ReceiveMessageLongPointer receive_message_long,
+                               TNC_IMV_SolicitRecommendationPointer solicit_recommendation,
+                               TNC_IMV_BatchEndingPointer batch_ending,
+                               TNC_IMV_TerminatePointer terminate,
+                               TNC_IMV_ProvideBindFunctionPointer provide_bind_function)
+{
+       private_tnc_imv_t *this;
+
+       this = tnc_imv_create_empty(name);
+
+       this->public.initialize = initialize;
+       this->public.notify_connection_change = notify_connection_change;
+       this->public.receive_message = receive_message;
+       this->public.receive_message_long = receive_message_long;
+       this->public.solicit_recommendation = solicit_recommendation;
+       this->public.batch_ending = batch_ending;
+       this->public.terminate = terminate;
+       this->public.provide_bind_function = provide_bind_function;
+
+       return &this->public;
+}
index 75939e54c3762a1abf326ba425ce3a832ca6742d..e7c7b8b4fb692c482d0395014c115d859fd6f8a5 100644 (file)
@@ -25,7 +25,7 @@
 #include <tnc/imv/imv.h>
 
 /**
- * Create an Integrity Measurement Verifier.
+ * Create an Integrity Measurement Verifier loaded from a library.
  *
  * @param name                 name of the IMV
  * @param filename             path to the dynamic IMV library
  */
 imv_t* tnc_imv_create(char *name, char *filename);
 
+/**
+ * Create an Integrity Measurement Verifier from a set of IMV functions.
+ *
+ * @param name                                         name of the IMV
+ * @param initialize                           TNC_IMV_InitializePointer
+ * @param notify_connection_change     TNC_IMV_NotifyConnectionChangePointer
+ * @param receive_message                      TNC_IMV_ReceiveMessagePointer
+ * @param receive_message_long         TNC_IMV_ReceiveMessageLongPointer
+ * @param solicit_recommendation       TNC_IMV_SolicitRecommendationPointer
+ * @param batch_ending                         TNC_IMV_BatchEndingPointer
+ * @param terminate                                    TNC_IMV_TerminatePointer
+ * @param provide_bind_function                TNC_IMV_ProvideBindFunctionPointer
+ * @return                                                     instance of the imv_t interface
+ */
+imv_t* tnc_imv_create_from_functions(char *name,
+                               TNC_IMV_InitializePointer initialize,
+                               TNC_IMV_NotifyConnectionChangePointer notify_connection_change,
+                               TNC_IMV_ReceiveMessagePointer receive_message,
+                               TNC_IMV_ReceiveMessageLongPointer receive_message_long,
+                               TNC_IMV_SolicitRecommendationPointer solicit_recommendation,
+                               TNC_IMV_BatchEndingPointer batch_ending,
+                               TNC_IMV_TerminatePointer terminate,
+                               TNC_IMV_ProvideBindFunctionPointer provide_bind_function);
+
 #endif /** TNC_IMV_H_ @}*/