aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMartin Willi <martin@strongswan.org>2005-11-21 15:34:44 +0000
committerMartin Willi <martin@strongswan.org>2005-11-21 15:34:44 +0000
commite0d609397696d778688ac8965c3a3b566f729e22 (patch)
tree8172e1597fc28efb234d0cf469d774d0a9b13dc4
parent61a401c8fb907949a2ab6053b44bc9278fc6a1ab (diff)
downloadstrongswan-e0d609397696d778688ac8965c3a3b566f729e22.tar.bz2
strongswan-e0d609397696d778688ac8965c3a3b566f729e22.tar.xz
- cleaned up logging
-rw-r--r--Source/charon/message.c69
1 files changed, 48 insertions, 21 deletions
diff --git a/Source/charon/message.c b/Source/charon/message.c
index aa850c3a0..607585615 100644
--- a/Source/charon/message.c
+++ b/Source/charon/message.c
@@ -85,7 +85,9 @@ struct message_rule_s {
supported_payload_entry_t *supported_payloads;
};
-
+/**
+ * message rule for ike_sa_init from initiator
+ */
static supported_payload_entry_t supported_ike_sa_init_i_payloads[] =
{
{SECURITY_ASSOCIATION,1,1},
@@ -93,6 +95,9 @@ static supported_payload_entry_t supported_ike_sa_init_i_payloads[] =
{NONCE,1,1},
};
+/**
+ * message rule for ike_sa_init from responder
+ */
static supported_payload_entry_t supported_ike_sa_init_r_payloads[] =
{
{SECURITY_ASSOCIATION,1,1},
@@ -100,6 +105,10 @@ static supported_payload_entry_t supported_ike_sa_init_r_payloads[] =
{NONCE,1,1},
};
+
+/**
+ * message rules, defines allowed payloads
+ */
static message_rule_t message_rules[] = {
{IKE_SA_INIT,TRUE,(sizeof(supported_ike_sa_init_i_payloads)/sizeof(supported_payload_entry_t)),supported_ike_sa_init_i_payloads},
{IKE_SA_INIT,FALSE,(sizeof(supported_ike_sa_init_r_payloads)/sizeof(supported_payload_entry_t)),supported_ike_sa_init_r_payloads}
@@ -388,6 +397,9 @@ static status_t add_payload(private_message_t *this, payload_t *payload)
last_payload->set_next_type(last_payload,payload->get_type(payload));
}
+ this->logger->log(this->logger, CONTROL|MORE, "added payload of type %s to message",
+ mapping_find(payload_type_m, payload->get_type(payload)));
+
return SUCCESS;
}
@@ -442,6 +454,10 @@ static status_t generate(private_message_t *this, packet_t **packet)
linked_list_iterator_t *iterator;
status_t status;
+
+ this->logger->log(this->logger, CONTROL, "generating message, contains %d payloads",
+ this->payloads->get_count(this->payloads));
+
if (this->packet != NULL)
{
/* already generated packet is just cloned */
@@ -450,15 +466,18 @@ static status_t generate(private_message_t *this, packet_t **packet)
if (this->exchange_type == EXCHANGE_TYPE_UNDEFINED)
{
+ this->logger->log(this->logger, ERROR, "exchange type is not defined");
return INVALID_STATE;
}
if (this->packet->source == NULL ||
this->packet->destination == NULL)
{
+ this->logger->log(this->logger, ERROR, "source/destination not defined");
return INVALID_STATE;
}
+
ike_header = ike_header_create();
if (ike_header == NULL)
{
@@ -530,6 +549,9 @@ static status_t generate(private_message_t *this, packet_t **packet)
this->packet->clone(this->packet, packet);
generator->destroy(generator);
+
+
+ this->logger->log(this->logger, CONTROL, "message generated successfully");
return SUCCESS;
}
@@ -537,11 +559,14 @@ static status_t generate(private_message_t *this, packet_t **packet)
* Implements message_t's parse_header function.
* See #message_s.parse_header.
*/
-static status_t parse_header (private_message_t *this)
+static status_t parse_header(private_message_t *this)
{
ike_header_t *ike_header;
status_t status;
+
+ this->logger->log(this->logger, CONTROL, "parsing header of message");
+
this->parser->reset_context(this->parser);
status = this->parser->parse_payload(this->parser,HEADER,(payload_t **) &ike_header);
if (status != SUCCESS)
@@ -555,7 +580,7 @@ static status_t parse_header (private_message_t *this)
status = ike_header->payload_interface.verify(&(ike_header->payload_interface));
if (status != SUCCESS)
{
- this->logger->log(this->logger, ERROR, "Header could not be verified");
+ this->logger->log(this->logger, ERROR, "Header verification failed");
return status;
}
@@ -566,10 +591,10 @@ static status_t parse_header (private_message_t *this)
this->ike_sa_id = ike_sa_id_create(ike_header->get_initiator_spi(ike_header),
ike_header->get_responder_spi(ike_header),
- !ike_header->get_initiator_flag(ike_header));
+ ike_header->get_initiator_flag(ike_header));
if (this->ike_sa_id == NULL)
{
- this->logger->log(this->logger, ERROR, "Could not creaee ike_sa_id object");
+ this->logger->log(this->logger, ERROR, "could not create ike_sa_id object");
ike_header->destroy(ike_header);
return OUT_OF_RES;
}
@@ -580,6 +605,9 @@ static status_t parse_header (private_message_t *this)
this->minor_version = ike_header->get_min_version(ike_header);
this->first_payload = ike_header->payload_interface.get_next_type(&(ike_header->payload_interface));
+
+ this->logger->log(this->logger, CONTROL, "parsing header successfully");
+
ike_header->destroy(ike_header);
return SUCCESS;
}
@@ -596,23 +624,22 @@ static status_t parse_body (private_message_t *this)
supported_payload_entry_t *supported_payloads;
size_t supported_payloads_count;
+
+ this->logger->log(this->logger, CONTROL, "parsing body of message");
- if (this->get_supported_payloads (this,&supported_payloads,&supported_payloads_count) != SUCCESS)
+ if (this->get_supported_payloads (this, &supported_payloads, &supported_payloads_count) != SUCCESS)
{
this->logger->log(this->logger, ERROR, "could not get supported payloads");
- /* message type is not supported */
return FAILED;
}
-
-
- this->logger->log(this->logger, ERROR, "first payload %s", mapping_find(payload_type_m, current_payload_type));
-
+
while (current_payload_type != NO_PAYLOAD)
{
payload_t *current_payload;
bool supported = FALSE;
- this->logger->log(this->logger, ERROR, "Start parsing payload of type %s", mapping_find(payload_type_m, current_payload_type));
+ this->logger->log(this->logger, CONTROL|MORE, "start parsing payload of type %s",
+ mapping_find(payload_type_m, current_payload_type));
for (i = 0; i < supported_payloads_count;i++)
{
if (supported_payloads[i].payload_type == current_payload_type)
@@ -625,21 +652,21 @@ static status_t parse_body (private_message_t *this)
{
/* type not supported */
status = NOT_SUPPORTED;
- this->logger->log(this->logger, ERROR, "Payload type %s not supported",mapping_find(payload_type_m,current_payload_type));
+ this->logger->log(this->logger, ERROR, "payload type %s not supported",mapping_find(payload_type_m,current_payload_type));
break;
}
status = this->parser->parse_payload(this->parser,current_payload_type,(payload_t **) &current_payload);
if (status != SUCCESS)
{
- this->logger->log(this->logger, ERROR, "Payload type %s could not be parsed",mapping_find(payload_type_m,current_payload_type));
+ this->logger->log(this->logger, ERROR, "payload type %s could not be parsed",mapping_find(payload_type_m,current_payload_type));
break;
}
status = current_payload->verify(current_payload);
if (status != SUCCESS)
{
- this->logger->log(this->logger, ERROR, "Payload type %s could not be verified",mapping_find(payload_type_m,current_payload_type));
+ this->logger->log(this->logger, ERROR, "payload type %s could not be verified",mapping_find(payload_type_m,current_payload_type));
status = VERIFY_ERROR;
break;
}
@@ -670,7 +697,6 @@ static status_t parse_body (private_message_t *this)
return status;
}
-
/* check for payloads with wrong count*/
for (i = 0; i < supported_payloads_count;i++)
{
@@ -687,7 +713,7 @@ static status_t parse_body (private_message_t *this)
status = iterator->current(iterator,(void **)&current_payload);
if (status != SUCCESS)
{
- this->logger->log(this->logger, CONTROL|MORE, "Could not get payload from internal list");
+ this->logger->log(this->logger, ERROR, "Could not get payload from internal list");
iterator->destroy(iterator);
return status;
}
@@ -696,7 +722,7 @@ static status_t parse_body (private_message_t *this)
found_payloads++;
if (found_payloads > max_occurence)
{
- this->logger->log(this->logger, CONTROL|MORE, "Payload of type %s more than %d times (%d) occured in current message",
+ this->logger->log(this->logger, ERROR, "Payload of type %s more than %d times (%d) occured in current message",
mapping_find(payload_type_m,current_payload->get_type(current_payload)),max_occurence,found_payloads);
iterator->destroy(iterator);
return NOT_SUPPORTED;
@@ -706,7 +732,7 @@ static status_t parse_body (private_message_t *this)
}
if (found_payloads < min_occurence)
{
- this->logger->log(this->logger, CONTROL|MORE, "Payload of type %s not occured %d times",
+ this->logger->log(this->logger, ERROR, "Payload of type %s not occured %d times",
mapping_find(payload_type_m,payload_type),min_occurence);
iterator->destroy(iterator);
return NOT_SUPPORTED;
@@ -742,13 +768,14 @@ static status_t destroy (private_message_t *this)
{
payload_t *payload;
iterator->current(iterator, (void**)&payload);
- this->logger->log(this->logger, CONTROL|MORE, "Destroying payload of type %s",
- mapping_find(payload_type_m, payload->get_type(payload)));
+ this->logger->log(this->logger, CONTROL|MOST, "Destroying payload of type %s",
+ mapping_find(payload_type_m, payload->get_type(payload)));
payload->destroy(payload);
}
iterator->destroy(iterator);
this->payloads->destroy(this->payloads);
this->parser->destroy(this->parser);
+ global_logger_manager->destroy_logger(global_logger_manager, this->logger);
allocator_free(this);
return SUCCESS;