radlib.h revision 234191
152419Sjulian/*-
252419Sjulian * Copyright 1998 Juniper Networks, Inc.
352419Sjulian * All rights reserved.
452419Sjulian *
552419Sjulian * Redistribution and use in source and binary forms, with or without
652419Sjulian * modification, are permitted provided that the following conditions
752419Sjulian * are met:
852419Sjulian * 1. Redistributions of source code must retain the above copyright
952419Sjulian *    notice, this list of conditions and the following disclaimer.
1052419Sjulian * 2. Redistributions in binary form must reproduce the above copyright
1152419Sjulian *    notice, this list of conditions and the following disclaimer in the
1252419Sjulian *    documentation and/or other materials provided with the distribution.
1352419Sjulian *
1452419Sjulian * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
1552419Sjulian * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
1652419Sjulian * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
1752419Sjulian * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
1852419Sjulian * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
1952419Sjulian * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
2052419Sjulian * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
2152419Sjulian * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
2252419Sjulian * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
2352419Sjulian * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
2452419Sjulian * SUCH DAMAGE.
2552419Sjulian *
2652419Sjulian *	$FreeBSD: stable/9/lib/libradius/radlib.h 234191 2012-04-12 17:49:53Z melifaro $
2752419Sjulian */
2852419Sjulian
2952419Sjulian#ifndef _RADLIB_H_
3052419Sjulian#define _RADLIB_H_
3152419Sjulian
3252419Sjulian#include <sys/types.h>
3352419Sjulian#include <netinet/in.h>
3452419Sjulian
3552419Sjulian/* Limits */
3652419Sjulian#define RAD_MAX_ATTR_LEN		253
3752419Sjulian
3852419Sjulian/* Message types */
3952419Sjulian#define RAD_ACCESS_REQUEST		1
40158882Sglebius#define RAD_ACCESS_ACCEPT		2
41158882Sglebius#define RAD_ACCESS_REJECT		3
42158882Sglebius#define RAD_ACCOUNTING_REQUEST		4
43158882Sglebius#define RAD_ACCOUNTING_RESPONSE		5
4452419Sjulian#define RAD_ACCESS_CHALLENGE		11
4552419Sjulian#define RAD_DISCONNECT_REQUEST		40
4652419Sjulian#define RAD_DISCONNECT_ACK		41
4752419Sjulian#define RAD_DISCONNECT_NAK		42
4852419Sjulian#define RAD_COA_REQUEST			43
4952419Sjulian#define RAD_COA_ACK			44
5052419Sjulian#define RAD_COA_NAK			45
5152419Sjulian
5253913Sarchie/* Attribute types and values */
5353913Sarchie#define RAD_USER_NAME			1	/* String */
5452419Sjulian#define RAD_USER_PASSWORD		2	/* String */
5552419Sjulian#define RAD_CHAP_PASSWORD		3	/* String */
5652419Sjulian#define RAD_NAS_IP_ADDRESS		4	/* IP address */
5752419Sjulian#define RAD_NAS_PORT			5	/* Integer */
5852419Sjulian#define RAD_SERVICE_TYPE		6	/* Integer */
5952419Sjulian	#define RAD_LOGIN			1
6052419Sjulian	#define RAD_FRAMED			2
6152419Sjulian	#define RAD_CALLBACK_LOGIN		3
6252419Sjulian	#define RAD_CALLBACK_FRAMED		4
6352419Sjulian	#define RAD_OUTBOUND			5
6452419Sjulian	#define RAD_ADMINISTRATIVE		6
6552419Sjulian	#define RAD_NAS_PROMPT			7
6652419Sjulian	#define RAD_AUTHENTICATE_ONLY		8
67160002Sglebius	#define RAD_CALLBACK_NAS_PROMPT		9
6852419Sjulian#define RAD_FRAMED_PROTOCOL		7	/* Integer */
6952419Sjulian	#define RAD_PPP				1
7052419Sjulian	#define RAD_SLIP			2
7152419Sjulian	#define RAD_ARAP			3	/* Appletalk */
7252419Sjulian	#define RAD_GANDALF			4
7352419Sjulian	#define RAD_XYLOGICS			5
74160002Sglebius#define RAD_FRAMED_IP_ADDRESS		8	/* IP address */
7552419Sjulian#define RAD_FRAMED_IP_NETMASK		9	/* IP address */
76160002Sglebius#define RAD_FRAMED_ROUTING		10	/* Integer */
7752419Sjulian#define RAD_FILTER_ID			11	/* String */
7852419Sjulian#define RAD_FRAMED_MTU			12	/* Integer */
7952419Sjulian#define RAD_FRAMED_COMPRESSION		13	/* Integer */
80	#define RAD_COMP_NONE			0
81	#define RAD_COMP_VJ			1
82	#define RAD_COMP_IPXHDR			2
83#define RAD_LOGIN_IP_HOST		14	/* IP address */
84#define RAD_LOGIN_SERVICE		15	/* Integer */
85#define RAD_LOGIN_TCP_PORT		16	/* Integer */
86     /* unassiged			17 */
87#define RAD_REPLY_MESSAGE		18	/* String */
88#define RAD_CALLBACK_NUMBER		19	/* String */
89#define RAD_CALLBACK_ID			20	/* String */
90     /* unassiged			21 */
91#define RAD_FRAMED_ROUTE		22	/* String */
92#define RAD_FRAMED_IPX_NETWORK		23	/* IP address */
93#define RAD_STATE			24	/* String */
94#define RAD_CLASS			25	/* Integer */
95#define RAD_VENDOR_SPECIFIC		26	/* Integer */
96#define RAD_SESSION_TIMEOUT		27	/* Integer */
97#define RAD_IDLE_TIMEOUT		28	/* Integer */
98#define RAD_TERMINATION_ACTION		29	/* Integer */
99#define RAD_CALLED_STATION_ID		30	/* String */
100#define RAD_CALLING_STATION_ID		31	/* String */
101#define RAD_NAS_IDENTIFIER		32	/* Integer */
102#define RAD_PROXY_STATE			33	/* Integer */
103#define RAD_LOGIN_LAT_SERVICE		34	/* Integer */
104#define RAD_LOGIN_LAT_NODE		35	/* Integer */
105#define RAD_LOGIN_LAT_GROUP		36	/* Integer */
106#define RAD_FRAMED_APPLETALK_LINK	37	/* Integer */
107#define RAD_FRAMED_APPLETALK_NETWORK	38	/* Integer */
108#define RAD_FRAMED_APPLETALK_ZONE	39	/* Integer */
109     /* reserved for accounting		40-59 */
110#define RAD_ACCT_INPUT_GIGAWORDS	52
111#define RAD_ACCT_OUTPUT_GIGAWORDS	53
112
113#define RAD_CHAP_CHALLENGE		60	/* String */
114#define RAD_NAS_PORT_TYPE		61	/* Integer */
115	#define RAD_ASYNC			0
116	#define RAD_SYNC			1
117	#define RAD_ISDN_SYNC			2
118	#define RAD_ISDN_ASYNC_V120		3
119	#define RAD_ISDN_ASYNC_V110		4
120	#define RAD_VIRTUAL			5
121	#define RAD_PIAFS			6
122	#define RAD_HDLC_CLEAR_CHANNEL		7
123	#define RAD_X_25			8
124	#define RAD_X_75			9
125	#define RAD_G_3_FAX			10
126	#define RAD_SDSL			11
127	#define RAD_ADSL_CAP			12
128	#define RAD_ADSL_DMT			13
129	#define RAD_IDSL			14
130	#define RAD_ETHERNET			15
131	#define RAD_XDSL			16
132	#define RAD_CABLE			17
133	#define RAD_WIRELESS_OTHER		18
134	#define RAD_WIRELESS_IEEE_802_11	19
135#define RAD_PORT_LIMIT			62	/* Integer */
136#define RAD_LOGIN_LAT_PORT		63	/* Integer */
137#define RAD_CONNECT_INFO		77	/* String */
138#define RAD_EAP_MESSAGE			79	/* Octets */
139#define RAD_MESSAGE_AUTHENTIC		80	/* Octets */
140#define RAD_ACCT_INTERIM_INTERVAL	85	/* Integer */
141#define RAD_NAS_IPV6_ADDRESS		95	/* IPv6 address */
142#define RAD_FRAMED_INTERFACE_ID		96	/* 8 octets */
143#define RAD_FRAMED_IPV6_PREFIX		97	/* Octets */
144#define RAD_LOGIN_IPV6_HOST		98	/* IPv6 address */
145#define RAD_FRAMED_IPV6_ROUTE		99	/* String */
146#define RAD_FRAMED_IPV6_POOL		100	/* String */
147
148/* Accounting attribute types and values */
149#define RAD_ACCT_STATUS_TYPE		40	/* Integer */
150	#define RAD_START			1
151	#define RAD_STOP			2
152	#define RAD_UPDATE			3
153	#define RAD_ACCOUNTING_ON		7
154	#define RAD_ACCOUNTING_OFF		8
155#define RAD_ACCT_DELAY_TIME		41	/* Integer */
156#define RAD_ACCT_INPUT_OCTETS		42	/* Integer */
157#define RAD_ACCT_OUTPUT_OCTETS		43	/* Integer */
158#define RAD_ACCT_SESSION_ID		44	/* String */
159#define RAD_ACCT_AUTHENTIC		45	/* Integer */
160	#define RAD_AUTH_RADIUS			1
161	#define RAD_AUTH_LOCAL			2
162	#define RAD_AUTH_REMOTE			3
163#define RAD_ACCT_SESSION_TIME		46	/* Integer */
164#define RAD_ACCT_INPUT_PACKETS		47	/* Integer */
165#define RAD_ACCT_OUTPUT_PACKETS		48	/* Integer */
166#define RAD_ACCT_TERMINATE_CAUSE	49	/* Integer */
167        #define RAD_TERM_USER_REQUEST		1
168        #define RAD_TERM_LOST_CARRIER		2
169        #define RAD_TERM_LOST_SERVICE		3
170        #define RAD_TERM_IDLE_TIMEOUT		4
171        #define RAD_TERM_SESSION_TIMEOUT	5
172        #define RAD_TERM_ADMIN_RESET		6
173        #define RAD_TERM_ADMIN_REBOOT		7
174        #define RAD_TERM_PORT_ERROR		8
175        #define RAD_TERM_NAS_ERROR		9
176        #define RAD_TERM_NAS_REQUEST		10
177        #define RAD_TERM_NAS_REBOOT		11
178        #define RAD_TERM_PORT_UNNEEDED		12
179        #define RAD_TERM_PORT_PREEMPTED		13
180        #define RAD_TERM_PORT_SUSPENDED		14
181        #define RAD_TERM_SERVICE_UNAVAILABLE    15
182        #define RAD_TERM_CALLBACK		16
183        #define RAD_TERM_USER_ERROR		17
184        #define RAD_TERM_HOST_REQUEST		18
185#define	RAD_ACCT_MULTI_SESSION_ID	50	/* String */
186#define	RAD_ACCT_LINK_COUNT		51	/* Integer */
187
188#define	RAD_ERROR_CAUSE			101	/* Integer */
189
190struct rad_handle;
191struct timeval;
192
193__BEGIN_DECLS
194struct rad_handle	*rad_acct_open(void);
195int			 rad_add_server(struct rad_handle *,
196			    const char *, int, const char *, int, int);
197struct rad_handle	*rad_auth_open(void);
198void			 rad_bind_to(struct rad_handle *, in_addr_t);
199void			 rad_close(struct rad_handle *);
200int			 rad_config(struct rad_handle *, const char *);
201int			 rad_continue_send_request(struct rad_handle *, int,
202			    int *, struct timeval *);
203int			 rad_create_request(struct rad_handle *, int);
204int			 rad_create_response(struct rad_handle *, int);
205struct in_addr		 rad_cvt_addr(const void *);
206u_int32_t		 rad_cvt_int(const void *);
207char			*rad_cvt_string(const void *, size_t);
208int			 rad_get_attr(struct rad_handle *, const void **,
209			    size_t *);
210int			 rad_init_send_request(struct rad_handle *, int *,
211			    struct timeval *);
212struct rad_handle	*rad_open(void);  /* Deprecated, == rad_auth_open */
213int			 rad_put_addr(struct rad_handle *, int, struct in_addr);
214int			 rad_put_attr(struct rad_handle *, int,
215			    const void *, size_t);
216int			 rad_put_int(struct rad_handle *, int, u_int32_t);
217int			 rad_put_string(struct rad_handle *, int,
218			    const char *);
219int			 rad_put_message_authentic(struct rad_handle *);
220ssize_t			 rad_request_authenticator(struct rad_handle *, char *,
221			    size_t);
222int			 rad_receive_request(struct rad_handle *);
223int			 rad_send_request(struct rad_handle *);
224int			 rad_send_response(struct rad_handle *);
225struct rad_handle	*rad_server_open(int fd);
226const char		*rad_server_secret(struct rad_handle *);
227const char		*rad_strerror(struct rad_handle *);
228u_char			*rad_demangle(struct rad_handle *, const void *,
229			    size_t);
230
231__END_DECLS
232
233#endif /* _RADLIB_H_ */
234