Complete rewrite of RADIUS encode/decode routines.
[freeradius.git] / src / include / radius.h
1 /*
2  * radius.h     Constants of the radius protocol.
3  *
4  * Version:     $Id$
5  *
6  */
7
8
9 #define PW_TYPE_STRING                  0
10 #define PW_TYPE_INTEGER                 1
11 #define PW_TYPE_IPADDR                  2
12 #define PW_TYPE_DATE                    3
13 #define PW_TYPE_ABINARY                 4
14 #define PW_TYPE_OCTETS                  5
15 #define PW_TYPE_IFID                    6
16 #define PW_TYPE_IPV6ADDR                7
17 #define PW_TYPE_IPV6PREFIX              8
18 #define PW_TYPE_BYTE                    9
19 #define PW_TYPE_SHORT                   10
20 #define PW_TYPE_ETHERNET                11
21 #define PW_TYPE_SIGNED                  12
22 #define PW_TYPE_COMBO_IP                13
23 #define PW_TYPE_TLV                     14
24 #define PW_TYPE_EXTENDED                15
25 #define PW_TYPE_EXTENDED_FLAGS          16
26 #define PW_TYPE_EVS                     17
27
28 #define PW_AUTHENTICATION_REQUEST       1
29 #define PW_AUTHENTICATION_ACK           2
30 #define PW_AUTHENTICATION_REJECT        3
31 #define PW_ACCOUNTING_REQUEST           4
32 #define PW_ACCOUNTING_RESPONSE          5
33 #define PW_ACCOUNTING_STATUS            6
34 #define PW_PASSWORD_REQUEST             7
35 #define PW_PASSWORD_ACK                 8
36 #define PW_PASSWORD_REJECT              9
37 #define PW_ACCOUNTING_MESSAGE           10
38 #define PW_ACCESS_CHALLENGE             11
39 #define PW_STATUS_SERVER                12
40 #define PW_STATUS_CLIENT                13
41 #define PW_DISCONNECT_REQUEST           40
42 #define PW_DISCONNECT_ACK               41
43 #define PW_DISCONNECT_NAK               42
44 #define PW_COA_REQUEST                  43
45 #define PW_COA_ACK                      44
46 #define PW_COA_NAK                      45
47
48 #define PW_AUTH_UDP_PORT                1812
49 #define PW_ACCT_UDP_PORT                1813
50 #define PW_POD_UDP_PORT                 1700
51 #define PW_COA_UDP_PORT                 3799
52
53 #define PW_USER_NAME                    1
54 #define PW_USER_PASSWORD                2
55 #define PW_PASSWORD                     2
56 #define PW_CHAP_PASSWORD                3
57 #define PW_NAS_IP_ADDRESS               4
58 #define PW_NAS_PORT                     5
59 #define PW_SERVICE_TYPE                 6
60 #define PW_FRAMED_PROTOCOL              7
61 #define PW_FRAMED_IP_ADDRESS            8
62 #define PW_FRAMED_IP_NETMASK            9
63 #define PW_FRAMED_ROUTING               10
64 #define PW_FILTER_ID                    11
65 #define PW_FRAMED_MTU                   12
66 #define PW_FRAMED_COMPRESSION           13
67 #define PW_LOGIN_IP_HOST                14
68 #define PW_LOGIN_SERVICE                15
69 #define PW_LOGIN_TCP_PORT               16
70 #define PW_OLD_PASSWORD                 17
71 #define PW_REPLY_MESSAGE                18
72 #define PW_CALLBACK_NUMBER              19
73 #define PW_CALLBACK_ID                  20
74 #if 0
75 /*
76  *  Deprecated, and no longer used.
77  */
78 #define PW_EXPIRATION                   21
79 #endif
80 #define PW_FRAMED_ROUTE                 22
81 #define PW_FRAMED_IPXNET                23
82 #define PW_STATE                        24
83 #define PW_CLASS                        25
84 #define PW_VENDOR_SPECIFIC              26
85 #define PW_SESSION_TIMEOUT              27
86 #define PW_IDLE_TIMEOUT                 28
87 #define PW_CALLED_STATION_ID            30
88 #define PW_CALLING_STATION_ID           31
89 #define PW_NAS_IDENTIFIER               32
90 #define PW_PROXY_STATE                  33
91
92 #define PW_ACCT_STATUS_TYPE             40
93 #define PW_ACCT_DELAY_TIME              41
94 #define PW_ACCT_INPUT_OCTETS            42
95 #define PW_ACCT_OUTPUT_OCTETS           43
96 #define PW_ACCT_SESSION_ID              44
97 #define PW_ACCT_AUTHENTIC               45
98 #define PW_ACCT_SESSION_TIME            46
99 #define PW_ACCT_INPUT_PACKETS           47
100 #define PW_ACCT_OUTPUT_PACKETS          48
101 #define PW_ACCT_TERMINATE_CAUSE         49
102
103 #define PW_EVENT_TIMESTAMP              55
104
105 #define PW_CHAP_CHALLENGE               60
106 #define PW_NAS_PORT_TYPE                61
107 #define PW_PORT_LIMIT                   62
108
109 #define PW_ARAP_PASSWORD                70
110 #define PW_ARAP_FEATURES                71
111 #define PW_ARAP_ZONE_ACCESS             72
112 #define PW_ARAP_SECURITY                73
113 #define PW_ARAP_SECURITY_DATA           74
114 #define PW_PASSWORD_RETRY               75
115 #define PW_PROMPT                       76
116 #define PW_CONNECT_INFO                 77
117 #define PW_CONFIGURATION_TOKEN          78
118 #define PW_EAP_MESSAGE                  79
119 #define PW_MESSAGE_AUTHENTICATOR        80
120
121 #define PW_ARAP_CHALLENGE_RESPONSE      84
122 #define PW_NAS_PORT_ID_STRING           87
123 #define PW_FRAMED_POOL                  88
124 #define PW_CHARGEABLE_USER_IDENTITY     89
125 #define PW_NAS_IPV6_ADDRESS             95
126
127 #define PW_EXTENDED_ATTRIBUTE           192
128
129 #define PW_DIGEST_RESPONSE              206
130 #define PW_DIGEST_ATTRIBUTES            207
131
132 #define PW_FALL_THROUGH                 500
133 #define PW_EXEC_PROGRAM                 502
134 #define PW_EXEC_PROGRAM_WAIT            503
135
136 #define PW_AUTH_TYPE                    1000
137 #define PW_PREFIX                       1003
138 #define PW_SUFFIX                       1004
139 #define PW_GROUP                        1005
140 #define PW_CRYPT_PASSWORD               1006
141 #define PW_CONNECT_RATE                 1007
142 #define PW_ADD_PREFIX                   1008
143 #define PW_ADD_SUFFIX                   1009
144 #define PW_EXPIRATION                   1010
145 #define PW_AUTZ_TYPE                    1011
146 #define PW_ACCT_TYPE                    1012
147 #define PW_SESSION_TYPE                 1013
148 #define PW_POST_AUTH_TYPE               1014
149 #define PW_PRE_PROXY_TYPE               1015
150 #define PW_POST_PROXY_TYPE              1016
151 #define PW_PRE_ACCT_TYPE                1017
152 #define PW_EAP_TYPE                     1018
153 #define PW_EAP_TLS_REQUIRE_CLIENT_CERT  1019
154 #define PW_CLIENT_SHORTNAME             1024
155 #define PW_LOAD_BALANCE_KEY             1025
156 #define PW_RAW_ATTRIBUTE                1026
157 #define PW_TNC_VLAN_ACCESS              1027
158 #define PW_TNC_VLAN_ISOLATE             1028
159 #define PW_USER_CATEGORY                1029
160 #define PW_GROUP_NAME                   1030
161 #define PW_HUNTGROUP_NAME               1031
162 #define PW_SIMULTANEOUS_USE             1034
163 #define PW_STRIP_USER_NAME              1035
164 #define PW_HINT                         1040
165 #define PAM_AUTH_ATTR                   1041
166 #define PW_LOGIN_TIME                   1042
167 #define PW_STRIPPED_USER_NAME           1043
168 #define PW_CURRENT_TIME                 1044
169 #define PW_REALM                        1045
170 #define PW_NO_SUCH_ATTRIBUTE            1046
171 #define PW_PACKET_TYPE                  1047
172 #define PW_PROXY_TO_REALM               1048
173 #define PW_REPLICATE_TO_REALM           1049
174 #define PW_ACCT_SESSION_START_TIME      1050
175 #define PW_ACCT_UNIQUE_SESSION_ID       1051
176 #define PW_CLIENT_IP_ADDRESS            1052
177 #define PW_LDAP_USERDN                  1053
178 #define PW_NS_MTA_MD5_PASSWORD          1054
179 #define PW_SQL_USER_NAME                1055
180 #define PW_LM_PASSWORD                  1057
181 #define PW_NT_PASSWORD                  1058
182 #define PW_SMB_ACCOUNT_CTRL             1059
183 #define PW_SMB_ACCOUNT_CTRL_TEXT        1061
184 #define PW_USER_PROFILE                 1062
185 #define PW_DIGEST_REALM                 1063
186 #define PW_DIGEST_NONCE                 1064
187 #define PW_DIGEST_METHOD                1065
188 #define PW_DIGEST_URI                   1066
189 #define PW_DIGEST_QOP                   1067
190 #define PW_DIGEST_ALGORITHM             1068
191 #define PW_DIGEST_BODY_DIGEST           1069
192 #define PW_DIGEST_CNONCE                1070
193 #define PW_DIGEST_NONCE_COUNT           1071
194 #define PW_DIGEST_USER_NAME             1072
195 #define PW_POOL_NAME                    1073
196 #define PW_LDAP_GROUP                   1074
197 #define PW_MODULE_SUCCESS_MESSAGE       1075
198 #define PW_MODULE_FAILURE_MESSAGE       1076
199 #if 0 /* no longer used */
200 #define PW_X99_FAST                     1077
201 #endif
202 #define PW_REWRITE_RULE                 1078
203 #define PW_SQL_GROUP                    1079
204 #define PW_RESPONSE_PACKET_TYPE         1080
205 #define PW_DIGEST_HA1                   1081
206 #define PW_MS_CHAP_USE_NTLM_AUTH        1082
207 #define PW_MS_CHAP_USER_NAME            1083
208 #define PW_PACKET_SRC_IP_ADDRESS        1084
209 #define PW_PACKET_DST_IP_ADDRESS        1085
210 #define PW_PACKET_SRC_PORT              1086
211 #define PW_PACKET_DST_PORT              1087
212 #define PW_PACKET_AUTHENTICATION_VECTOR 1088
213 #define PW_TIME_OF_DAY                  1089
214 #define PW_REQUEST_PROCESSING_STAGE     1090
215 #define PW_CACHE_NO_CACHING             1091
216 #define PW_CACHE_DELETE_CACHE           1092
217
218 #define PW_SHA_PASSWORD                 1093
219 #define PW_SSHA_PASSWORD                1094
220 #define PW_MD5_PASSWORD                 1095
221 #define PW_SMD5_PASSWORD                1096
222
223 #define PW_PACKET_SRC_IPV6_ADDRESS      1097
224 #define PW_PACKET_DST_IPV6_ADDRESS      1098
225 #define PW_VIRTUAL_SERVER               1099
226 #define PW_CLEARTEXT_PASSWORD           1100
227 #define PW_PASSWORD_WITH_HEADER         1101
228 #define PW_SEND_COA_REQUEST             1107
229 #define PW_MODULE_RETURN_CODE           1108
230 #define PW_PACKET_ORIGINAL_TIMESTAMP    1109
231 #define PW_HOME_SERVER_POOL             1111
232 #define PW_RECV_COA_TYPE                1131
233 #define PW_SEND_COA_TYPE                1132
234 #define PW_MSCHAP_PASSWORD              1133
235 #define PW_PACKET_TRANSMIT_COUNTER      1134
236 #define PW_CACHED_SESSION_POLICY        1135
237
238 /*
239  *      Integer Translations
240  */
241
242 /*      User Types      */
243
244 #define PW_LOGIN_USER                   1
245 #define PW_FRAMED_USER                  2
246 #define PW_CALLBACK_LOGIN_USER          3
247 #define PW_CALLBACK_FRAMED_USER         4
248 #define PW_OUTBOUND_USER                5
249 #define PW_ADMINISTRATIVE_USER          6
250 #define PW_NAS_PROMPT_USER              7
251 #define PW_AUTHENTICATE_ONLY            8
252 #define PW_CALLBACK_NAS_PROMPT          9
253
254 /*      Framed Protocols        */
255
256 #define PW_PPP                          1
257 #define PW_SLIP                         2
258
259 /*      Framed Routing Values   */
260
261 #define PW_NONE                         0
262 #define PW_BROADCAST                    1
263 #define PW_LISTEN                       2
264 #define PW_BROADCAST_LISTEN             3
265
266 /*      Framed Compression Types        */
267
268 #define PW_VAN_JACOBSEN_TCP_IP          1
269
270 /*      Login Services  */
271
272 #define PW_TELNET                       0
273 #define PW_RLOGIN                       1
274 #define PW_TCP_CLEAR                    2
275 #define PW_PORTMASTER                   3
276
277 /*      Authentication Level    */
278
279 #define PW_AUTHTYPE_LOCAL               0
280 #define PW_AUTHTYPE_SYSTEM              1
281 #define PW_AUTHTYPE_SECURID             2
282 #define PW_AUTHTYPE_CRYPT               3
283 #define PW_AUTHTYPE_REJECT              4
284 #define PW_AUTHTYPE_ACTIVCARD           5
285 #define PW_AUTHTYPE_EAP                 6
286 #define PW_AUTHTYPE_ACCEPT              254
287 #define PW_AUTHTYPE_MS_CHAP             1028
288
289 /*      Port Types              */
290
291 #define PW_NAS_PORT_ASYNC               0
292 #define PW_NAS_PORT_SYNC                1
293 #define PW_NAS_PORT_ISDN                2
294 #define PW_NAS_PORT_ISDN_V120           3
295 #define PW_NAS_PORT_ISDN_V110           4
296
297 /*      Status Types    */
298
299 #define PW_STATUS_START                 1
300 #define PW_STATUS_STOP                  2
301 #define PW_STATUS_ALIVE                 3
302 #define PW_STATUS_ACCOUNTING_ON         7
303 #define PW_STATUS_ACCOUNTING_OFF        8
304
305 /*
306  *  Vendor Private Enterprise Codes
307  */
308 #define VENDORPEC_MICROSOFT     311
309 #define VENDORPEC_FREERADIUS    11344
310 #define VENDORPEC_WIMAX         24757
311 #define VENDORPEC_EXTENDED      (1 << 25)
312
313 /*
314  * Vendor specific attributes
315  */
316 #define PW_FREERADIUS_PROXIED_TO        1
317
318 /*
319  *  Microsoft has vendor code 311.
320  */
321 #define PW_MSCHAP_RESPONSE      1
322 #define PW_MSCHAP_ERROR         2
323 #define PW_MSCHAP_CHALLENGE     11
324 #define PW_MSCHAP2_RESPONSE     25
325 #define PW_MSCHAP2_SUCCESS      26
326
327
328 /*
329  *  Old nonsense.  Will be deleted ASAP
330  */
331 #define PW_AUTHTYPE                     1000
332 #define PW_AUTZTYPE                     1011
333 #define PW_ACCTTYPE                     1012
334 #define PW_SESSTYPE                     1013
335 #define PW_POSTAUTHTYPE                 1014
336
337 /*
338  *      Cisco's VLAN Query Protocol.
339  */
340 #define PW_VQP_PACKET_TYPE              0x2b00
341 #define PW_VQP_ERROR_CODE               0x2b01
342 #define PW_VQP_SEQUENCE_NUMBER          0x2b02
343
344 #define PW_VQP_CLIENT_IP_ADDRESS        0x2c01
345 #define PW_VQP_PORT_NAME                0x2c02
346 #define PW_VQP_VLAN_NAME                0x2c03
347 #define PW_VQP_DOMAIN_NAME              0x2c04
348 #define PW_VQP_ETHERNET_FRAME           0x2c05
349 #define PW_VQP_MAC                      0x2c06
350 #define PW_VQP_UNKNOWN                  0x2c07
351 #define PW_VQP_COOKIE                   0x2c08