diff options
author | Martin Willi <martin@strongswan.org> | 2009-11-30 09:58:54 +0100 |
---|---|---|
committer | Martin Willi <martin@strongswan.org> | 2009-11-30 10:00:06 +0100 |
commit | bff9f824ed0774e0410c28d92834c23b03337219 (patch) | |
tree | 0f8e3fae734a553c1aa027894adacdc0a89f9b8f /src/charon/plugins/eap_sim/eap_sim_server.c | |
parent | b04e72c21c08caae6cbb0e2b68545461aaf36db6 (diff) | |
download | strongswan-bff9f824ed0774e0410c28d92834c23b03337219.tar.bz2 strongswan-bff9f824ed0774e0410c28d92834c23b03337219.tar.xz |
Verify EAP-SIM/AKA AT_MAC before processing any attributes
Diffstat (limited to 'src/charon/plugins/eap_sim/eap_sim_server.c')
-rw-r--r-- | src/charon/plugins/eap_sim/eap_sim_server.c | 20 |
1 files changed, 10 insertions, 10 deletions
diff --git a/src/charon/plugins/eap_sim/eap_sim_server.c b/src/charon/plugins/eap_sim/eap_sim_server.c index 03b6a19d6..f6d5df09b 100644 --- a/src/charon/plugins/eap_sim/eap_sim_server.c +++ b/src/charon/plugins/eap_sim/eap_sim_server.c @@ -196,6 +196,11 @@ static status_t process_reauthentication(private_eap_sim_server_t *this, simaka_subtype_names, SIM_REAUTHENTICATION); return FAILED; } + /* verify AT_MAC attribute, signature is over "EAP packet | NONCE_S" */ + if (!in->verify(in, this->nonce)) + { + return FAILED; + } enumerator = in->create_attribute_enumerator(in); while (enumerator->enumerate(enumerator, &type, &data)) @@ -219,11 +224,6 @@ static status_t process_reauthentication(private_eap_sim_server_t *this, } enumerator->destroy(enumerator); - /* verify AT_MAC attribute, signature is over "EAP packet | NONCE_S" */ - if (!in->verify(in, this->nonce)) - { - return FAILED; - } if (too_small) { DBG1(DBG_IKE, "received %N, initiating full authentication", @@ -429,6 +429,11 @@ static status_t process_challenge(private_eap_sim_server_t *this, simaka_subtype_names, SIM_CHALLENGE); return FAILED; } + /* verify AT_MAC attribute, signature is over "EAP packet | n*SRES" */ + if (!in->verify(in, this->sreses)) + { + return FAILED; + } enumerator = in->create_attribute_enumerator(in); while (enumerator->enumerate(enumerator, &type, &data)) @@ -441,11 +446,6 @@ static status_t process_challenge(private_eap_sim_server_t *this, } enumerator->destroy(enumerator); - /* verify AT_MAC attribute, signature is over "EAP packet | n*SRES" */ - if (!in->verify(in, this->sreses)) - { - return FAILED; - } return SUCCESS; } |