/* * Copyright (C) 2011 Andreas Steffen, HSR Hochschule fuer Technik Rapperswil * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the * Free Software Foundation; either version 2 of the License, or (at your * option) any later version. See . * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * for more details. */ #include "imc_test_state.h" #include #include typedef struct private_imc_test_state_t private_imc_test_state_t; /** * Private data of an imc_test_state_t object. */ struct private_imc_test_state_t { /** * Public members of imc_test_state_t */ imc_test_state_t public; /** * TNCCS connection ID */ TNC_ConnectionID connection_id; /** * TNCCS connection state */ 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, private_imc_test_state_t *this) { 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) { this->state = new_state; } METHOD(imc_state_t, destroy, void, private_imc_test_state_t *this) { free(this->command); free(this); } METHOD(imc_test_state_t, get_command, char*, private_imc_test_state_t *this) { return this->command; } METHOD(imc_test_state_t, set_command, void, private_imc_test_state_t *this, char* command) { char *old_command; old_command = this->command; this->command = strdup(command); 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) { bool retry; /* test and reset handshake_retry flag */ retry = this->handshake_retry; this->handshake_retry = FALSE; return retry; } /** * Described in header. */ imc_state_t *imc_test_state_create(TNC_ConnectionID connection_id, char *command, bool retry) { private_imc_test_state_t *this; INIT(this, .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, ); return &this->public.interface; }