diff options
Diffstat (limited to 'src/libcharon/plugins')
-rw-r--r-- | src/libcharon/plugins/tnc_imc/tnc_imc.c | 28 | ||||
-rw-r--r-- | src/libcharon/plugins/tnc_imc/tnc_imc_manager.c | 21 | ||||
-rw-r--r-- | src/libcharon/plugins/tnc_imv/tnc_imv.c | 28 | ||||
-rw-r--r-- | src/libcharon/plugins/tnc_imv/tnc_imv_manager.c | 22 | ||||
-rw-r--r-- | src/libcharon/plugins/tnccs_20/tnccs_20.c | 27 |
5 files changed, 124 insertions, 2 deletions
diff --git a/src/libcharon/plugins/tnc_imc/tnc_imc.c b/src/libcharon/plugins/tnc_imc/tnc_imc.c index f87853bf9..29f34d939 100644 --- a/src/libcharon/plugins/tnc_imc/tnc_imc.c +++ b/src/libcharon/plugins/tnc_imc/tnc_imc.c @@ -84,6 +84,33 @@ METHOD(imc_t, set_message_types, void, } } +METHOD(imc_t, type_supported, bool, + private_tnc_imc_t *this, TNC_MessageType message_type) +{ + TNC_VendorID msg_vid, vid; + TNC_MessageSubtype msg_subtype, subtype; + int i; + + msg_vid = (message_type >> 8) & TNC_VENDORID_ANY; + msg_subtype = message_type & TNC_SUBTYPE_ANY; + + for (i = 0; i < this->type_count; i++) + { + vid = (this->supported_types[i] >> 8) & TNC_VENDORID_ANY; + subtype = this->supported_types[i] & TNC_SUBTYPE_ANY; + + if (this->supported_types[i] == message_type + || (subtype == TNC_SUBTYPE_ANY + && (msg_vid == vid || vid == TNC_VENDORID_ANY)) + || (vid == TNC_VENDORID_ANY + && (msg_subtype == subtype || subtype == TNC_SUBTYPE_ANY))) + { + return TRUE; + } + } + return FALSE; +} + METHOD(imc_t, destroy, void, private_tnc_imc_t *this) { @@ -106,6 +133,7 @@ imc_t* tnc_imc_create(char* name, char *filename) .get_id = _get_id, .get_name = _get_name, .set_message_types = _set_message_types, + .type_supported = _type_supported, .destroy = _destroy, }, ); diff --git a/src/libcharon/plugins/tnc_imc/tnc_imc_manager.c b/src/libcharon/plugins/tnc_imc/tnc_imc_manager.c index e6555cb51..8e0564446 100644 --- a/src/libcharon/plugins/tnc_imc/tnc_imc_manager.c +++ b/src/libcharon/plugins/tnc_imc/tnc_imc_manager.c @@ -124,6 +124,26 @@ METHOD(imc_manager_t, set_message_types, TNC_Result, return result; } +METHOD(imc_manager_t, receive_message, void, + private_tnc_imc_manager_t *this, TNC_ConnectionID connection_id, + TNC_BufferReference message, + TNC_UInt32 message_len, + TNC_MessageType message_type) +{ + enumerator_t *enumerator; + imc_t *imc; + + enumerator = this->imcs->create_enumerator(this->imcs); + while (enumerator->enumerate(enumerator, &imc)) + { + if (imc->receive_message && imc->type_supported(imc, message_type)) + { + imc->receive_message(imc->get_id(imc), connection_id, + message, message_len, message_type); + } + } + enumerator->destroy(enumerator); +} METHOD(imc_manager_t, destroy, void, private_tnc_imc_manager_t *this) @@ -157,6 +177,7 @@ imc_manager_t* tnc_imc_manager_create(void) .notify_connection_change = _notify_connection_change, .begin_handshake = _begin_handshake, .set_message_types = _set_message_types, + .receive_message = _receive_message, .destroy = _destroy, }, .imcs = linked_list_create(), diff --git a/src/libcharon/plugins/tnc_imv/tnc_imv.c b/src/libcharon/plugins/tnc_imv/tnc_imv.c index 722f6d946..3dfc50b4f 100644 --- a/src/libcharon/plugins/tnc_imv/tnc_imv.c +++ b/src/libcharon/plugins/tnc_imv/tnc_imv.c @@ -84,6 +84,33 @@ METHOD(imv_t, set_message_types, void, } } +METHOD(imv_t, type_supported, bool, + private_tnc_imv_t *this, TNC_MessageType message_type) +{ + TNC_VendorID msg_vid, vid; + TNC_MessageSubtype msg_subtype, subtype; + int i; + + msg_vid = (message_type >> 8) & TNC_VENDORID_ANY; + msg_subtype = message_type & TNC_SUBTYPE_ANY; + + for (i = 0; i < this->type_count; i++) + { + vid = (this->supported_types[i] >> 8) & TNC_VENDORID_ANY; + subtype = this->supported_types[i] & TNC_SUBTYPE_ANY; + + if (this->supported_types[i] == message_type + || (subtype == TNC_SUBTYPE_ANY + && (msg_vid == vid || vid == TNC_VENDORID_ANY)) + || (vid == TNC_VENDORID_ANY + && (msg_subtype == subtype || subtype == TNC_SUBTYPE_ANY))) + { + return TRUE; + } + } + return FALSE; +} + METHOD(imv_t, destroy, void, private_tnc_imv_t *this) { @@ -106,6 +133,7 @@ imv_t* tnc_imv_create(char *name, char *filename) .get_id = _get_id, .get_name = _get_name, .set_message_types = _set_message_types, + .type_supported = _type_supported, .destroy = _destroy, }, ); diff --git a/src/libcharon/plugins/tnc_imv/tnc_imv_manager.c b/src/libcharon/plugins/tnc_imv/tnc_imv_manager.c index a5309e462..fa6d35d41 100644 --- a/src/libcharon/plugins/tnc_imv/tnc_imv_manager.c +++ b/src/libcharon/plugins/tnc_imv/tnc_imv_manager.c @@ -109,6 +109,27 @@ METHOD(imv_manager_t, set_message_types, TNC_Result, return result; } +METHOD(imv_manager_t, receive_message, void, + private_tnc_imv_manager_t *this, TNC_ConnectionID connection_id, + TNC_BufferReference message, + TNC_UInt32 message_len, + TNC_MessageType message_type) +{ + enumerator_t *enumerator; + imv_t *imv; + + enumerator = this->imvs->create_enumerator(this->imvs); + while (enumerator->enumerate(enumerator, &imv)) + { + if (imv->receive_message && imv->type_supported(imv, message_type)) + { + imv->receive_message(imv->get_id(imv), connection_id, + message, message_len, message_type); + } + } + enumerator->destroy(enumerator); +} + METHOD(imv_manager_t, destroy, void, private_tnc_imv_manager_t *this) { @@ -140,6 +161,7 @@ imv_manager_t* tnc_imv_manager_create(void) .add = _add, .notify_connection_change = _notify_connection_change, .set_message_types = _set_message_types, + .receive_message = _receive_message, .destroy = _destroy, }, .imvs = linked_list_create(), diff --git a/src/libcharon/plugins/tnccs_20/tnccs_20.c b/src/libcharon/plugins/tnccs_20/tnccs_20.c index 5afc6e196..8f6f11e50 100644 --- a/src/libcharon/plugins/tnccs_20/tnccs_20.c +++ b/src/libcharon/plugins/tnccs_20/tnccs_20.c @@ -63,6 +63,9 @@ METHOD(tnccs_t, send_message, void, METHOD(tls_t, process, status_t, private_tnccs_20_t *this, void *buf, size_t buflen) { + char *pos; + size_t len; + if (this->is_server && !this->connection_id) { this->connection_id = charon->tnccs->create_connection(charon->tnccs, @@ -73,14 +76,34 @@ METHOD(tls_t, process, status_t, DBG1(DBG_TNC, "received TNCCS Batch (%u bytes) for Connection ID %u", buflen, this->connection_id); DBG3(DBG_TNC, "%.*s", buflen, buf); - + pos = strchr(buf, '|'); + if (pos) + { + pos++; + len = buflen - ((char*)buf - pos); + } + else + { + pos = buf; + len = buflen; + } + if (this->is_server) + { + charon->imvs->receive_message(charon->imvs, this->connection_id, + pos, len, 0x0080ab31); + } + else + { + charon->imcs->receive_message(charon->imcs, this->connection_id, + pos, len, 0x0080ab31); + } return NEED_MORE; } METHOD(tls_t, build, status_t, private_tnccs_20_t *this, void *buf, size_t *buflen, size_t *msglen) { - char *msg = this->is_server ? "|tncs->tncc 2.0|" : "|tncc->tncs 2.0|"; + char *msg = this->is_server ? "tncs->tncc 2.0|" : "tncc->tncs 2.0|"; size_t len; this->batch = chunk_clone(chunk_create(msg, strlen(msg))); |