2 * Copyright (C) 2013-2014 Andreas Steffen
3 * HSR Hochschule fuer Technik Rapperswil
5 * This program is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License as published by the
7 * Free Software Foundation; either version 2 of the License, or (at your
8 * option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>.
10 * This program is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
12 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 #include "imc_swid_state.h"
18 #include <tncif_names.h>
20 #include <utils/debug.h>
22 typedef struct private_imc_swid_state_t private_imc_swid_state_t
;
25 * Private data of an imc_swid_state_t object.
27 struct private_imc_swid_state_t
{
30 * Public members of imc_swid_state_t
32 imc_swid_state_t
public;
37 TNC_ConnectionID connection_id
;
40 * TNCCS connection state
42 TNC_ConnectionState state
;
45 * Assessment/Evaluation Result
47 TNC_IMV_Evaluation_Result result
;
50 * Does the TNCCS connection support long message types?
55 * Does the TNCCS connection support exclusive delivery?
60 * Maximum PA-TNC message size for this TNCCS connection
65 * PA-TNC attribute segmentation contracts associated with TNCCS connection
67 seg_contract_manager_t
*contracts
;
75 METHOD(imc_state_t
, get_connection_id
, TNC_ConnectionID
,
76 private_imc_swid_state_t
*this)
78 return this->connection_id
;
81 METHOD(imc_state_t
, has_long
, bool,
82 private_imc_swid_state_t
*this)
84 return this->has_long
;
87 METHOD(imc_state_t
, has_excl
, bool,
88 private_imc_swid_state_t
*this)
90 return this->has_excl
;
93 METHOD(imc_state_t
, set_flags
, void,
94 private_imc_swid_state_t
*this, bool has_long
, bool has_excl
)
96 this->has_long
= has_long
;
97 this->has_excl
= has_excl
;
100 METHOD(imc_state_t
, set_max_msg_len
, void,
101 private_imc_swid_state_t
*this, uint32_t max_msg_len
)
103 this->max_msg_len
= max_msg_len
;
106 METHOD(imc_state_t
, get_max_msg_len
, uint32_t,
107 private_imc_swid_state_t
*this)
109 return this->max_msg_len
;
112 METHOD(imc_state_t
, get_contracts
, seg_contract_manager_t
*,
113 private_imc_swid_state_t
*this)
115 return this->contracts
;
118 METHOD(imc_state_t
, change_state
, void,
119 private_imc_swid_state_t
*this, TNC_ConnectionState new_state
)
121 this->state
= new_state
;
124 METHOD(imc_state_t
, set_result
, void,
125 private_imc_swid_state_t
*this, TNC_IMCID id
,
126 TNC_IMV_Evaluation_Result result
)
128 this->result
= result
;
131 METHOD(imc_state_t
, get_result
, bool,
132 private_imc_swid_state_t
*this, TNC_IMCID id
,
133 TNC_IMV_Evaluation_Result
*result
)
137 *result
= this->result
;
139 return this->result
!= TNC_IMV_EVALUATION_RESULT_DONT_KNOW
;
142 METHOD(imc_state_t
, destroy
, void,
143 private_imc_swid_state_t
*this)
145 this->contracts
->destroy(this->contracts
);
149 METHOD(imc_swid_state_t
, get_eid_epoch
, uint32_t,
150 private_imc_swid_state_t
*this)
152 return this->eid_epoch
;
156 * Described in header.
158 imc_state_t
*imc_swid_state_create(TNC_ConnectionID connection_id
)
160 private_imc_swid_state_t
*this;
164 ng
= lib
->crypto
->create_nonce_gen(lib
->crypto
);
165 if (!ng
|| !ng
->get_nonce(ng
, 4, (uint8_t*)&eid_epoch
))
167 DBG1(DBG_TNC
, "failed to generate random EID epoch value");
173 DBG1(DBG_IMC
, "creating random EID epoch 0x%08x", eid_epoch
);
178 .get_connection_id
= _get_connection_id
,
179 .has_long
= _has_long
,
180 .has_excl
= _has_excl
,
181 .set_flags
= _set_flags
,
182 .set_max_msg_len
= _set_max_msg_len
,
183 .get_max_msg_len
= _get_max_msg_len
,
184 .get_contracts
= _get_contracts
,
185 .change_state
= _change_state
,
186 .set_result
= _set_result
,
187 .get_result
= _get_result
,
190 .get_eid_epoch
= _get_eid_epoch
,
192 .state
= TNC_CONNECTION_STATE_CREATE
,
193 .result
= TNC_IMV_EVALUATION_RESULT_DONT_KNOW
,
194 .connection_id
= connection_id
,
195 .contracts
= seg_contract_manager_create(),
196 .eid_epoch
= eid_epoch
,
200 return &this->public.interface
;