xref: /dflybsd-src/contrib/wpa_supplicant/src/eap_common/eap_defs.h (revision 3a84a4273475ed07d0ab1c2dfeffdfedef35d9cd)
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