moved management of additional IMC/IMV IDs to agent
[strongswan.git] / src / libimcv / plugins / imc_test / imc_test_state.c
index ade1fc1..2adfd7d 100644 (file)
@@ -15,6 +15,7 @@
 #include "imc_test_state.h"
 
 #include <debug.h>
+#include <utils/linked_list.h>
 
 typedef struct private_imc_test_state_t private_imc_test_state_t;
 
@@ -39,14 +40,30 @@ struct private_imc_test_state_t {
        TNC_ConnectionState state;
 
        /**
+        * Does the TNCCS connection support long message types?
+        */
+       bool has_long;
+
+       /**
+        * Does the TNCCS connection support exclusive delivery?
+        */
+       bool has_excl;
+
+       /**
         * Command to transmit to IMV
         */
        char *command;
 
        /**
+        * Is it the first handshake?
+        */
+       bool first_handshake;
+
+       /**
         * Do a handshake retry
         */
        bool handshake_retry;
+       
 };
 
 METHOD(imc_state_t, get_connection_id, TNC_ConnectionID,
@@ -55,6 +72,25 @@ METHOD(imc_state_t, get_connection_id, TNC_ConnectionID,
        return this->connection_id;
 }
 
+METHOD(imc_state_t, has_long, bool,
+       private_imc_test_state_t *this)
+{
+       return this->has_long;
+}
+
+METHOD(imc_state_t, has_excl, bool,
+       private_imc_test_state_t *this)
+{
+       return this->has_excl;
+}
+
+METHOD(imc_state_t, set_flags, void,
+       private_imc_test_state_t *this, bool has_long, bool has_excl)
+{
+       this->has_long = has_long;
+       this->has_excl = has_excl;
+}
+
 METHOD(imc_state_t, change_state, void,
        private_imc_test_state_t *this, TNC_ConnectionState new_state)
 {
@@ -84,6 +120,17 @@ METHOD(imc_test_state_t, set_command, void,
        free(old_command);
 }
 
+METHOD(imc_test_state_t, is_first_handshake, bool,
+       private_imc_test_state_t *this)
+{
+       bool first;
+
+       /* test and reset first_handshake flag */
+       first= this->first_handshake;
+       this->first_handshake = FALSE;
+       return first;
+}
+
 METHOD(imc_test_state_t, do_handshake_retry, bool,
        private_imc_test_state_t *this)
 {
@@ -95,7 +142,6 @@ METHOD(imc_test_state_t, do_handshake_retry, bool,
        return retry;
 }
 
-
 /**
  * Described in header.
  */
@@ -108,16 +154,21 @@ imc_state_t *imc_test_state_create(TNC_ConnectionID connection_id,
                .public = {
                        .interface = {
                                .get_connection_id = _get_connection_id,
+                               .has_long = _has_long,
+                               .has_excl = _has_excl,
+                               .set_flags = _set_flags,
                                .change_state = _change_state,
                                .destroy = _destroy,
                        },
                        .get_command = _get_command,
                        .set_command = _set_command,
+                       .is_first_handshake = _is_first_handshake,
                        .do_handshake_retry = _do_handshake_retry,
                },
                .state = TNC_CONNECTION_STATE_CREATE,
                .connection_id = connection_id,
                .command = strdup(command),
+               .first_handshake = TRUE,
                .handshake_retry = retry,
        );