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