xref: /dflybsd-src/usr.sbin/ppp/libradius/radlib.h (revision 1a67aa78e2451db72fc3b0782d4f2f4f3f3458d3)
1624037c1Szrj /*-
2624037c1Szrj  * Copyright 1998 Juniper Networks, Inc.
3624037c1Szrj  * All rights reserved.
4624037c1Szrj  *
5624037c1Szrj  * Redistribution and use in source and binary forms, with or without
6624037c1Szrj  * modification, are permitted provided that the following conditions
7624037c1Szrj  * are met:
8624037c1Szrj  * 1. Redistributions of source code must retain the above copyright
9624037c1Szrj  *    notice, this list of conditions and the following disclaimer.
10624037c1Szrj  * 2. Redistributions in binary form must reproduce the above copyright
11624037c1Szrj  *    notice, this list of conditions and the following disclaimer in the
12624037c1Szrj  *    documentation and/or other materials provided with the distribution.
13624037c1Szrj  *
14624037c1Szrj  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15624037c1Szrj  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16624037c1Szrj  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17624037c1Szrj  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18624037c1Szrj  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19624037c1Szrj  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20624037c1Szrj  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21624037c1Szrj  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22624037c1Szrj  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23624037c1Szrj  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24624037c1Szrj  * SUCH DAMAGE.
25624037c1Szrj  *
26624037c1Szrj  *	$FreeBSD: src/lib/libradius/radlib.h,v 1.8 2009/09/11 11:42:56 mav Exp $
27624037c1Szrj  */
28624037c1Szrj 
29624037c1Szrj #ifndef _RADLIB_H_
30624037c1Szrj #define _RADLIB_H_
31624037c1Szrj 
32624037c1Szrj #include <sys/types.h>
33624037c1Szrj #include <netinet/in.h>
34624037c1Szrj 
35624037c1Szrj /* Limits */
36624037c1Szrj #define RAD_MAX_ATTR_LEN		253
37624037c1Szrj 
38624037c1Szrj /* Message types */
39624037c1Szrj #define RAD_ACCESS_REQUEST		1
40624037c1Szrj #define RAD_ACCESS_ACCEPT		2
41624037c1Szrj #define RAD_ACCESS_REJECT		3
42624037c1Szrj #define RAD_ACCOUNTING_REQUEST		4
43624037c1Szrj #define RAD_ACCOUNTING_RESPONSE		5
44624037c1Szrj #define RAD_ACCESS_CHALLENGE		11
45624037c1Szrj #define RAD_DISCONNECT_REQUEST		40
46624037c1Szrj #define RAD_DISCONNECT_ACK		41
47624037c1Szrj #define RAD_DISCONNECT_NAK		42
48624037c1Szrj #define RAD_COA_REQUEST			43
49624037c1Szrj #define RAD_COA_ACK			44
50624037c1Szrj #define RAD_COA_NAK			45
51624037c1Szrj 
52624037c1Szrj /* Attribute types and values */
53624037c1Szrj #define RAD_USER_NAME			1	/* String */
54624037c1Szrj #define RAD_USER_PASSWORD		2	/* String */
55624037c1Szrj #define RAD_CHAP_PASSWORD		3	/* String */
56624037c1Szrj #define RAD_NAS_IP_ADDRESS		4	/* IP address */
57624037c1Szrj #define RAD_NAS_PORT			5	/* Integer */
58624037c1Szrj #define RAD_SERVICE_TYPE		6	/* Integer */
59624037c1Szrj 	#define RAD_LOGIN			1
60624037c1Szrj 	#define RAD_FRAMED			2
61624037c1Szrj 	#define RAD_CALLBACK_LOGIN		3
62624037c1Szrj 	#define RAD_CALLBACK_FRAMED		4
63624037c1Szrj 	#define RAD_OUTBOUND			5
64624037c1Szrj 	#define RAD_ADMINISTRATIVE		6
65624037c1Szrj 	#define RAD_NAS_PROMPT			7
66624037c1Szrj 	#define RAD_AUTHENTICATE_ONLY		8
67624037c1Szrj 	#define RAD_CALLBACK_NAS_PROMPT		9
68624037c1Szrj #define RAD_FRAMED_PROTOCOL		7	/* Integer */
69624037c1Szrj 	#define RAD_PPP				1
70624037c1Szrj 	#define RAD_SLIP			2
71624037c1Szrj 	#define RAD_ARAP			3	/* Appletalk */
72624037c1Szrj 	#define RAD_GANDALF			4
73624037c1Szrj 	#define RAD_XYLOGICS			5
74624037c1Szrj #define RAD_FRAMED_IP_ADDRESS		8	/* IP address */
75624037c1Szrj #define RAD_FRAMED_IP_NETMASK		9	/* IP address */
76624037c1Szrj #define RAD_FRAMED_ROUTING		10	/* Integer */
77624037c1Szrj #define RAD_FILTER_ID			11	/* String */
78624037c1Szrj #define RAD_FRAMED_MTU			12	/* Integer */
79624037c1Szrj #define RAD_FRAMED_COMPRESSION		13	/* Integer */
80624037c1Szrj 	#define RAD_COMP_NONE			0
81624037c1Szrj 	#define RAD_COMP_VJ			1
82624037c1Szrj 	#define RAD_COMP_IPXHDR			2
83624037c1Szrj #define RAD_LOGIN_IP_HOST		14	/* IP address */
84624037c1Szrj #define RAD_LOGIN_SERVICE		15	/* Integer */
85624037c1Szrj #define RAD_LOGIN_TCP_PORT		16	/* Integer */
86624037c1Szrj      /* unassiged			17 */
87624037c1Szrj #define RAD_REPLY_MESSAGE		18	/* String */
88624037c1Szrj #define RAD_CALLBACK_NUMBER		19	/* String */
89624037c1Szrj #define RAD_CALLBACK_ID			20	/* String */
90624037c1Szrj      /* unassiged			21 */
91624037c1Szrj #define RAD_FRAMED_ROUTE		22	/* String */
92624037c1Szrj #define RAD_FRAMED_IPX_NETWORK		23	/* IP address */
93624037c1Szrj #define RAD_STATE			24	/* String */
94624037c1Szrj #define RAD_CLASS			25	/* Integer */
95624037c1Szrj #define RAD_VENDOR_SPECIFIC		26	/* Integer */
96624037c1Szrj #define RAD_SESSION_TIMEOUT		27	/* Integer */
97624037c1Szrj #define RAD_IDLE_TIMEOUT		28	/* Integer */
98624037c1Szrj #define RAD_TERMINATION_ACTION		29	/* Integer */
99624037c1Szrj #define RAD_CALLED_STATION_ID		30	/* String */
100624037c1Szrj #define RAD_CALLING_STATION_ID		31	/* String */
101*1a67aa78Szrj #define RAD_NAS_IDENTIFIER		32	/* String */
102624037c1Szrj #define RAD_PROXY_STATE			33	/* Integer */
103624037c1Szrj #define RAD_LOGIN_LAT_SERVICE		34	/* Integer */
104624037c1Szrj #define RAD_LOGIN_LAT_NODE		35	/* Integer */
105624037c1Szrj #define RAD_LOGIN_LAT_GROUP		36	/* Integer */
106624037c1Szrj #define RAD_FRAMED_APPLETALK_LINK	37	/* Integer */
107624037c1Szrj #define RAD_FRAMED_APPLETALK_NETWORK	38	/* Integer */
108624037c1Szrj #define RAD_FRAMED_APPLETALK_ZONE	39	/* Integer */
109624037c1Szrj      /* reserved for accounting		40-59 */
110624037c1Szrj #define RAD_ACCT_INPUT_GIGAWORDS	52
111624037c1Szrj #define RAD_ACCT_OUTPUT_GIGAWORDS	53
112624037c1Szrj 
113624037c1Szrj #define RAD_CHAP_CHALLENGE		60	/* String */
114624037c1Szrj #define RAD_NAS_PORT_TYPE		61	/* Integer */
115624037c1Szrj 	#define RAD_ASYNC			0
116624037c1Szrj 	#define RAD_SYNC			1
117624037c1Szrj 	#define RAD_ISDN_SYNC			2
118624037c1Szrj 	#define RAD_ISDN_ASYNC_V120		3
119624037c1Szrj 	#define RAD_ISDN_ASYNC_V110		4
120624037c1Szrj 	#define RAD_VIRTUAL			5
121624037c1Szrj 	#define RAD_PIAFS			6
122624037c1Szrj 	#define RAD_HDLC_CLEAR_CHANNEL		7
123624037c1Szrj 	#define RAD_X_25			8
124624037c1Szrj 	#define RAD_X_75			9
125624037c1Szrj 	#define RAD_G_3_FAX			10
126624037c1Szrj 	#define RAD_SDSL			11
127624037c1Szrj 	#define RAD_ADSL_CAP			12
128624037c1Szrj 	#define RAD_ADSL_DMT			13
129624037c1Szrj 	#define RAD_IDSL			14
130624037c1Szrj 	#define RAD_ETHERNET			15
131624037c1Szrj 	#define RAD_XDSL			16
132624037c1Szrj 	#define RAD_CABLE			17
133624037c1Szrj 	#define RAD_WIRELESS_OTHER		18
134624037c1Szrj 	#define RAD_WIRELESS_IEEE_802_11	19
135624037c1Szrj #define RAD_PORT_LIMIT			62	/* Integer */
136624037c1Szrj #define RAD_LOGIN_LAT_PORT		63	/* Integer */
137624037c1Szrj #define RAD_CONNECT_INFO		77	/* String */
138624037c1Szrj #define RAD_EAP_MESSAGE			79	/* Octets */
139624037c1Szrj #define RAD_MESSAGE_AUTHENTIC		80	/* Octets */
140624037c1Szrj #define RAD_ACCT_INTERIM_INTERVAL	85	/* Integer */
141624037c1Szrj #define RAD_NAS_IPV6_ADDRESS		95	/* IPv6 address */
142624037c1Szrj #define RAD_FRAMED_INTERFACE_ID		96	/* 8 octets */
143624037c1Szrj #define RAD_FRAMED_IPV6_PREFIX		97	/* Octets */
144624037c1Szrj #define RAD_LOGIN_IPV6_HOST		98	/* IPv6 address */
145624037c1Szrj #define RAD_FRAMED_IPV6_ROUTE		99	/* String */
146624037c1Szrj #define RAD_FRAMED_IPV6_POOL		100	/* String */
147624037c1Szrj 
148624037c1Szrj /* Accounting attribute types and values */
149624037c1Szrj #define RAD_ACCT_STATUS_TYPE		40	/* Integer */
150624037c1Szrj 	#define RAD_START			1
151624037c1Szrj 	#define RAD_STOP			2
152624037c1Szrj 	#define RAD_UPDATE			3
153624037c1Szrj 	#define RAD_ACCOUNTING_ON		7
154624037c1Szrj 	#define RAD_ACCOUNTING_OFF		8
155624037c1Szrj #define RAD_ACCT_DELAY_TIME		41	/* Integer */
156624037c1Szrj #define RAD_ACCT_INPUT_OCTETS		42	/* Integer */
157624037c1Szrj #define RAD_ACCT_OUTPUT_OCTETS		43	/* Integer */
158624037c1Szrj #define RAD_ACCT_SESSION_ID		44	/* String */
159624037c1Szrj #define RAD_ACCT_AUTHENTIC		45	/* Integer */
160624037c1Szrj 	#define RAD_AUTH_RADIUS			1
161624037c1Szrj 	#define RAD_AUTH_LOCAL			2
162624037c1Szrj 	#define RAD_AUTH_REMOTE			3
163624037c1Szrj #define RAD_ACCT_SESSION_TIME		46	/* Integer */
164624037c1Szrj #define RAD_ACCT_INPUT_PACKETS		47	/* Integer */
165624037c1Szrj #define RAD_ACCT_OUTPUT_PACKETS		48	/* Integer */
166624037c1Szrj #define RAD_ACCT_TERMINATE_CAUSE	49	/* Integer */
167624037c1Szrj         #define RAD_TERM_USER_REQUEST		1
168624037c1Szrj         #define RAD_TERM_LOST_CARRIER		2
169624037c1Szrj         #define RAD_TERM_LOST_SERVICE		3
170624037c1Szrj         #define RAD_TERM_IDLE_TIMEOUT		4
171624037c1Szrj         #define RAD_TERM_SESSION_TIMEOUT	5
172624037c1Szrj         #define RAD_TERM_ADMIN_RESET		6
173624037c1Szrj         #define RAD_TERM_ADMIN_REBOOT		7
174624037c1Szrj         #define RAD_TERM_PORT_ERROR		8
175624037c1Szrj         #define RAD_TERM_NAS_ERROR		9
176624037c1Szrj         #define RAD_TERM_NAS_REQUEST		10
177624037c1Szrj         #define RAD_TERM_NAS_REBOOT		11
178624037c1Szrj         #define RAD_TERM_PORT_UNNEEDED		12
179624037c1Szrj         #define RAD_TERM_PORT_PREEMPTED		13
180624037c1Szrj         #define RAD_TERM_PORT_SUSPENDED		14
181624037c1Szrj         #define RAD_TERM_SERVICE_UNAVAILABLE    15
182624037c1Szrj         #define RAD_TERM_CALLBACK		16
183624037c1Szrj         #define RAD_TERM_USER_ERROR		17
184624037c1Szrj         #define RAD_TERM_HOST_REQUEST		18
185624037c1Szrj #define	RAD_ACCT_MULTI_SESSION_ID	50	/* String */
186624037c1Szrj #define	RAD_ACCT_LINK_COUNT		51	/* Integer */
187624037c1Szrj 
188624037c1Szrj #define	RAD_ERROR_CAUSE			101	/* Integer */
189624037c1Szrj 
190624037c1Szrj struct rad_handle;
191624037c1Szrj struct timeval;
192624037c1Szrj 
193624037c1Szrj __BEGIN_DECLS
194624037c1Szrj struct rad_handle	*rad_acct_open(void);
195624037c1Szrj int			 rad_add_server(struct rad_handle *,
196624037c1Szrj 			    const char *, int, const char *, int, int);
197624037c1Szrj int			 rad_add_server_ex(struct rad_handle *,
198624037c1Szrj 			    const char *, int, const char *, int, int,
199624037c1Szrj 			    int, struct in_addr *);
200624037c1Szrj struct rad_handle	*rad_auth_open(void);
201624037c1Szrj void			 rad_bind_to(struct rad_handle *, in_addr_t);
202624037c1Szrj void			 rad_close(struct rad_handle *);
203624037c1Szrj int			 rad_config(struct rad_handle *, const char *);
204624037c1Szrj int			 rad_continue_send_request(struct rad_handle *, int,
205624037c1Szrj 			    int *, struct timeval *);
206624037c1Szrj int			 rad_create_request(struct rad_handle *, int);
207624037c1Szrj int			 rad_create_response(struct rad_handle *, int);
208624037c1Szrj struct in_addr		 rad_cvt_addr(const void *);
209624037c1Szrj struct in6_addr		 rad_cvt_addr6(const void *);
210624037c1Szrj u_int32_t		 rad_cvt_int(const void *);
211624037c1Szrj char			*rad_cvt_string(const void *, size_t);
212624037c1Szrj int			 rad_get_attr(struct rad_handle *, const void **,
213624037c1Szrj 			    size_t *);
214624037c1Szrj int			 rad_init_send_request(struct rad_handle *, int *,
215624037c1Szrj 			    struct timeval *);
216624037c1Szrj struct rad_handle	*rad_open(void);  /* Deprecated, == rad_auth_open */
217624037c1Szrj int			 rad_put_addr(struct rad_handle *, int, struct in_addr);
218624037c1Szrj int			 rad_put_addr6(struct rad_handle *, int, struct in6_addr);
219624037c1Szrj int			 rad_put_attr(struct rad_handle *, int,
220624037c1Szrj 			    const void *, size_t);
221624037c1Szrj int			 rad_put_int(struct rad_handle *, int, u_int32_t);
222624037c1Szrj int			 rad_put_string(struct rad_handle *, int,
223624037c1Szrj 			    const char *);
224624037c1Szrj int			 rad_put_message_authentic(struct rad_handle *);
225624037c1Szrj ssize_t			 rad_request_authenticator(struct rad_handle *, char *,
226624037c1Szrj 			    size_t);
227624037c1Szrj int			 rad_receive_request(struct rad_handle *);
228624037c1Szrj int			 rad_send_request(struct rad_handle *);
229624037c1Szrj int			 rad_send_response(struct rad_handle *);
230624037c1Szrj struct rad_handle	*rad_server_open(int fd);
231624037c1Szrj const char		*rad_server_secret(struct rad_handle *);
232624037c1Szrj const char		*rad_strerror(struct rad_handle *);
233624037c1Szrj u_char			*rad_demangle(struct rad_handle *, const void *,
234624037c1Szrj 			    size_t);
235624037c1Szrj 
236624037c1Szrj __END_DECLS
237624037c1Szrj 
238624037c1Szrj #endif /* _RADLIB_H_ */
239