EAP-TEAP peer: Support vendor EAP method in Phase 2
The implementation was previously hardcoded to use only the non-expanded IETF EAP methods in Phase 2. Extend that to allow vendor EAP methods with expanded header to be used. Signed-off-by: Jouni Malinen <j@w1.fi>
This commit is contained in:
parent
aba8dc82fc
commit
62af2b18f7
3 changed files with 37 additions and 16 deletions
|
@ -679,12 +679,13 @@ struct wpabuf * eap_teap_tlv_error(enum teap_error_codes error)
|
|||
}
|
||||
|
||||
|
||||
int eap_teap_allowed_anon_prov_phase2_method(u8 type)
|
||||
int eap_teap_allowed_anon_prov_phase2_method(int vendor, enum eap_type type)
|
||||
{
|
||||
/* RFC 7170, Section 3.8.3: MUST provide mutual authentication,
|
||||
* provide key generation, and be resistant to dictionary attack.
|
||||
* Section 3.8 also mentions requirement for using EMSK Compound MAC. */
|
||||
return type == EAP_TYPE_PWD || type == EAP_TYPE_EKE;
|
||||
return vendor == EAP_VENDOR_IETF &&
|
||||
(type == EAP_TYPE_PWD || type == EAP_TYPE_EKE);
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -215,7 +215,8 @@ int eap_teap_parse_tlv(struct eap_teap_tlv_parse *tlv,
|
|||
const char * eap_teap_tlv_type_str(enum teap_tlv_types type);
|
||||
struct wpabuf * eap_teap_tlv_result(int status, int intermediate);
|
||||
struct wpabuf * eap_teap_tlv_error(enum teap_error_codes error);
|
||||
int eap_teap_allowed_anon_prov_phase2_method(u8 type);
|
||||
enum eap_type;
|
||||
int eap_teap_allowed_anon_prov_phase2_method(int vendor, enum eap_type type);
|
||||
int eap_teap_allowed_anon_prov_cipher_suite(u16 cs);
|
||||
|
||||
#endif /* EAP_TEAP_H */
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue