mirror of
https://github.com/strongswan/strongswan.git
synced 2025-10-08 00:02:03 -04:00
centralized processing of assessment information
This commit is contained in:
parent
6782bf3722
commit
3de9a31a49
@ -369,10 +369,9 @@ static void handle_message(private_tnccs_20_t *this, pb_tnc_msg_t *msg)
|
|||||||
reason_msg = (pb_reason_string_msg_t*)msg;
|
reason_msg = (pb_reason_string_msg_t*)msg;
|
||||||
reason_string = reason_msg->get_reason_string(reason_msg);
|
reason_string = reason_msg->get_reason_string(reason_msg);
|
||||||
language_code = reason_msg->get_language_code(reason_msg);
|
language_code = reason_msg->get_language_code(reason_msg);
|
||||||
DBG2(DBG_TNC, "reason string is '%.*s'", (int)reason_string.len,
|
DBG1(DBG_TNC, "reason string is '%.*s' [%.*s]",
|
||||||
reason_string.ptr);
|
(int)reason_string.len, reason_string.ptr,
|
||||||
DBG2(DBG_TNC, "language code is '%.*s'", (int)language_code.len,
|
(int)language_code.len, language_code.ptr);
|
||||||
language_code.ptr);
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
|
|
||||||
#include "ietf/ietf_attr.h"
|
#include "ietf/ietf_attr.h"
|
||||||
#include "ietf/ietf_attr_assess_result.h"
|
#include "ietf/ietf_attr_assess_result.h"
|
||||||
|
#include "ietf/ietf_attr_remediation_instr.h"
|
||||||
|
|
||||||
#include <tncif_names.h>
|
#include <tncif_names.h>
|
||||||
|
|
||||||
@ -167,13 +168,38 @@ METHOD(imc_msg_t, send_, TNC_Result,
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Print a clearly visible assessment header to the log
|
||||||
|
*/
|
||||||
|
static void print_assessment_header(const char *name, TNC_UInt32 id, bool *first)
|
||||||
|
{
|
||||||
|
if (*first)
|
||||||
|
{
|
||||||
|
DBG1(DBG_IMC, "***** assessment of IMC %u \"%s\" *****", id, name);
|
||||||
|
*first = FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Print a clearly visible assessment trailer to the log
|
||||||
|
*/
|
||||||
|
static void print_assessment_trailer(bool first)
|
||||||
|
{
|
||||||
|
if (!first)
|
||||||
|
{
|
||||||
|
DBG1(DBG_IMC, "***** end of assessment *****");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
METHOD(imc_msg_t, receive, TNC_Result,
|
METHOD(imc_msg_t, receive, TNC_Result,
|
||||||
private_imc_msg_t *this, bool *fatal_error)
|
private_imc_msg_t *this, bool *fatal_error)
|
||||||
{
|
{
|
||||||
|
TNC_UInt32 target_imc_id;
|
||||||
enumerator_t *enumerator;
|
enumerator_t *enumerator;
|
||||||
pa_tnc_attr_t *attr;
|
pa_tnc_attr_t *attr;
|
||||||
pen_type_t attr_type;
|
pen_type_t attr_type;
|
||||||
chunk_t msg;
|
chunk_t msg;
|
||||||
|
bool first = TRUE;
|
||||||
|
|
||||||
if (this->state->has_long(this->state))
|
if (this->state->has_long(this->state))
|
||||||
{
|
{
|
||||||
@ -235,6 +261,10 @@ METHOD(imc_msg_t, receive, TNC_Result,
|
|||||||
return TNC_RESULT_FATAL;
|
return TNC_RESULT_FATAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* determine target IMC ID */
|
||||||
|
target_imc_id = (this->dst_id != TNC_IMCID_ANY) ?
|
||||||
|
this->dst_id : this->agent->get_id(this->agent);
|
||||||
|
|
||||||
/* preprocess any received IETF standard error attributes */
|
/* preprocess any received IETF standard error attributes */
|
||||||
*fatal_error = this->pa_msg->process_ietf_std_errors(this->pa_msg);
|
*fatal_error = this->pa_msg->process_ietf_std_errors(this->pa_msg);
|
||||||
|
|
||||||
@ -244,24 +274,63 @@ METHOD(imc_msg_t, receive, TNC_Result,
|
|||||||
{
|
{
|
||||||
attr_type = attr->get_type(attr);
|
attr_type = attr->get_type(attr);
|
||||||
|
|
||||||
if (attr_type.vendor_id == PEN_IETF &&
|
if (attr_type.vendor_id != PEN_IETF)
|
||||||
attr_type.type == IETF_ATTR_ASSESSMENT_RESULT)
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (attr_type.type == IETF_ATTR_ASSESSMENT_RESULT)
|
||||||
{
|
{
|
||||||
ietf_attr_assess_result_t *attr_cast;
|
ietf_attr_assess_result_t *attr_cast;
|
||||||
TNC_UInt32 target_imc_id;
|
|
||||||
TNC_IMV_Evaluation_Result result;
|
TNC_IMV_Evaluation_Result result;
|
||||||
|
|
||||||
attr_cast = (ietf_attr_assess_result_t*)attr;
|
attr_cast = (ietf_attr_assess_result_t*)attr;
|
||||||
result = attr_cast->get_result(attr_cast);
|
result = attr_cast->get_result(attr_cast);
|
||||||
target_imc_id = (this->dst_id != TNC_IMCID_ANY) ?
|
|
||||||
this->dst_id : this->agent->get_id(this->agent);
|
|
||||||
this->state->set_result(this->state, target_imc_id, result);
|
this->state->set_result(this->state, target_imc_id, result);
|
||||||
|
|
||||||
DBG1(DBG_IMC, "set assessment result for IMC %u to '%N'",
|
print_assessment_header(this->agent->get_name(this->agent),
|
||||||
target_imc_id, TNC_IMV_Evaluation_Result_names, result);
|
target_imc_id, &first);
|
||||||
|
DBG1(DBG_IMC, "assessment result is '%N'",
|
||||||
|
TNC_IMV_Evaluation_Result_names, result);
|
||||||
|
}
|
||||||
|
else if (attr_type.type == IETF_ATTR_REMEDIATION_INSTRUCTIONS)
|
||||||
|
{
|
||||||
|
ietf_attr_remediation_instr_t *attr_cast;
|
||||||
|
pen_type_t parameters_type;
|
||||||
|
chunk_t parameters, string, lang_code;
|
||||||
|
|
||||||
|
attr_cast = (ietf_attr_remediation_instr_t*)attr;
|
||||||
|
parameters_type = attr_cast->get_parameters_type(attr_cast);
|
||||||
|
parameters = attr_cast->get_parameters(attr_cast);
|
||||||
|
|
||||||
|
print_assessment_header(this->agent->get_name(this->agent),
|
||||||
|
target_imc_id, &first);
|
||||||
|
if (parameters_type.vendor_id == PEN_IETF)
|
||||||
|
{
|
||||||
|
switch (parameters_type.type)
|
||||||
|
{
|
||||||
|
case IETF_REMEDIATION_PARAMETERS_URI:
|
||||||
|
DBG1(DBG_IMC, "remediation uri: '%.*s'",
|
||||||
|
parameters.len, parameters.ptr);
|
||||||
|
break;
|
||||||
|
case IETF_REMEDIATION_PARAMETERS_STRING:
|
||||||
|
string = attr_cast->get_string(attr_cast, &lang_code);
|
||||||
|
DBG1(DBG_IMC, "remediation string: '%.*s' [%.*s]",
|
||||||
|
string.len, string.ptr,
|
||||||
|
lang_code.len, lang_code.ptr);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
DBG1(DBG_IMC, "remediation parameters %B", ¶meters);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
DBG1(DBG_IMC, "remediation parameters %B", ¶meters);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
enumerator->destroy(enumerator);
|
enumerator->destroy(enumerator);
|
||||||
|
|
||||||
|
print_assessment_trailer(first);
|
||||||
|
|
||||||
return TNC_RESULT_SUCCESS;
|
return TNC_RESULT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
@ -191,7 +191,7 @@ METHOD(imv_msg_t, send_assessment, TNC_Result,
|
|||||||
TNC_IMV_Action_Recommendation rec;
|
TNC_IMV_Action_Recommendation rec;
|
||||||
TNC_IMV_Evaluation_Result eval;
|
TNC_IMV_Evaluation_Result eval;
|
||||||
pa_tnc_attr_t *attr;
|
pa_tnc_attr_t *attr;
|
||||||
char *string, *lang_code;
|
char *string = NULL, *lang_code = NULL, *uri = NULL;
|
||||||
enumerator_t *e;
|
enumerator_t *e;
|
||||||
|
|
||||||
/* Send an IETF Assessment Result attribute if enabled */
|
/* Send an IETF Assessment Result attribute if enabled */
|
||||||
@ -202,17 +202,27 @@ METHOD(imv_msg_t, send_assessment, TNC_Result,
|
|||||||
attr = ietf_attr_assess_result_create(eval);
|
attr = ietf_attr_assess_result_create(eval);
|
||||||
add_attribute(this, attr);
|
add_attribute(this, attr);
|
||||||
|
|
||||||
|
/* Send IETF Remediation Instructions if available */
|
||||||
if (eval != TNC_IMV_EVALUATION_RESULT_COMPLIANT)
|
if (eval != TNC_IMV_EVALUATION_RESULT_COMPLIANT)
|
||||||
{
|
{
|
||||||
e = this->agent->create_language_enumerator(this->agent,
|
e = this->agent->create_language_enumerator(this->agent,
|
||||||
this->state);
|
this->state);
|
||||||
if (this->state->get_remediation_instructions(this->state,
|
if (this->state->get_remediation_instructions(this->state,
|
||||||
e, &string, &lang_code))
|
e, &string, &lang_code, &uri))
|
||||||
{
|
{
|
||||||
attr = ietf_attr_remediation_instr_create_from_string(
|
if (string && lang_code)
|
||||||
|
{
|
||||||
|
attr = ietf_attr_remediation_instr_create_from_string(
|
||||||
chunk_create(string, strlen(string)),
|
chunk_create(string, strlen(string)),
|
||||||
chunk_create(lang_code, strlen(lang_code)));
|
chunk_create(lang_code, strlen(lang_code)));
|
||||||
add_attribute(this, attr);
|
add_attribute(this, attr);
|
||||||
|
}
|
||||||
|
if (uri)
|
||||||
|
{
|
||||||
|
attr = ietf_attr_remediation_instr_create_from_uri(
|
||||||
|
chunk_create(uri, strlen(uri)));
|
||||||
|
add_attribute(this, attr);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
e->destroy(e);
|
e->destroy(e);
|
||||||
}
|
}
|
||||||
|
@ -124,11 +124,13 @@ struct imv_state_t {
|
|||||||
* @param language_enumerator language enumerator
|
* @param language_enumerator language enumerator
|
||||||
* @param string remediation instruction string
|
* @param string remediation instruction string
|
||||||
* @param lang_code language of the remediation instructions
|
* @param lang_code language of the remediation instructions
|
||||||
|
* @param uri remediation URI
|
||||||
* @return TRUE if remediation instructions were found
|
* @return TRUE if remediation instructions were found
|
||||||
*/
|
*/
|
||||||
bool (*get_remediation_instructions)(imv_state_t *this,
|
bool (*get_remediation_instructions)(imv_state_t *this,
|
||||||
enumerator_t *language_enumerator,
|
enumerator_t *language_enumerator,
|
||||||
char **string, char **lang_code);
|
char **string, char **lang_code,
|
||||||
|
char **uri);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Destroys an imv_state_t object
|
* Destroys an imv_state_t object
|
||||||
|
@ -25,7 +25,6 @@
|
|||||||
#include <ietf/ietf_attr_numeric_version.h>
|
#include <ietf/ietf_attr_numeric_version.h>
|
||||||
#include <ietf/ietf_attr_op_status.h>
|
#include <ietf/ietf_attr_op_status.h>
|
||||||
#include <ietf/ietf_attr_product_info.h>
|
#include <ietf/ietf_attr_product_info.h>
|
||||||
#include <ietf/ietf_attr_remediation_instr.h>
|
|
||||||
#include <ietf/ietf_attr_string_version.h>
|
#include <ietf/ietf_attr_string_version.h>
|
||||||
#include <ita/ita_attr.h>
|
#include <ita/ita_attr.h>
|
||||||
#include <ita/ita_attr_get_settings.h>
|
#include <ita/ita_attr_get_settings.h>
|
||||||
@ -444,39 +443,6 @@ static TNC_Result receive_message(imc_state_t *state, imc_msg_t *in_msg)
|
|||||||
}
|
}
|
||||||
e->destroy(e);
|
e->destroy(e);
|
||||||
}
|
}
|
||||||
else if (type.type == IETF_ATTR_REMEDIATION_INSTRUCTIONS)
|
|
||||||
{
|
|
||||||
ietf_attr_remediation_instr_t *attr_cast;
|
|
||||||
pen_type_t parameters_type;
|
|
||||||
chunk_t parameters, string, lang_code;
|
|
||||||
|
|
||||||
attr_cast = (ietf_attr_remediation_instr_t*)attr;
|
|
||||||
parameters_type = attr_cast->get_parameters_type(attr_cast);
|
|
||||||
parameters = attr_cast->get_parameters(attr_cast);
|
|
||||||
|
|
||||||
if (parameters_type.vendor_id == PEN_IETF)
|
|
||||||
{
|
|
||||||
switch (parameters_type.type)
|
|
||||||
{
|
|
||||||
case IETF_REMEDIATION_PARAMETERS_URI:
|
|
||||||
DBG1(DBG_IMC, "remediation uri: '%.*s'",
|
|
||||||
parameters.len, parameters.ptr);
|
|
||||||
break;
|
|
||||||
case IETF_REMEDIATION_PARAMETERS_STRING:
|
|
||||||
string = attr_cast->get_string(attr_cast, &lang_code);
|
|
||||||
DBG1(DBG_IMC, "remediation string: '%.*s' [%.*s]",
|
|
||||||
string.len, string.ptr,
|
|
||||||
lang_code.len, lang_code.ptr);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
DBG1(DBG_IMC, "remediation parameters %B", ¶meters);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
DBG1(DBG_IMC, "remediation parameters %B", ¶meters);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else if (type.vendor_id == PEN_ITA && type.type == ITA_ATTR_GET_SETTINGS)
|
else if (type.vendor_id == PEN_ITA && type.type == ITA_ATTR_GET_SETTINGS)
|
||||||
{
|
{
|
||||||
|
@ -20,7 +20,6 @@
|
|||||||
#include <ietf/ietf_attr.h>
|
#include <ietf/ietf_attr.h>
|
||||||
#include <ietf/ietf_attr_attr_request.h>
|
#include <ietf/ietf_attr_attr_request.h>
|
||||||
#include <ietf/ietf_attr_port_filter.h>
|
#include <ietf/ietf_attr_port_filter.h>
|
||||||
#include <ietf/ietf_attr_remediation_instr.h>
|
|
||||||
|
|
||||||
#include <tncif_pa_subtypes.h>
|
#include <tncif_pa_subtypes.h>
|
||||||
|
|
||||||
@ -340,39 +339,6 @@ static TNC_Result receive_message(imc_msg_t *in_msg)
|
|||||||
}
|
}
|
||||||
e->destroy(e);
|
e->destroy(e);
|
||||||
}
|
}
|
||||||
else if (attr_type.type == IETF_ATTR_REMEDIATION_INSTRUCTIONS)
|
|
||||||
{
|
|
||||||
ietf_attr_remediation_instr_t *attr_cast;
|
|
||||||
pen_type_t parameters_type;
|
|
||||||
chunk_t parameters, string, lang_code;
|
|
||||||
|
|
||||||
attr_cast = (ietf_attr_remediation_instr_t*)attr;
|
|
||||||
parameters_type = attr_cast->get_parameters_type(attr_cast);
|
|
||||||
parameters = attr_cast->get_parameters(attr_cast);
|
|
||||||
|
|
||||||
if (parameters_type.vendor_id == PEN_IETF)
|
|
||||||
{
|
|
||||||
switch (parameters_type.type)
|
|
||||||
{
|
|
||||||
case IETF_REMEDIATION_PARAMETERS_URI:
|
|
||||||
DBG1(DBG_IMC, "remediation uri: '%.*s'",
|
|
||||||
parameters.len, parameters.ptr);
|
|
||||||
break;
|
|
||||||
case IETF_REMEDIATION_PARAMETERS_STRING:
|
|
||||||
string = attr_cast->get_string(attr_cast, &lang_code);
|
|
||||||
DBG1(DBG_IMC, "remediation string: '%.*s' [%.*s]",
|
|
||||||
string.len, string.ptr,
|
|
||||||
lang_code.len, lang_code.ptr);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
DBG1(DBG_IMC, "remediation parameters %B", ¶meters);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
DBG1(DBG_IMC, "remediation parameters %B", ¶meters);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
enumerator->destroy(enumerator);
|
enumerator->destroy(enumerator);
|
||||||
|
|
||||||
|
@ -199,7 +199,7 @@ METHOD(imv_state_t, get_reason_string, bool,
|
|||||||
|
|
||||||
METHOD(imv_state_t, get_remediation_instructions, bool,
|
METHOD(imv_state_t, get_remediation_instructions, bool,
|
||||||
private_imv_os_state_t *this, enumerator_t *language_enumerator,
|
private_imv_os_state_t *this, enumerator_t *language_enumerator,
|
||||||
char **string, char **lang_code)
|
char **string, char **lang_code, char **uri)
|
||||||
{
|
{
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
@ -205,7 +205,7 @@ METHOD(imv_state_t, get_reason_string, bool,
|
|||||||
|
|
||||||
METHOD(imv_state_t, get_remediation_instructions, bool,
|
METHOD(imv_state_t, get_remediation_instructions, bool,
|
||||||
private_imv_scanner_state_t *this, enumerator_t *language_enumerator,
|
private_imv_scanner_state_t *this, enumerator_t *language_enumerator,
|
||||||
char **string, char **lang_code)
|
char **string, char **lang_code, char **uri)
|
||||||
{
|
{
|
||||||
bool match = FALSE;
|
bool match = FALSE;
|
||||||
char *lang;
|
char *lang;
|
||||||
@ -241,6 +241,8 @@ METHOD(imv_state_t, get_remediation_instructions, bool,
|
|||||||
strlen(this->violating_ports) + 1);
|
strlen(this->violating_ports) + 1);
|
||||||
sprintf(this->instructions, "%s%s", *string, this->violating_ports);
|
sprintf(this->instructions, "%s%s", *string, this->violating_ports);
|
||||||
*string = this->instructions;
|
*string = this->instructions;
|
||||||
|
*uri = lib->settings->get_str(lib->settings,
|
||||||
|
"libimcv.plugins.imv-scanner.remediation_uri", NULL);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@ -197,9 +197,9 @@ METHOD(imv_state_t, get_reason_string, bool,
|
|||||||
|
|
||||||
METHOD(imv_state_t, get_remediation_instructions, bool,
|
METHOD(imv_state_t, get_remediation_instructions, bool,
|
||||||
private_imv_test_state_t *this, enumerator_t *language_enumerator,
|
private_imv_test_state_t *this, enumerator_t *language_enumerator,
|
||||||
char **string, char **lang_code)
|
char **string, char **lang_code, char **uri)
|
||||||
{
|
{
|
||||||
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
METHOD(imv_state_t, destroy, void,
|
METHOD(imv_state_t, destroy, void,
|
||||||
|
@ -244,7 +244,7 @@ METHOD(imv_state_t, get_reason_string, bool,
|
|||||||
|
|
||||||
METHOD(imv_state_t, get_remediation_instructions, bool,
|
METHOD(imv_state_t, get_remediation_instructions, bool,
|
||||||
private_imv_attestation_state_t *this, enumerator_t *language_enumerator,
|
private_imv_attestation_state_t *this, enumerator_t *language_enumerator,
|
||||||
char **string, char **lang_code)
|
char **string, char **lang_code, char **uri)
|
||||||
{
|
{
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user