16d49e1aeSJan Lentfer /* 26d49e1aeSJan Lentfer * EAP server/peer: Shared EAP definitions 3*a1157835SDaniel Fojt * Copyright (c) 2004-2014, Jouni Malinen <j@w1.fi> 46d49e1aeSJan Lentfer * 53ff40c12SJohn Marino * This software may be distributed under the terms of the BSD license. 63ff40c12SJohn Marino * See README for more details. 76d49e1aeSJan Lentfer */ 86d49e1aeSJan Lentfer 96d49e1aeSJan Lentfer #ifndef EAP_DEFS_H 106d49e1aeSJan Lentfer #define EAP_DEFS_H 116d49e1aeSJan Lentfer 126d49e1aeSJan Lentfer /* RFC 3748 - Extensible Authentication Protocol (EAP) */ 136d49e1aeSJan Lentfer 146d49e1aeSJan Lentfer #ifdef _MSC_VER 156d49e1aeSJan Lentfer #pragma pack(push, 1) 166d49e1aeSJan Lentfer #endif /* _MSC_VER */ 176d49e1aeSJan Lentfer 186d49e1aeSJan Lentfer struct eap_hdr { 196d49e1aeSJan Lentfer u8 code; 206d49e1aeSJan Lentfer u8 identifier; 216d49e1aeSJan Lentfer be16 length; /* including code and identifier; network byte order */ 226d49e1aeSJan Lentfer /* followed by length-4 octets of data */ 236d49e1aeSJan Lentfer } STRUCT_PACKED; 246d49e1aeSJan Lentfer 256d49e1aeSJan Lentfer #ifdef _MSC_VER 266d49e1aeSJan Lentfer #pragma pack(pop) 276d49e1aeSJan Lentfer #endif /* _MSC_VER */ 286d49e1aeSJan Lentfer 296d49e1aeSJan Lentfer enum { EAP_CODE_REQUEST = 1, EAP_CODE_RESPONSE = 2, EAP_CODE_SUCCESS = 3, 30*a1157835SDaniel Fojt EAP_CODE_FAILURE = 4, EAP_CODE_INITIATE = 5, EAP_CODE_FINISH = 6 }; 316d49e1aeSJan Lentfer 326d49e1aeSJan Lentfer /* EAP Request and Response data begins with one octet Type. Success and 336d49e1aeSJan Lentfer * Failure do not have additional data. */ 346d49e1aeSJan Lentfer 35*a1157835SDaniel Fojt /* Type field in EAP-Initiate and EAP-Finish messages */ 36*a1157835SDaniel Fojt enum eap_erp_type { 37*a1157835SDaniel Fojt EAP_ERP_TYPE_REAUTH_START = 1, 38*a1157835SDaniel Fojt EAP_ERP_TYPE_REAUTH = 2, 39*a1157835SDaniel Fojt }; 40*a1157835SDaniel Fojt 41*a1157835SDaniel Fojt /* ERP TV/TLV types */ 42*a1157835SDaniel Fojt enum eap_erp_tlv_type { 43*a1157835SDaniel Fojt EAP_ERP_TLV_KEYNAME_NAI = 1, 44*a1157835SDaniel Fojt EAP_ERP_TV_RRK_LIFETIME = 2, 45*a1157835SDaniel Fojt EAP_ERP_TV_RMSK_LIFETIME = 3, 46*a1157835SDaniel Fojt EAP_ERP_TLV_DOMAIN_NAME = 4, 47*a1157835SDaniel Fojt EAP_ERP_TLV_CRYPTOSUITES = 5, 48*a1157835SDaniel Fojt EAP_ERP_TLV_AUTHORIZATION_INDICATION = 6, 49*a1157835SDaniel Fojt EAP_ERP_TLV_CALLED_STATION_ID = 128, 50*a1157835SDaniel Fojt EAP_ERP_TLV_CALLING_STATION_ID = 129, 51*a1157835SDaniel Fojt EAP_ERP_TLV_NAS_IDENTIFIER = 130, 52*a1157835SDaniel Fojt EAP_ERP_TLV_NAS_IP_ADDRESS = 131, 53*a1157835SDaniel Fojt EAP_ERP_TLV_NAS_IPV6_ADDRESS = 132, 54*a1157835SDaniel Fojt }; 55*a1157835SDaniel Fojt 56*a1157835SDaniel Fojt /* ERP Cryptosuite */ 57*a1157835SDaniel Fojt enum eap_erp_cryptosuite { 58*a1157835SDaniel Fojt EAP_ERP_CS_HMAC_SHA256_64 = 1, 59*a1157835SDaniel Fojt EAP_ERP_CS_HMAC_SHA256_128 = 2, 60*a1157835SDaniel Fojt EAP_ERP_CS_HMAC_SHA256_256 = 3, 61*a1157835SDaniel Fojt }; 62*a1157835SDaniel Fojt 636d49e1aeSJan Lentfer /* 646d49e1aeSJan Lentfer * EAP Method Types as allocated by IANA: 656d49e1aeSJan Lentfer * http://www.iana.org/assignments/eap-numbers 666d49e1aeSJan Lentfer */ 676d49e1aeSJan Lentfer typedef enum { 686d49e1aeSJan Lentfer EAP_TYPE_NONE = 0, 696d49e1aeSJan Lentfer EAP_TYPE_IDENTITY = 1 /* RFC 3748 */, 706d49e1aeSJan Lentfer EAP_TYPE_NOTIFICATION = 2 /* RFC 3748 */, 716d49e1aeSJan Lentfer EAP_TYPE_NAK = 3 /* Response only, RFC 3748 */, 726d49e1aeSJan Lentfer EAP_TYPE_MD5 = 4, /* RFC 3748 */ 736d49e1aeSJan Lentfer EAP_TYPE_OTP = 5 /* RFC 3748 */, 746d49e1aeSJan Lentfer EAP_TYPE_GTC = 6, /* RFC 3748 */ 756d49e1aeSJan Lentfer EAP_TYPE_TLS = 13 /* RFC 2716 */, 766d49e1aeSJan Lentfer EAP_TYPE_LEAP = 17 /* Cisco proprietary */, 776d49e1aeSJan Lentfer EAP_TYPE_SIM = 18 /* RFC 4186 */, 786d49e1aeSJan Lentfer EAP_TYPE_TTLS = 21 /* RFC 5281 */, 796d49e1aeSJan Lentfer EAP_TYPE_AKA = 23 /* RFC 4187 */, 806d49e1aeSJan Lentfer EAP_TYPE_PEAP = 25 /* draft-josefsson-pppext-eap-tls-eap-06.txt */, 816d49e1aeSJan Lentfer EAP_TYPE_MSCHAPV2 = 26 /* draft-kamath-pppext-eap-mschapv2-00.txt */, 826d49e1aeSJan Lentfer EAP_TYPE_TLV = 33 /* draft-josefsson-pppext-eap-tls-eap-07.txt */, 836d49e1aeSJan Lentfer EAP_TYPE_TNC = 38 /* TNC IF-T v1.0-r3; note: tentative assignment; 846d49e1aeSJan Lentfer * type 38 has previously been allocated for 856d49e1aeSJan Lentfer * EAP-HTTP Digest, (funk.com) */, 866d49e1aeSJan Lentfer EAP_TYPE_FAST = 43 /* RFC 4851 */, 876d49e1aeSJan Lentfer EAP_TYPE_PAX = 46 /* RFC 4746 */, 886d49e1aeSJan Lentfer EAP_TYPE_PSK = 47 /* RFC 4764 */, 896d49e1aeSJan Lentfer EAP_TYPE_SAKE = 48 /* RFC 4763 */, 906d49e1aeSJan Lentfer EAP_TYPE_IKEV2 = 49 /* RFC 5106 */, 913ff40c12SJohn Marino EAP_TYPE_AKA_PRIME = 50 /* RFC 5448 */, 926d49e1aeSJan Lentfer EAP_TYPE_GPSK = 51 /* RFC 5433 */, 933ff40c12SJohn Marino EAP_TYPE_PWD = 52 /* RFC 5931 */, 943ff40c12SJohn Marino EAP_TYPE_EKE = 53 /* RFC 6124 */, 95*a1157835SDaniel Fojt EAP_TYPE_TEAP = 55 /* RFC 7170 */, 966d49e1aeSJan Lentfer EAP_TYPE_EXPANDED = 254 /* RFC 3748 */ 976d49e1aeSJan Lentfer } EapType; 986d49e1aeSJan Lentfer 996d49e1aeSJan Lentfer 1006d49e1aeSJan Lentfer /* SMI Network Management Private Enterprise Code for vendor specific types */ 1016d49e1aeSJan Lentfer enum { 1026d49e1aeSJan Lentfer EAP_VENDOR_IETF = 0, 1036d49e1aeSJan Lentfer EAP_VENDOR_MICROSOFT = 0x000137 /* Microsoft */, 104*a1157835SDaniel Fojt EAP_VENDOR_WFA = 0x00372A /* Wi-Fi Alliance (moved to WBA) */, 105*a1157835SDaniel Fojt EAP_VENDOR_HOSTAP = 39068 /* hostapd/wpa_supplicant project */, 106*a1157835SDaniel Fojt EAP_VENDOR_WFA_NEW = 40808 /* Wi-Fi Alliance */ 1076d49e1aeSJan Lentfer }; 1086d49e1aeSJan Lentfer 1093ff40c12SJohn Marino #define EAP_VENDOR_UNAUTH_TLS EAP_VENDOR_HOSTAP 1103ff40c12SJohn Marino #define EAP_VENDOR_TYPE_UNAUTH_TLS 1 1113ff40c12SJohn Marino 112*a1157835SDaniel Fojt #define EAP_VENDOR_WFA_UNAUTH_TLS 13 113*a1157835SDaniel Fojt 1146d49e1aeSJan Lentfer #define EAP_MSK_LEN 64 1156d49e1aeSJan Lentfer #define EAP_EMSK_LEN 64 116*a1157835SDaniel Fojt #define EAP_EMSK_NAME_LEN 8 117*a1157835SDaniel Fojt #define ERP_MAX_KEY_LEN 64 1186d49e1aeSJan Lentfer 1196d49e1aeSJan Lentfer #endif /* EAP_DEFS_H */ 120