diff options
Diffstat (limited to 'src/charon/threads/stroke_interface.c')
-rwxr-xr-x | src/charon/threads/stroke_interface.c | 119 |
1 files changed, 57 insertions, 62 deletions
diff --git a/src/charon/threads/stroke_interface.c b/src/charon/threads/stroke_interface.c index 7480dfe30..62d71dd95 100755 --- a/src/charon/threads/stroke_interface.c +++ b/src/charon/threads/stroke_interface.c @@ -133,7 +133,7 @@ static x509_t* load_end_certificate(const char *filename, identification_t **idp if (ugh != NULL) { - DBG1(SIG_DBG_CFG, "warning: certificate %s", ugh); + DBG1(DBG_CFG, "warning: certificate %s", ugh); } if (!id->equals(id, subject) && !cert->equals_subjectAltName(cert, id)) { @@ -178,27 +178,27 @@ static void stroke_add_conn(private_stroke_t *this, stroke_msg_t *msg) pop_string(msg, &msg->add_conn.algorithms.ike); pop_string(msg, &msg->add_conn.algorithms.esp); - DBG1(SIG_DBG_CFG, "received stroke: add connection '%s'", msg->add_conn.name); + DBG1(DBG_CFG, "received stroke: add connection '%s'", msg->add_conn.name); - DBG2(SIG_DBG_CFG, "conn %s", msg->add_conn.name); - DBG2(SIG_DBG_CFG, " right=%s", msg->add_conn.me.address); - DBG2(SIG_DBG_CFG, " left=%s", msg->add_conn.other.address); - DBG2(SIG_DBG_CFG, " rightsubnet=%s", msg->add_conn.me.subnet); - DBG2(SIG_DBG_CFG, " leftsubnet=%s", msg->add_conn.other.subnet); - DBG2(SIG_DBG_CFG, " rightid=%s", msg->add_conn.me.id); - DBG2(SIG_DBG_CFG, " leftid=%s", msg->add_conn.other.id); - DBG2(SIG_DBG_CFG, " rightcert=%s", msg->add_conn.me.cert); - DBG2(SIG_DBG_CFG, " leftcert=%s", msg->add_conn.other.cert); - DBG2(SIG_DBG_CFG, " rightca=%s", msg->add_conn.me.ca); - DBG2(SIG_DBG_CFG, " leftca=%s", msg->add_conn.other.ca); - DBG2(SIG_DBG_CFG, " ike=%s", msg->add_conn.algorithms.ike); - DBG2(SIG_DBG_CFG, " esp=%s", msg->add_conn.algorithms.esp); + DBG2(DBG_CFG, "conn %s", msg->add_conn.name); + DBG2(DBG_CFG, " right=%s", msg->add_conn.me.address); + DBG2(DBG_CFG, " left=%s", msg->add_conn.other.address); + DBG2(DBG_CFG, " rightsubnet=%s", msg->add_conn.me.subnet); + DBG2(DBG_CFG, " leftsubnet=%s", msg->add_conn.other.subnet); + DBG2(DBG_CFG, " rightid=%s", msg->add_conn.me.id); + DBG2(DBG_CFG, " leftid=%s", msg->add_conn.other.id); + DBG2(DBG_CFG, " rightcert=%s", msg->add_conn.me.cert); + DBG2(DBG_CFG, " leftcert=%s", msg->add_conn.other.cert); + DBG2(DBG_CFG, " rightca=%s", msg->add_conn.me.ca); + DBG2(DBG_CFG, " leftca=%s", msg->add_conn.other.ca); + DBG2(DBG_CFG, " ike=%s", msg->add_conn.algorithms.ike); + DBG2(DBG_CFG, " esp=%s", msg->add_conn.algorithms.esp); my_host = msg->add_conn.me.address? host_create_from_string(msg->add_conn.me.address, IKE_PORT) : NULL; if (my_host == NULL) { - DBG1(SIG_DBG_CFG, "invalid host: %s\n", msg->add_conn.me.address); + DBG1(DBG_CFG, "invalid host: %s\n", msg->add_conn.me.address); return; } @@ -206,7 +206,7 @@ static void stroke_add_conn(private_stroke_t *this, stroke_msg_t *msg) host_create_from_string(msg->add_conn.other.address, IKE_PORT) : NULL; if (other_host == NULL) { - DBG1(SIG_DBG_CFG, "invalid host: %s\n", msg->add_conn.other.address); + DBG1(DBG_CFG, "invalid host: %s\n", msg->add_conn.other.address); my_host->destroy(my_host); return; } @@ -216,7 +216,7 @@ static void stroke_add_conn(private_stroke_t *this, stroke_msg_t *msg) stroke_end_t tmp_end; host_t *tmp_host; - DBG2(SIG_DBG_CFG, "left is other host, swapping ends\n"); + DBG2(DBG_CFG, "left is other host, swapping ends\n"); tmp_host = my_host; my_host = other_host; @@ -228,7 +228,7 @@ static void stroke_add_conn(private_stroke_t *this, stroke_msg_t *msg) } else if (!charon->socket->is_local_address(charon->socket, my_host, NULL)) { - DBG1(SIG_DBG_CFG, "left nor right host is our side, aborting\n"); + DBG1(DBG_CFG, "left nor right host is our side, aborting\n"); goto destroy_hosts; } @@ -236,7 +236,7 @@ static void stroke_add_conn(private_stroke_t *this, stroke_msg_t *msg) msg->add_conn.me.id : msg->add_conn.me.address); if (my_id == NULL) { - DBG1(SIG_DBG_CFG, "invalid ID: %s\n", msg->add_conn.me.id); + DBG1(DBG_CFG, "invalid ID: %s\n", msg->add_conn.me.id); goto destroy_hosts; } @@ -244,7 +244,7 @@ static void stroke_add_conn(private_stroke_t *this, stroke_msg_t *msg) msg->add_conn.other.id : msg->add_conn.other.address); if (other_id == NULL) { - DBG1(SIG_DBG_CFG, "invalid ID: %s\n", msg->add_conn.other.id); + DBG1(DBG_CFG, "invalid ID: %s\n", msg->add_conn.other.id); my_id->destroy(my_id); goto destroy_hosts; } @@ -253,7 +253,7 @@ static void stroke_add_conn(private_stroke_t *this, stroke_msg_t *msg) msg->add_conn.me.subnet : msg->add_conn.me.address, IKE_PORT); if (my_subnet == NULL) { - DBG1(SIG_DBG_CFG, "invalid subnet: %s\n", msg->add_conn.me.subnet); + DBG1(DBG_CFG, "invalid subnet: %s\n", msg->add_conn.me.subnet); goto destroy_ids; } @@ -261,7 +261,7 @@ static void stroke_add_conn(private_stroke_t *this, stroke_msg_t *msg) msg->add_conn.other.subnet : msg->add_conn.other.address, IKE_PORT); if (other_subnet == NULL) { - DBG1(SIG_DBG_CFG, "invalid subnet: %s\n", msg->add_conn.me.subnet); + DBG1(DBG_CFG, "invalid subnet: %s\n", msg->add_conn.me.subnet); my_subnet->destroy(my_subnet); goto destroy_ids; } @@ -336,9 +336,9 @@ static void stroke_add_conn(private_stroke_t *this, stroke_msg_t *msg) { other_ca = identification_create_from_string("%any"); } - DBG2(SIG_DBG_CFG, " my ca: '%D'", my_ca); - DBG2(SIG_DBG_CFG, " other ca:'%D'", other_ca); - DBG2(SIG_DBG_CFG, " updown: '%s'", msg->add_conn.me.updown); + DBG2(DBG_CFG, " my ca: '%D'", my_ca); + DBG2(DBG_CFG, " other ca:'%D'", other_ca); + DBG2(DBG_CFG, " updown: '%s'", msg->add_conn.me.updown); connection = connection_create(msg->add_conn.name, msg->add_conn.ikev2, @@ -366,7 +366,7 @@ static void stroke_add_conn(private_stroke_t *this, stroke_msg_t *msg) proposal = proposal_create_from_string(PROTO_IKE, proposal_string); if (proposal == NULL) { - DBG1(SIG_DBG_CFG, "invalid IKE proposal string: %s", proposal_string); + DBG1(DBG_CFG, "invalid IKE proposal string: %s", proposal_string); my_id->destroy(my_id); other_id->destroy(other_id); my_ts->destroy(my_ts); @@ -416,7 +416,7 @@ static void stroke_add_conn(private_stroke_t *this, stroke_msg_t *msg) proposal = proposal_create_from_string(PROTO_ESP, proposal_string); if (proposal == NULL) { - DBG1(SIG_DBG_CFG, "invalid ESP proposal string: %s", proposal_string); + DBG1(DBG_CFG, "invalid ESP proposal string: %s", proposal_string); policy->destroy(policy); connection->destroy(connection); return; @@ -437,7 +437,7 @@ static void stroke_add_conn(private_stroke_t *this, stroke_msg_t *msg) /* add to global connection list */ charon->connections->add_connection(charon->connections, connection); - DBG1(SIG_DBG_CFG, "added connection '%s': %H[%D]...%H[%D]", + DBG1(DBG_CFG, "added connection '%s': %H[%D]...%H[%D]", msg->add_conn.name, my_host, my_id, other_host, other_id); /* add to global policy list */ charon->policies->add_policy(charon->policies, policy); @@ -463,7 +463,7 @@ static void stroke_del_conn(private_stroke_t *this, stroke_msg_t *msg) status_t status; pop_string(msg, &(msg->del_conn.name)); - DBG1(SIG_DBG_CFG, "received stroke: delete '%s'", msg->del_conn.name); + DBG1(DBG_CFG, "received stroke: delete '%s'", msg->del_conn.name); status = charon->connections->delete_connection(charon->connections, msg->del_conn.name); @@ -490,7 +490,7 @@ static void stroke_initiate(private_stroke_t *this, stroke_msg_t *msg) signal_t signal; pop_string(msg, &(msg->initiate.name)); - DBG1(SIG_DBG_CFG, "received stroke: initiate '%s'", msg->initiate.name); + DBG1(DBG_CFG, "received stroke: initiate '%s'", msg->initiate.name); connection = charon->connections->get_connection_by_name(charon->connections, msg->initiate.name); @@ -519,10 +519,6 @@ static void stroke_initiate(private_stroke_t *this, stroke_msg_t *msg) connection->destroy(connection); return; } - if (msg->output_verbosity >= 0) - { - fprintf(this->out, "initiating connection '%s'\n", msg->initiate.name); - } job = initiate_job_create(connection, policy); @@ -552,17 +548,16 @@ static void stroke_initiate(private_stroke_t *this, stroke_msg_t *msg) /* TODO: Handle INVALID_KE_PAYLOAD signal (ike_sa switch) */ switch (signal) { - case SIG_IKE_UP: - case SIG_IKE_FAILED: - case SIG_CHILD_UP: - case SIG_CHILD_FAILED: + case CHILD_UP_SUCCESS: + case CHILD_UP_FAILED: if (ike_sa == init_ike_sa) { charon->bus->set_listen_state(charon->bus, FALSE); return; } continue; - case SIG_INITIATE: + case CHILD_UP_START: + case IKE_UP_START: if (init_ike_sa == NULL) { init_ike_sa = ike_sa; @@ -584,7 +579,7 @@ static void stroke_route(private_stroke_t *this, stroke_msg_t *msg, bool route) policy_t *policy; pop_string(msg, &(msg->route.name)); - DBG1(SIG_DBG_CFG, "received stroke: %s '%s'", + DBG1(DBG_CFG, "received stroke: %s '%s'", route ? "route" : "unroute", msg->route.name); /* we wouldn't need a connection, but we only want to route policies @@ -622,7 +617,7 @@ static void stroke_route(private_stroke_t *this, stroke_msg_t *msg, bool route) static void stroke_terminate(private_stroke_t *this, stroke_msg_t *msg) { pop_string(msg, &(msg->terminate.name)); - DBG1(SIG_DBG_CFG, "received stroke: terminate '%s'", msg->terminate.name); + DBG1(DBG_CFG, "received stroke: terminate '%s'", msg->terminate.name); charon->ike_sa_manager->delete_by_name(charon->ike_sa_manager, msg->terminate.name); } @@ -843,15 +838,15 @@ static void stroke_reread(private_stroke_t *this, stroke_msg_t *msg) signal_t get_signal_from_logtype(char *type) { if (strcasecmp(type, "any") == 0) return SIG_ANY; - else if (strcasecmp(type, "mgr") == 0) return SIG_DBG_MGR; - else if (strcasecmp(type, "ike") == 0) return SIG_DBG_IKE; - else if (strcasecmp(type, "chd") == 0) return SIG_DBG_CHD; - else if (strcasecmp(type, "job") == 0) return SIG_DBG_JOB; - else if (strcasecmp(type, "cfg") == 0) return SIG_DBG_CFG; - else if (strcasecmp(type, "knl") == 0) return SIG_DBG_KNL; - else if (strcasecmp(type, "net") == 0) return SIG_DBG_NET; - else if (strcasecmp(type, "enc") == 0) return SIG_DBG_ENC; - else if (strcasecmp(type, "lib") == 0) return SIG_DBG_LIB; + else if (strcasecmp(type, "mgr") == 0) return DBG_MGR; + else if (strcasecmp(type, "ike") == 0) return DBG_IKE; + else if (strcasecmp(type, "chd") == 0) return DBG_CHD; + else if (strcasecmp(type, "job") == 0) return DBG_JOB; + else if (strcasecmp(type, "cfg") == 0) return DBG_CFG; + else if (strcasecmp(type, "knl") == 0) return DBG_KNL; + else if (strcasecmp(type, "net") == 0) return DBG_NET; + else if (strcasecmp(type, "enc") == 0) return DBG_ENC; + else if (strcasecmp(type, "lib") == 0) return DBG_LIB; else return -1; } @@ -863,7 +858,7 @@ static void stroke_loglevel(private_stroke_t *this, stroke_msg_t *msg) signal_t signal; pop_string(msg, &(msg->loglevel.type)); - DBG1(SIG_DBG_CFG, "received stroke: loglevel %d for %s", + DBG1(DBG_CFG, "received stroke: loglevel %d for %s", msg->loglevel.level, msg->loglevel.type); signal = get_signal_from_logtype(msg->loglevel.type); @@ -902,7 +897,7 @@ static void stroke_receive(private_stroke_t *this) if (strokefd < 0) { - DBG1(SIG_DBG_CFG, "accepting stroke connection failed: %m"); + DBG1(DBG_CFG, "accepting stroke connection failed: %m"); continue; } @@ -910,7 +905,7 @@ static void stroke_receive(private_stroke_t *this) bytes_read = recv(strokefd, &msg_length, sizeof(msg_length), MSG_PEEK); if (bytes_read != sizeof(msg_length)) { - DBG1(SIG_DBG_CFG, "reading lenght of stroke message failed"); + DBG1(DBG_CFG, "reading lenght of stroke message failed"); close(strokefd); continue; } @@ -920,7 +915,7 @@ static void stroke_receive(private_stroke_t *this) bytes_read = recv(strokefd, msg, msg_length, 0); if (bytes_read != msg_length) { - DBG1(SIG_DBG_CFG, "reading stroke message failed: %m"); + DBG1(DBG_CFG, "reading stroke message failed: %m"); close(strokefd); continue; } @@ -928,13 +923,13 @@ static void stroke_receive(private_stroke_t *this) this->out = fdopen(dup(strokefd), "w"); if (this->out == NULL) { - DBG1(SIG_DBG_CFG, "opening stroke output channel failed: %m"); + DBG1(DBG_CFG, "opening stroke output channel failed: %m"); close(strokefd); free(msg); continue; } - DBG3(SIG_DBG_CFG, "stroke message %b", (void*)msg, msg_length); + DBG3(DBG_CFG, "stroke message %b", (void*)msg, msg_length); switch (msg->type) { @@ -972,7 +967,7 @@ static void stroke_receive(private_stroke_t *this) stroke_reread(this, msg); break; default: - DBG1(SIG_DBG_CFG, "received unknown stroke"); + DBG1(DBG_CFG, "received unknown stroke"); } fclose(this->out); close(strokefd); @@ -1008,7 +1003,7 @@ stroke_t *stroke_create() this->socket = socket(AF_UNIX, SOCK_STREAM, 0); if (this->socket == -1) { - DBG1(SIG_DBG_CFG, "could not create whack socket"); + DBG1(DBG_CFG, "could not create whack socket"); free(this); return NULL; } @@ -1016,7 +1011,7 @@ stroke_t *stroke_create() old = umask(~S_IRWXU); if (bind(this->socket, (struct sockaddr *)&socket_addr, sizeof(socket_addr)) < 0) { - DBG1(SIG_DBG_CFG, "could not bind stroke socket: %m"); + DBG1(DBG_CFG, "could not bind stroke socket: %m"); close(this->socket); free(this); return NULL; @@ -1025,7 +1020,7 @@ stroke_t *stroke_create() if (listen(this->socket, 0) < 0) { - DBG1(SIG_DBG_CFG, "could not listen on stroke socket: %m"); + DBG1(DBG_CFG, "could not listen on stroke socket: %m"); close(this->socket); unlink(socket_addr.sun_path); free(this); @@ -1035,7 +1030,7 @@ stroke_t *stroke_create() /* start a thread reading from the socket */ if (pthread_create(&(this->assigned_thread), NULL, (void*(*)(void*))stroke_receive, this) != 0) { - DBG1(SIG_DBG_CFG, "Could not spawn stroke thread"); + DBG1(DBG_CFG, "could not spawn stroke thread"); close(this->socket); unlink(socket_addr.sun_path); free(this); |