radlib.h revision 116544
1/*-
2 * Copyright 1998 Juniper Networks, Inc.
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright
9 *    notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 *    notice, this list of conditions and the following disclaimer in the
12 *    documentation and/or other materials provided with the distribution.
13 *
14 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17 * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24 * SUCH DAMAGE.
25 *
26 *	$FreeBSD: head/lib/libradius/radlib.h 116544 2003-06-18 17:29:15Z ume $
27 */
28
29#ifndef _RADLIB_H_
30#define _RADLIB_H_
31
32#include <sys/types.h>
33#include <netinet/in.h>
34
35/* Message types */
36#define RAD_ACCESS_REQUEST		1
37#define RAD_ACCESS_ACCEPT		2
38#define RAD_ACCESS_REJECT		3
39#define RAD_ACCOUNTING_REQUEST		4
40#define RAD_ACCOUNTING_RESPONSE		5
41#define RAD_ACCESS_CHALLENGE		11
42
43/* Attribute types and values */
44#define RAD_USER_NAME			1	/* String */
45#define RAD_USER_PASSWORD		2	/* String */
46#define RAD_CHAP_PASSWORD		3	/* String */
47#define RAD_NAS_IP_ADDRESS		4	/* IP address */
48#define RAD_NAS_PORT			5	/* Integer */
49#define RAD_SERVICE_TYPE		6	/* Integer */
50	#define RAD_LOGIN			1
51	#define RAD_FRAMED			2
52	#define RAD_CALLBACK_LOGIN		3
53	#define RAD_CALLBACK_FRAMED		4
54	#define RAD_OUTBOUND			5
55	#define RAD_ADMINISTRATIVE		6
56	#define RAD_NAS_PROMPT			7
57	#define RAD_AUTHENTICATE_ONLY		8
58	#define RAD_CALLBACK_NAS_PROMPT		9
59#define RAD_FRAMED_PROTOCOL		7	/* Integer */
60	#define RAD_PPP				1
61	#define RAD_SLIP			2
62	#define RAD_ARAP			3	/* Appletalk */
63	#define RAD_GANDALF			4
64	#define RAD_XYLOGICS			5
65#define RAD_FRAMED_IP_ADDRESS		8	/* IP address */
66#define RAD_FRAMED_IP_NETMASK		9	/* IP address */
67#define RAD_FRAMED_ROUTING		10	/* Integer */
68#define RAD_FILTER_ID			11	/* String */
69#define RAD_FRAMED_MTU			12	/* Integer */
70#define RAD_FRAMED_COMPRESSION		13	/* Integer */
71	#define RAD_COMP_NONE			0
72	#define RAD_COMP_VJ			1
73	#define RAD_COMP_IPXHDR			2
74#define RAD_LOGIN_IP_HOST		14	/* IP address */
75#define RAD_LOGIN_SERVICE		15	/* Integer */
76#define RAD_LOGIN_TCP_PORT		16	/* Integer */
77     /* unassiged			17 */
78#define RAD_REPLY_MESSAGE		18	/* String */
79#define RAD_CALLBACK_NUMBER		19	/* String */
80#define RAD_CALLBACK_ID			20	/* String */
81     /* unassiged			21 */
82#define RAD_FRAMED_ROUTE		22	/* String */
83#define RAD_FRAMED_IPX_NETWORK		23	/* IP address */
84#define RAD_STATE			24	/* String */
85#define RAD_CLASS			25	/* Integer */
86#define RAD_VENDOR_SPECIFIC		26	/* Integer */
87#define RAD_SESSION_TIMEOUT		27	/* Integer */
88#define RAD_IDLE_TIMEOUT		28	/* Integer */
89#define RAD_TERMINATION_ACTION		29	/* Integer */
90#define RAD_CALLED_STATION_ID		30	/* String */
91#define RAD_CALLING_STATION_ID		31	/* String */
92#define RAD_NAS_IDENTIFIER		32	/* Integer */
93#define RAD_PROXY_STATE			33	/* Integer */
94#define RAD_LOGIN_LAT_SERVICE		34	/* Integer */
95#define RAD_LOGIN_LAT_NODE		35	/* Integer */
96#define RAD_LOGIN_LAT_GROUP		36	/* Integer */
97#define RAD_FRAMED_APPLETALK_LINK	37	/* Integer */
98#define RAD_FRAMED_APPLETALK_NETWORK	38	/* Integer */
99#define RAD_FRAMED_APPLETALK_ZONE	39	/* Integer */
100     /* reserved for accounting		40-59 */
101#define RAD_CHAP_CHALLENGE		60	/* String */
102#define RAD_NAS_PORT_TYPE		61	/* Integer */
103	#define RAD_ASYNC			0
104	#define RAD_SYNC			1
105	#define RAD_ISDN_SYNC			2
106	#define RAD_ISDN_ASYNC_V120		3
107	#define RAD_ISDN_ASYNC_V110		4
108	#define RAD_VIRTUAL			5
109	#define RAD_PIAFS			6
110	#define RAD_HDLC_CLEAR_CHANNEL		7
111	#define RAD_X_25			8
112	#define RAD_X_75			9
113	#define RAD_G_3_FAX			10
114	#define RAD_SDSL			11
115	#define RAD_ADSL_CAP			12
116	#define RAD_ADSL_DMT			13
117	#define RAD_IDSL			14
118	#define RAD_ETHERNET			15
119	#define RAD_XDSL			16
120	#define RAD_CABLE			17
121	#define RAD_WIRELESS_OTHER		18
122	#define RAD_WIRELESS_IEEE_802_11	19
123#define RAD_PORT_LIMIT			62	/* Integer */
124#define RAD_LOGIN_LAT_PORT		63	/* Integer */
125#define RAD_CONNECT_INFO		77	/* String */
126#define RAD_NAS_IPV6_ADDRESS		95	/* IPv6 address */
127#define RAD_FRAMED_INTERFACE_ID		96	/* 8 octets */
128#define RAD_FRAMED_IPV6_PREFIX		97	/* Octets */
129#define RAD_LOGIN_IPV6_HOST		98	/* IPv6 address */
130#define RAD_FRAMED_IPV6_ROUTE		99	/* String */
131#define RAD_FRAMED_IPV6_POOL		100	/* String */
132
133/* Accounting attribute types and values */
134#define RAD_ACCT_STATUS_TYPE		40	/* Integer */
135	#define RAD_START			1
136	#define RAD_STOP			2
137	#define RAD_ACCOUNTING_ON		7
138	#define RAD_ACCOUNTING_OFF		8
139#define RAD_ACCT_DELAY_TIME		41	/* Integer */
140#define RAD_ACCT_INPUT_OCTETS		42	/* Integer */
141#define RAD_ACCT_OUTPUT_OCTETS		43	/* Integer */
142#define RAD_ACCT_SESSION_ID		44	/* String */
143#define RAD_ACCT_AUTHENTIC		45	/* Integer */
144	#define RAD_AUTH_RADIUS			1
145	#define RAD_AUTH_LOCAL			2
146	#define RAD_AUTH_REMOTE			3
147#define RAD_ACCT_SESSION_TIME		46	/* Integer */
148#define RAD_ACCT_INPUT_PACKETS		47	/* Integer */
149#define RAD_ACCT_OUTPUT_PACKETS		48	/* Integer */
150#define RAD_ACCT_TERMINATE_CAUSE	49	/* Integer */
151        #define RAD_TERM_USER_REQUEST		1
152        #define RAD_TERM_LOST_CARRIER		2
153        #define RAD_TERM_LOST_SERVICE		3
154        #define RAD_TERM_IDLE_TIMEOUT		4
155        #define RAD_TERM_SESSION_TIMEOUT	5
156        #define RAD_TERM_ADMIN_RESET		6
157        #define RAD_TERM_ADMIN_REBOOT		7
158        #define RAD_TERM_PORT_ERROR		8
159        #define RAD_TERM_NAS_ERROR		9
160        #define RAD_TERM_NAS_REQUEST		10
161        #define RAD_TERM_NAS_REBOOT		11
162        #define RAD_TERM_PORT_UNNEEDED		12
163        #define RAD_TERM_PORT_PREEMPTED		13
164        #define RAD_TERM_PORT_SUSPENDED		14
165        #define RAD_TERM_SERVICE_UNAVAILABLE    15
166        #define RAD_TERM_CALLBACK		16
167        #define RAD_TERM_USER_ERROR		17
168        #define RAD_TERM_HOST_REQUEST		18
169#define	RAD_ACCT_MULTI_SESSION_ID	50	/* String */
170#define	RAD_ACCT_LINK_COUNT		51	/* Integer */
171
172struct rad_handle;
173struct timeval;
174
175__BEGIN_DECLS
176struct rad_handle	*rad_acct_open(void);
177int			 rad_add_server(struct rad_handle *,
178			    const char *, int, const char *, int, int);
179struct rad_handle	*rad_auth_open(void);
180void			 rad_close(struct rad_handle *);
181int			 rad_config(struct rad_handle *, const char *);
182int			 rad_continue_send_request(struct rad_handle *, int,
183			    int *, struct timeval *);
184int			 rad_create_request(struct rad_handle *, int);
185struct in_addr		 rad_cvt_addr(const void *);
186u_int32_t		 rad_cvt_int(const void *);
187char			*rad_cvt_string(const void *, size_t);
188int			 rad_get_attr(struct rad_handle *, const void **,
189			    size_t *);
190int			 rad_init_send_request(struct rad_handle *, int *,
191			    struct timeval *);
192struct rad_handle	*rad_open(void);  /* Deprecated, == rad_auth_open */
193int			 rad_put_addr(struct rad_handle *, int, struct in_addr);
194int			 rad_put_attr(struct rad_handle *, int,
195			    const void *, size_t);
196int			 rad_put_int(struct rad_handle *, int, u_int32_t);
197int			 rad_put_string(struct rad_handle *, int,
198			    const char *);
199ssize_t			 rad_request_authenticator(struct rad_handle *, char *,
200			    size_t);
201int			 rad_send_request(struct rad_handle *);
202const char		*rad_server_secret(struct rad_handle *);
203const char		*rad_strerror(struct rad_handle *);
204__END_DECLS
205
206#endif /* _RADLIB_H_ */
207