1082bfe67SJohn Polstra.\" Copyright 1998 Juniper Networks, Inc. 23fc0b61cSAlexander Motin.\" Copyright 2009 Alexander Motin <mav@FreeBSD.org>. 3082bfe67SJohn Polstra.\" All rights reserved. 4082bfe67SJohn Polstra.\" 5082bfe67SJohn Polstra.\" Redistribution and use in source and binary forms, with or without 6082bfe67SJohn Polstra.\" modification, are permitted provided that the following conditions 7082bfe67SJohn Polstra.\" are met: 8082bfe67SJohn Polstra.\" 1. Redistributions of source code must retain the above copyright 9082bfe67SJohn Polstra.\" notice, this list of conditions and the following disclaimer. 10082bfe67SJohn Polstra.\" 2. Redistributions in binary form must reproduce the above copyright 11082bfe67SJohn Polstra.\" notice, this list of conditions and the following disclaimer in the 12082bfe67SJohn Polstra.\" documentation and/or other materials provided with the distribution. 13082bfe67SJohn Polstra.\" 14082bfe67SJohn Polstra.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 15082bfe67SJohn Polstra.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16082bfe67SJohn Polstra.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17082bfe67SJohn Polstra.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 18082bfe67SJohn Polstra.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19082bfe67SJohn Polstra.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20082bfe67SJohn Polstra.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21082bfe67SJohn Polstra.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22082bfe67SJohn Polstra.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23082bfe67SJohn Polstra.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24082bfe67SJohn Polstra.\" SUCH DAMAGE. 25082bfe67SJohn Polstra.\" 263fc0b61cSAlexander Motin.Dd August 5, 2009 27082bfe67SJohn Polstra.Dt LIBRADIUS 3 28a307d598SRuslan Ermilov.Os 29082bfe67SJohn Polstra.Sh NAME 30082bfe67SJohn Polstra.Nm libradius 313fc0b61cSAlexander Motin.Nd RADIUS client/server library 32082bfe67SJohn Polstra.Sh SYNOPSIS 3332eef9aeSRuslan Ermilov.In radlib.h 3481b380a8SRuslan Ermilov.Ft "struct rad_handle *" 350981dfefSJohn Polstra.Fn rad_acct_open "void" 36082bfe67SJohn Polstra.Ft int 37082bfe67SJohn Polstra.Fn rad_add_server "struct rad_handle *h" "const char *host" "int port" "const char *secret" "int timeout" "int max_tries" 38bf5a1b65SSergey Matveychuk.Ft int 3999d9e4ecSAndrey V. Elsukov.Fn rad_add_server_ex "struct rad_handle *h" "const char *host" "int port" "const char *secret" "int timeout" "int max_tries" "int dead_time" "struct in_addr *bindto" 4081b380a8SRuslan Ermilov.Ft "struct rad_handle *" 410981dfefSJohn Polstra.Fn rad_auth_open "void" 42082bfe67SJohn Polstra.Ft void 43082bfe67SJohn Polstra.Fn rad_close "struct rad_handle *h" 44082bfe67SJohn Polstra.Ft int 45082bfe67SJohn Polstra.Fn rad_config "struct rad_handle *h" "const char *file" 46082bfe67SJohn Polstra.Ft int 4748caee2aSBrian Somers.Fn rad_continue_send_request "struct rad_handle *h" "int selected" "int *fd" "struct timeval *tv" 4848caee2aSBrian Somers.Ft int 49082bfe67SJohn Polstra.Fn rad_create_request "struct rad_handle *h" "int code" 503fc0b61cSAlexander Motin.Ft int 513fc0b61cSAlexander Motin.Fn rad_create_response "struct rad_handle *h" "int code" 5281b380a8SRuslan Ermilov.Ft "struct in_addr" 53082bfe67SJohn Polstra.Fn rad_cvt_addr "const void *data" 546b99842aSEd Schouten.Ft uint32_t 55082bfe67SJohn Polstra.Fn rad_cvt_int "const void *data" 56082bfe67SJohn Polstra.Ft char * 57082bfe67SJohn Polstra.Fn rad_cvt_string "const void *data" "size_t len" 58082bfe67SJohn Polstra.Ft int 59082bfe67SJohn Polstra.Fn rad_get_attr "struct rad_handle *h" "const void **data" "size_t *len" 6048caee2aSBrian Somers.Ft int 616b99842aSEd Schouten.Fn rad_get_vendor_attr "uint32_t *vendor" "const void **data" "size_t *len" 62fc3f62faSBrian Somers.Ft int 6348caee2aSBrian Somers.Fn rad_init_send_request "struct rad_handle *h" "int *fd" "struct timeval *tv" 64082bfe67SJohn Polstra.Ft int 65082bfe67SJohn Polstra.Fn rad_put_addr "struct rad_handle *h" "int type" "struct in_addr addr" 66082bfe67SJohn Polstra.Ft int 67082bfe67SJohn Polstra.Fn rad_put_attr "struct rad_handle *h" "int type" "const void *data" "size_t len" 68082bfe67SJohn Polstra.Ft int 696b99842aSEd Schouten.Fn rad_put_int "struct rad_handle *h" "int type" "uint32_t value" 70082bfe67SJohn Polstra.Ft int 71082bfe67SJohn Polstra.Fn rad_put_string "struct rad_handle *h" "int type" "const char *str" 72082bfe67SJohn Polstra.Ft int 73b4b831efSRuslan Ermilov.Fn rad_put_message_authentic "struct rad_handle *h" 74b4b831efSRuslan Ermilov.Ft int 75b49a88f6SBrian Somers.Fn rad_put_vendor_addr "struct rad_handle *h" "int vendor" "int type" "struct in_addr addr" 76b49a88f6SBrian Somers.Ft int 77b49a88f6SBrian Somers.Fn rad_put_vendor_attr "struct rad_handle *h" "int vendor" "int type" "const void *data" "size_t len" 78b49a88f6SBrian Somers.Ft int 796b99842aSEd Schouten.Fn rad_put_vendor_int "struct rad_handle *h" "int vendor" "int type" "uint32_t value" 80b49a88f6SBrian Somers.Ft int 81b49a88f6SBrian Somers.Fn rad_put_vendor_string "struct rad_handle *h" "int vendor" "int type" "const char *str" 82628e6cd4SBrian Somers.Ft ssize_t 83628e6cd4SBrian Somers.Fn rad_request_authenticator "struct rad_handle *h" "char *buf" "size_t len" 84b49a88f6SBrian Somers.Ft int 853fc0b61cSAlexander Motin.Fn rad_receive_request "struct rad_handle *h" 863fc0b61cSAlexander Motin.Ft int 87082bfe67SJohn Polstra.Fn rad_send_request "struct rad_handle *h" 883fc0b61cSAlexander Motin.Ft int 893fc0b61cSAlexander Motin.Fn rad_send_response "struct rad_handle *h" 903fc0b61cSAlexander Motin.Ft "struct rad_handle *" 913fc0b61cSAlexander Motin.Fn rad_server_open "int fd" 9281b380a8SRuslan Ermilov.Ft "const char *" 93628e6cd4SBrian Somers.Fn rad_server_secret "struct rad_handle *h" 9407d7b74bSAlexander V. Chernikov.Ft "void" 9507d7b74bSAlexander V. Chernikov.Fn rad_bind_to "struct rad_handle *h" "in_addr_t addr" 96b4b831efSRuslan Ermilov.Ft u_char * 97b4b831efSRuslan Ermilov.Fn rad_demangle "struct rad_handle *h" "const void *mangled" "size_t mlen" 98b4b831efSRuslan Ermilov.Ft u_char * 99b4b831efSRuslan Ermilov.Fn rad_demangle_mppe_key "struct rad_handle *h" "const void *mangled" "size_t mlen" "size_t *len" 10081b380a8SRuslan Ermilov.Ft "const char *" 101082bfe67SJohn Polstra.Fn rad_strerror "struct rad_handle *h" 102082bfe67SJohn Polstra.Sh DESCRIPTION 103082bfe67SJohn PolstraThe 104082bfe67SJohn Polstra.Nm 1053fc0b61cSAlexander Motinlibrary implements the Remote Authentication Dial In User Service (RADIUS). 106b4b831efSRuslan ErmilovRADIUS, defined in RFCs 2865 and 2866, 1070981dfefSJohn Polstraallows clients to perform authentication and accounting by means of 1080981dfefSJohn Polstranetwork requests to remote servers. 10981b380a8SRuslan Ermilov.Ss Initialization 110082bfe67SJohn PolstraTo use the library, an application must first call 111a3fb6da9SGlen Barber.Fn rad_auth_open , 1120981dfefSJohn Polstra.Fn rad_acct_open 1133fc0b61cSAlexander Motinor 1143fc0b61cSAlexander Motin.Fn rad_server_open 115082bfe67SJohn Polstrato obtain a 11681b380a8SRuslan Ermilov.Vt "struct rad_handle *" , 117082bfe67SJohn Polstrawhich provides the context for subsequent operations. 1180981dfefSJohn PolstraThe former function is used for RADIUS authentication and the 1190981dfefSJohn Polstralatter is used for RADIUS accounting. 120082bfe67SJohn PolstraCalls to 121a3fb6da9SGlen Barber.Fn rad_auth_open , 1220981dfefSJohn Polstra.Fn rad_acct_open 1233fc0b61cSAlexander Motinand 1243fc0b61cSAlexander Motin.Fn rad_server_open 12581b380a8SRuslan Ermilovalways succeed unless insufficient virtual memory is available. 12681b380a8SRuslan ErmilovIf 1270981dfefSJohn Polstrathe necessary memory cannot be allocated, the functions return 128082bfe67SJohn Polstra.Dv NULL . 1290981dfefSJohn PolstraFor compatibility with earlier versions of this library, 1300981dfefSJohn Polstra.Fn rad_open 1310981dfefSJohn Polstrais provided as a synonym for 1320981dfefSJohn Polstra.Fn rad_auth_open . 133082bfe67SJohn Polstra.Pp 134082bfe67SJohn PolstraBefore issuing any RADIUS requests, the library must be made aware 13581b380a8SRuslan Ermilovof the servers it can contact. 13681b380a8SRuslan ErmilovThe easiest way to configure the 137082bfe67SJohn Polstralibrary is to call 138082bfe67SJohn Polstra.Fn rad_config . 139082bfe67SJohn Polstra.Fn rad_config 140082bfe67SJohn Polstracauses the library to read a configuration file whose format is 141082bfe67SJohn Polstradescribed in 142082bfe67SJohn Polstra.Xr radius.conf 5 . 143082bfe67SJohn PolstraThe pathname of the configuration file is passed as the 14481b380a8SRuslan Ermilov.Fa file 145082bfe67SJohn Polstraargument to 146082bfe67SJohn Polstra.Fn rad_config . 147082bfe67SJohn PolstraThis argument may also be given as 148082bfe67SJohn Polstra.Dv NULL , 149082bfe67SJohn Polstrain which case the standard configuration file 150082bfe67SJohn Polstra.Pa /etc/radius.conf 151082bfe67SJohn Polstrais used. 152082bfe67SJohn Polstra.Fn rad_config 15381b380a8SRuslan Ermilovreturns 0 on success, or \-1 if an error occurs. 154082bfe67SJohn Polstra.Pp 155082bfe67SJohn PolstraThe library can also be configured programmatically by calls to 156bf5a1b65SSergey Matveychuk.Fn rad_add_server 157bf5a1b65SSergey Matveychukor 158bf5a1b65SSergey Matveychuk.Fn rad_add_server_ex . 159bf5a1b65SSergey Matveychuk.Fn rad_add_server 160bf5a1b65SSergey Matveychukis a backward compatible function, implemented via 161bf5a1b65SSergey Matveychuk.Fn rad_add_server_ex . 162082bfe67SJohn PolstraThe 16381b380a8SRuslan Ermilov.Fa host 164082bfe67SJohn Polstraparameter specifies the server host, either as a fully qualified 165082bfe67SJohn Polstradomain name or as a dotted-quad IP address in text form. 166082bfe67SJohn PolstraThe 16781b380a8SRuslan Ermilov.Fa port 16881b380a8SRuslan Ermilovparameter specifies the UDP port to contact on the server. 16981b380a8SRuslan ErmilovIf 17081b380a8SRuslan Ermilov.Fa port 171082bfe67SJohn Polstrais given as 0, the library looks up the 172082bfe67SJohn Polstra.Ql radius/udp 1730981dfefSJohn Polstraor 1740981dfefSJohn Polstra.Ql radacct/udp 17581b380a8SRuslan Ermilovservice in the network 17681b380a8SRuslan Ermilov.Xr services 5 17781b380a8SRuslan Ermilovdatabase, and uses the port found 17881b380a8SRuslan Ermilovthere. 17981b380a8SRuslan ErmilovIf no entry is found, the library uses the standard RADIUS 1800981dfefSJohn Polstraports, 1812 for authentication and 1813 for accounting. 1810981dfefSJohn PolstraThe shared secret for the server host is passed to the 18281b380a8SRuslan Ermilov.Fa secret 183082bfe67SJohn Polstraparameter. 18481b380a8SRuslan ErmilovIt may be any 18581b380a8SRuslan Ermilov.Dv NUL Ns -terminated 18681b380a8SRuslan Ermilovstring of bytes. 18781b380a8SRuslan ErmilovThe RADIUS protocol 188082bfe67SJohn Polstraignores all but the leading 128 bytes of the shared secret. 189082bfe67SJohn PolstraThe timeout for receiving replies from the server is passed to the 19081b380a8SRuslan Ermilov.Fa timeout 19181b380a8SRuslan Ermilovparameter, in units of seconds. 19281b380a8SRuslan ErmilovThe maximum number of repeated 193082bfe67SJohn Polstrarequests to make before giving up is passed into the 19481b380a8SRuslan Ermilov.Fa max_tries 195082bfe67SJohn Polstraparameter. 196bf5a1b65SSergey MatveychukTime interval in seconds when the server will not be requested 197bf5a1b65SSergey Matveychukif it is marked as dead (did not answer on the last try) set with 198bf5a1b65SSergey Matveychuk.Fa dead_time 199bf5a1b65SSergey Matveychukparameter. 200bf5a1b65SSergey Matveychuk.Fa bindto 201bf5a1b65SSergey Matveychukparameter is an IP address on the multihomed host that is used as 202bf5a1b65SSergey Matveychuka source address for all requests. 203082bfe67SJohn Polstra.Fn rad_add_server 20481b380a8SRuslan Ermilovreturns 0 on success, or \-1 if an error occurs. 205082bfe67SJohn Polstra.Pp 206082bfe67SJohn Polstra.Fn rad_add_server 207bf5a1b65SSergey Matveychukor 208bf5a1b65SSergey Matveychuk.Fn rad_add_server_ex 209bf5a1b65SSergey Matveychukmay be called multiple times, and they may be used together with 210082bfe67SJohn Polstra.Fn rad_config . 211082bfe67SJohn PolstraAt most 10 servers may be specified. 212082bfe67SJohn PolstraWhen multiple servers are given, they are tried in round-robin 213082bfe67SJohn Polstrafashion until a valid response is received, or until each server's 21481b380a8SRuslan Ermilov.Fa max_tries 215082bfe67SJohn Polstralimit has been reached. 21681b380a8SRuslan Ermilov.Ss Creating a RADIUS Request 217082bfe67SJohn PolstraA RADIUS request consists of a code specifying the kind of request, 21881b380a8SRuslan Ermilovand zero or more attributes which provide additional information. 21981b380a8SRuslan ErmilovTo 220082bfe67SJohn Polstrabegin constructing a new request, call 221082bfe67SJohn Polstra.Fn rad_create_request . 222082bfe67SJohn PolstraIn addition to the usual 22381b380a8SRuslan Ermilov.Vt "struct rad_handle *" , 224082bfe67SJohn Polstrathis function takes a 22581b380a8SRuslan Ermilov.Fa code 22681b380a8SRuslan Ermilovparameter which specifies the type of the request. 22781b380a8SRuslan ErmilovMost often this 228082bfe67SJohn Polstrawill be 229082bfe67SJohn Polstra.Dv RAD_ACCESS_REQUEST . 230082bfe67SJohn Polstra.Fn rad_create_request 23181b380a8SRuslan Ermilovreturns 0 on success, or \-1 on if an error occurs. 232082bfe67SJohn Polstra.Pp 233082bfe67SJohn PolstraAfter the request has been created with 234abac9a9eSBrian Somers.Fn rad_create_request , 23581b380a8SRuslan Ermilovattributes can be attached to it. 23681b380a8SRuslan ErmilovThis is done through calls to 237082bfe67SJohn Polstra.Fn rad_put_addr , 238082bfe67SJohn Polstra.Fn rad_put_int , 239082bfe67SJohn Polstraand 240082bfe67SJohn Polstra.Fn rad_put_string . 241082bfe67SJohn PolstraEach accepts a 24281b380a8SRuslan Ermilov.Fa type 243082bfe67SJohn Polstraparameter identifying the attribute, and a value which may be 24481b380a8SRuslan Ermilovan Internet address, an integer, or a 24581b380a8SRuslan Ermilov.Dv NUL Ns -terminated 24681b380a8SRuslan Ermilovstring, 247082bfe67SJohn Polstrarespectively. 248b49a88f6SBrian SomersAlternatively, 249b49a88f6SBrian Somers.Fn rad_put_vendor_addr , 250b49a88f6SBrian Somers.Fn rad_put_vendor_int 251b49a88f6SBrian Somersor 252b49a88f6SBrian Somers.Fn rad_put_vendor_string 25381b380a8SRuslan Ermilovmay be used to specify vendor specific attributes. 25481b380a8SRuslan ErmilovVendor specific 255b49a88f6SBrian Somersdefinitions may be found in 256fe08efe6SRuslan Ermilov.In radlib_vs.h 257082bfe67SJohn Polstra.Pp 258082bfe67SJohn PolstraThe library also provides a function 259082bfe67SJohn Polstra.Fn rad_put_attr 26081b380a8SRuslan Ermilovwhich can be used to supply a raw, uninterpreted attribute. 26181b380a8SRuslan ErmilovThe 26281b380a8SRuslan Ermilov.Fa data 263082bfe67SJohn Polstraargument points to an array of bytes, and the 26481b380a8SRuslan Ermilov.Fa len 265082bfe67SJohn Polstraargument specifies its length. 266082bfe67SJohn Polstra.Pp 267b4b831efSRuslan ErmilovIt is possible adding the Message-Authenticator to the request. 268b4b831efSRuslan ErmilovThis is an HMAC-MD5 hash of the entire Access-Request packet (see RFC 3579). 269b4b831efSRuslan ErmilovThis attribute must be present in any packet that includes an EAP-Message 270b4b831efSRuslan Ermilovattribute. 271b4b831efSRuslan ErmilovIt can be added by using the 272b4b831efSRuslan Ermilov.Fn rad_put_message_authentic 273b4b831efSRuslan Ermilovfunction. 274b4b831efSRuslan ErmilovThe 275b4b831efSRuslan Ermilov.Nm 276b4b831efSRuslan Ermilovlibrary 277b4b831efSRuslan Ermilovcalculates the HMAC-MD5 hash implicitly before sending the request. 278b4b831efSRuslan ErmilovIf the Message-Authenticator was found inside the response packet, 279b4b831efSRuslan Ermilovthen the packet is silently dropped, if the validation failed. 280b4b831efSRuslan ErmilovIn order to get this feature, the library should be compiled with 281b4b831efSRuslan ErmilovOpenSSL support. 282b4b831efSRuslan Ermilov.Pp 283082bfe67SJohn PolstraThe 284082bfe67SJohn Polstra.Fn rad_put_X 28581b380a8SRuslan Ermilovfunctions return 0 on success, or \-1 if an error occurs. 28681b380a8SRuslan Ermilov.Ss Sending the Request and Receiving the Response 28748caee2aSBrian SomersAfter the RADIUS request has been constructed, it is sent either by means of 28848caee2aSBrian Somers.Fn rad_send_request 28948caee2aSBrian Somersor by a combination of calls to 29048caee2aSBrian Somers.Fn rad_init_send_request 29148caee2aSBrian Somersand 29248caee2aSBrian Somers.Fn rad_continue_send_request . 29348caee2aSBrian Somers.Pp 29448caee2aSBrian SomersThe 29548caee2aSBrian Somers.Fn rad_send_request 29648caee2aSBrian Somersfunction sends the request and waits for a valid reply, 297082bfe67SJohn Polstraretrying the defined servers in round-robin fashion as necessary. 298082bfe67SJohn PolstraIf a valid response is received, 299082bfe67SJohn Polstra.Fn rad_send_request 300082bfe67SJohn Polstrareturns the RADIUS code which specifies the type of the response. 301082bfe67SJohn PolstraThis will typically be 302082bfe67SJohn Polstra.Dv RAD_ACCESS_ACCEPT , 303082bfe67SJohn Polstra.Dv RAD_ACCESS_REJECT , 304082bfe67SJohn Polstraor 305082bfe67SJohn Polstra.Dv RAD_ACCESS_CHALLENGE . 306082bfe67SJohn PolstraIf no valid response is received, 307082bfe67SJohn Polstra.Fn rad_send_request 30881b380a8SRuslan Ermilovreturns \-1. 309082bfe67SJohn Polstra.Pp 31048caee2aSBrian SomersAs an alternative, if you do not wish to block waiting for a response, 31148caee2aSBrian Somers.Fn rad_init_send_request 31248caee2aSBrian Somersand 31348caee2aSBrian Somers.Fn rad_continue_send_request 31481b380a8SRuslan Ermilovmay be used instead. 31581b380a8SRuslan ErmilovIf a reply is received from the RADIUS server or a 31648caee2aSBrian Somerstimeout occurs, these functions return a value as described for 31748caee2aSBrian Somers.Fn rad_send_request . 31848caee2aSBrian SomersOtherwise, a value of zero is returned and the values pointed to by 31981b380a8SRuslan Ermilov.Fa fd 32048caee2aSBrian Somersand 32181b380a8SRuslan Ermilov.Fa tv 32248caee2aSBrian Somersare set to the descriptor and timeout that should be passed to 32348caee2aSBrian Somers.Xr select 2 . 32448caee2aSBrian Somers.Pp 32548caee2aSBrian Somers.Fn rad_init_send_request 32648caee2aSBrian Somersmust be called first, followed by repeated calls to 32748caee2aSBrian Somers.Fn rad_continue_send_request 32848caee2aSBrian Somersas long as a return value of zero is given. 32948caee2aSBrian SomersBetween each call, the application should call 33048caee2aSBrian Somers.Xr select 2 , 33148caee2aSBrian Somerspassing 33281b380a8SRuslan Ermilov.Fa *fd 33348caee2aSBrian Somersas a read descriptor and timing out after the interval specified by 33481b380a8SRuslan Ermilov.Fa tv . 33581b380a8SRuslan ErmilovWhen 33681b380a8SRuslan Ermilov.Xr select 2 33781b380a8SRuslan Ermilovreturns, 33848caee2aSBrian Somers.Fn rad_continue_send_request 33948caee2aSBrian Somersshould be called with 34081b380a8SRuslan Ermilov.Fa selected 34148caee2aSBrian Somersset to a non-zero value if 34248caee2aSBrian Somers.Xr select 2 34348caee2aSBrian Somersindicated that the descriptor is readable. 34448caee2aSBrian Somers.Pp 345082bfe67SJohn PolstraLike RADIUS requests, each response may contain zero or more 34681b380a8SRuslan Ermilovattributes. 34781b380a8SRuslan ErmilovAfter a response has been received successfully by 34848caee2aSBrian Somers.Fn rad_send_request 34948caee2aSBrian Somersor 35048caee2aSBrian Somers.Fn rad_continue_send_request , 351082bfe67SJohn Polstraits attributes can be extracted one by one using 352082bfe67SJohn Polstra.Fn rad_get_attr . 353082bfe67SJohn PolstraEach time 354082bfe67SJohn Polstra.Fn rad_get_attr 355082bfe67SJohn Polstrais called, it gets the next attribute from the current response, and 356082bfe67SJohn Polstrastores a pointer to the data and the length of the data via the 357082bfe67SJohn Polstrareference parameters 35881b380a8SRuslan Ermilov.Fa data 359082bfe67SJohn Polstraand 36081b380a8SRuslan Ermilov.Fa len , 36181b380a8SRuslan Ermilovrespectively. 36281b380a8SRuslan ErmilovNote that the data resides in the response itself, 363082bfe67SJohn Polstraand must not be modified. 364082bfe67SJohn PolstraA successful call to 365082bfe67SJohn Polstra.Fn rad_get_attr 366082bfe67SJohn Polstrareturns the RADIUS attribute type. 367082bfe67SJohn PolstraIf no more attributes remain in the current response, 368082bfe67SJohn Polstra.Fn rad_get_attr 369082bfe67SJohn Polstrareturns 0. 37081b380a8SRuslan ErmilovIf an error such as a malformed attribute is detected, \-1 is 371082bfe67SJohn Polstrareturned. 372082bfe67SJohn Polstra.Pp 373fc3f62faSBrian SomersIf 374fc3f62faSBrian Somers.Fn rad_get_attr 375fc3f62faSBrian Somersreturns 376fc3f62faSBrian Somers.Dv RAD_VENDOR_SPECIFIC , 377fc3f62faSBrian Somers.Fn rad_get_vendor_attr 378fc3f62faSBrian Somersmay be called to determine the vendor. 379fc3f62faSBrian SomersThe vendor specific RADIUS attribute type is returned. 380fc3f62faSBrian SomersThe reference parameters 38181b380a8SRuslan Ermilov.Fa data 382fc3f62faSBrian Somersand 38381b380a8SRuslan Ermilov.Fa len 38448091bb0SRuslan Ermilov(as returned from 38548091bb0SRuslan Ermilov.Fn rad_get_attr ) 386fc3f62faSBrian Somersare passed to 387fc3f62faSBrian Somers.Fn rad_get_vendor_attr , 388fc3f62faSBrian Somersand are adjusted to point to the vendor specific attribute data. 389fc3f62faSBrian Somers.Pp 390082bfe67SJohn PolstraThe common types of attributes can be decoded using 391082bfe67SJohn Polstra.Fn rad_cvt_addr , 392082bfe67SJohn Polstra.Fn rad_cvt_int , 393082bfe67SJohn Polstraand 394082bfe67SJohn Polstra.Fn rad_cvt_string . 395082bfe67SJohn PolstraThese functions accept a pointer to the attribute data, which should 396082bfe67SJohn Polstrahave been obtained using 397fc3f62faSBrian Somers.Fn rad_get_attr 398fc3f62faSBrian Somersand optionally 399fc3f62faSBrian Somers.Fn rad_get_vendor_attr . 400082bfe67SJohn PolstraIn the case of 401082bfe67SJohn Polstra.Fn rad_cvt_string , 402082bfe67SJohn Polstrathe length 40381b380a8SRuslan Ermilov.Fa len 40481b380a8SRuslan Ermilovmust also be given. 40581b380a8SRuslan ErmilovThese functions interpret the attribute as an 406082bfe67SJohn PolstraInternet address, an integer, or a string, respectively, and return 407082bfe67SJohn Polstraits value. 408082bfe67SJohn Polstra.Fn rad_cvt_string 40981b380a8SRuslan Ermilovreturns its value as a 41081b380a8SRuslan Ermilov.Dv NUL Ns -terminated 41181b380a8SRuslan Ermilovstring in dynamically 41281b380a8SRuslan Ermilovallocated memory. 41381b380a8SRuslan ErmilovThe application should free the string using 414082bfe67SJohn Polstra.Xr free 3 415082bfe67SJohn Polstrawhen it is no longer needed. 416082bfe67SJohn Polstra.Pp 417082bfe67SJohn PolstraIf insufficient virtual memory is available, 418082bfe67SJohn Polstra.Fn rad_cvt_string 419082bfe67SJohn Polstrareturns 420082bfe67SJohn Polstra.Dv NULL . 421082bfe67SJohn Polstra.Fn rad_cvt_addr 422082bfe67SJohn Polstraand 423082bfe67SJohn Polstra.Fn rad_cvt_int 424082bfe67SJohn Polstracannot fail. 425628e6cd4SBrian Somers.Pp 426628e6cd4SBrian SomersThe 427628e6cd4SBrian Somers.Fn rad_request_authenticator 428628e6cd4SBrian Somersfunction may be used to obtain the Request-Authenticator attribute value 429628e6cd4SBrian Somersassociated with the current RADIUS server according to the supplied 430628e6cd4SBrian Somersrad_handle. 431628e6cd4SBrian SomersThe target buffer 43281b380a8SRuslan Ermilov.Fa buf 433628e6cd4SBrian Somersof length 43481b380a8SRuslan Ermilov.Fa len 435628e6cd4SBrian Somersmust be supplied and should be at least 16 bytes. 436628e6cd4SBrian SomersThe return value is the number of bytes written to 43781b380a8SRuslan Ermilov.Fa buf 43881b380a8SRuslan Ermilovor \-1 to indicate that 43981b380a8SRuslan Ermilov.Fa len 440628e6cd4SBrian Somerswas not large enough. 441628e6cd4SBrian Somers.Pp 442628e6cd4SBrian SomersThe 443628e6cd4SBrian Somers.Fn rad_server_secret 444628e6cd4SBrian Somersreturns the secret shared with the current RADIUS server according to the 445628e6cd4SBrian Somerssupplied rad_handle. 446b4b831efSRuslan Ermilov.Pp 447b4b831efSRuslan ErmilovThe 44807d7b74bSAlexander V. Chernikov.Fn rad_bind_to 44907d7b74bSAlexander V. Chernikovassigns a source address for all requests to the current RADIUS server. 45007d7b74bSAlexander V. Chernikov.Pp 45107d7b74bSAlexander V. ChernikovThe 452b4b831efSRuslan Ermilov.Fn rad_demangle 453b4b831efSRuslan Ermilovfunction demangles attributes containing passwords and MS-CHAPv1 MPPE-Keys. 454b4b831efSRuslan ErmilovThe return value is 455b4b831efSRuslan Ermilov.Dv NULL 456b4b831efSRuslan Ermilovon failure, or the plaintext attribute. 457b4b831efSRuslan ErmilovThis value should be freed using 458b4b831efSRuslan Ermilov.Xr free 3 459b4b831efSRuslan Ermilovwhen it is no longer needed. 460b4b831efSRuslan Ermilov.Pp 461b4b831efSRuslan ErmilovThe 462b4b831efSRuslan Ermilov.Fn rad_demangle_mppe_key 463b4b831efSRuslan Ermilovfunction demangles the send- and recv-keys when using MPPE (see RFC 2548). 464b4b831efSRuslan ErmilovThe return value is 465b4b831efSRuslan Ermilov.Dv NULL 466b4b831efSRuslan Ermilovon failure, or the plaintext attribute. 467b4b831efSRuslan ErmilovThis value should be freed using 468b4b831efSRuslan Ermilov.Xr free 3 469b4b831efSRuslan Ermilovwhen it is no longer needed. 47081b380a8SRuslan Ermilov.Ss Obtaining Error Messages 471082bfe67SJohn PolstraThose functions which accept a 47281b380a8SRuslan Ermilov.Vt "struct rad_handle *" 47381b380a8SRuslan Ermilovargument record an error message if they fail. 47481b380a8SRuslan ErmilovThe error message 475082bfe67SJohn Polstracan be retrieved by calling 476082bfe67SJohn Polstra.Fn rad_strerror . 477082bfe67SJohn PolstraThe message text is overwritten on each new error for the given 47881b380a8SRuslan Ermilov.Vt "struct rad_handle *" . 479082bfe67SJohn PolstraThus the message must be copied if it is to be preserved through 480082bfe67SJohn Polstrasubsequent library calls using the same handle. 48181b380a8SRuslan Ermilov.Ss Cleanup 482082bfe67SJohn PolstraTo free the resources used by the RADIUS library, call 483082bfe67SJohn Polstra.Fn rad_close . 4843fc0b61cSAlexander Motin.Ss Server operation 485c2025a76SJoel DahlServer mode operates much alike to client mode, except packet send and receive 486*3d265fceSGordon Berglingsteps are swapped. 487*3d265fceSGordon BerglingTo operate as server you should obtain server context with 4883fc0b61cSAlexander Motin.Fn rad_server_open 4893fc0b61cSAlexander Motinfunction, passing opened and bound UDP socket file descriptor as argument. 4903fc0b61cSAlexander MotinYou should define allowed clients and their secrets using 4913fc0b61cSAlexander Motin.Fn rad_add_server 4923fc0b61cSAlexander Motinfunction. port, timeout and max_tries arguments are ignored in server mode. 4933fc0b61cSAlexander MotinYou should call 4943fc0b61cSAlexander Motin.Fn rad_receive_request 495*3d265fceSGordon Berglingfunction to receive request from client. 496*3d265fceSGordon BerglingIf you do not want to block on socket read, you are free to use any 497*3d265fceSGordon Berglingpoll(), select() or non-blocking sockets for the socket. 4983fc0b61cSAlexander MotinReceived request can be parsed with same parsing functions as for client. 4993fc0b61cSAlexander MotinTo respond to the request you should call 5003fc0b61cSAlexander Motin.Fn rad_create_response 5013fc0b61cSAlexander Motinand fill response content with same packet writing functions as for client. 5023fc0b61cSAlexander MotinWhen packet is ready, it should be sent with 503a3fb6da9SGlen Barber.Fn rad_send_response . 504082bfe67SJohn Polstra.Sh RETURN VALUES 50581b380a8SRuslan ErmilovThe following functions return a non-negative value on success. 50681b380a8SRuslan ErmilovIf 50781b380a8SRuslan Ermilovthey detect an error, they return \-1 and record an error message 508082bfe67SJohn Polstrawhich can be retrieved using 509082bfe67SJohn Polstra.Fn rad_strerror . 510082bfe67SJohn Polstra.Pp 511082bfe67SJohn Polstra.Bl -item -offset indent -compact 512082bfe67SJohn Polstra.It 513082bfe67SJohn Polstra.Fn rad_add_server 514082bfe67SJohn Polstra.It 515082bfe67SJohn Polstra.Fn rad_config 516082bfe67SJohn Polstra.It 517082bfe67SJohn Polstra.Fn rad_create_request 518082bfe67SJohn Polstra.It 5193fc0b61cSAlexander Motin.Fn rad_create_response 5203fc0b61cSAlexander Motin.It 521082bfe67SJohn Polstra.Fn rad_get_attr 522082bfe67SJohn Polstra.It 523082bfe67SJohn Polstra.Fn rad_put_addr 524082bfe67SJohn Polstra.It 525082bfe67SJohn Polstra.Fn rad_put_attr 526082bfe67SJohn Polstra.It 527082bfe67SJohn Polstra.Fn rad_put_int 528082bfe67SJohn Polstra.It 529082bfe67SJohn Polstra.Fn rad_put_string 530082bfe67SJohn Polstra.It 531b4b831efSRuslan Ermilov.Fn rad_put_message_authentic 532b4b831efSRuslan Ermilov.It 53348caee2aSBrian Somers.Fn rad_init_send_request 53448caee2aSBrian Somers.It 53548caee2aSBrian Somers.Fn rad_continue_send_request 53648caee2aSBrian Somers.It 537082bfe67SJohn Polstra.Fn rad_send_request 5383fc0b61cSAlexander Motin.It 5393fc0b61cSAlexander Motin.Fn rad_send_response 540082bfe67SJohn Polstra.El 541082bfe67SJohn Polstra.Pp 542082bfe67SJohn PolstraThe following functions return a 543082bfe67SJohn Polstra.No non- Ns Dv NULL 54481b380a8SRuslan Ermilovpointer on success. 54581b380a8SRuslan ErmilovIf they are unable to allocate sufficient 546082bfe67SJohn Polstravirtual memory, they return 547082bfe67SJohn Polstra.Dv NULL , 548082bfe67SJohn Polstrawithout recording an error message. 549082bfe67SJohn Polstra.Pp 550082bfe67SJohn Polstra.Bl -item -offset indent -compact 551082bfe67SJohn Polstra.It 5520981dfefSJohn Polstra.Fn rad_acct_open 553082bfe67SJohn Polstra.It 5540981dfefSJohn Polstra.Fn rad_auth_open 5550981dfefSJohn Polstra.It 5563fc0b61cSAlexander Motin.Fn rad_server_open 5573fc0b61cSAlexander Motin.It 5580981dfefSJohn Polstra.Fn rad_cvt_string 559082bfe67SJohn Polstra.El 560b4b831efSRuslan Ermilov.Pp 561b4b831efSRuslan ErmilovThe following functions return a 562b4b831efSRuslan Ermilov.No non- Ns Dv NULL 563b4b831efSRuslan Ermilovpointer on success. 564b4b831efSRuslan ErmilovIf they fail, they return 565b4b831efSRuslan Ermilov.Dv NULL , 566b4b831efSRuslan Ermilovwith recording an error message. 567b4b831efSRuslan Ermilov.Pp 568b4b831efSRuslan Ermilov.Bl -item -offset indent -compact 569b4b831efSRuslan Ermilov.It 570b4b831efSRuslan Ermilov.Fn rad_demangle 571b4b831efSRuslan Ermilov.It 572b4b831efSRuslan Ermilov.Fn rad_demangle_mppe_key 573b4b831efSRuslan Ermilov.El 574082bfe67SJohn Polstra.Sh FILES 57581b380a8SRuslan Ermilov.Bl -tag -width indent 57681b380a8SRuslan Ermilov.It Pa /etc/radius.conf 57781b380a8SRuslan Ermilov.El 578082bfe67SJohn Polstra.Sh SEE ALSO 579082bfe67SJohn Polstra.Xr radius.conf 5 580082bfe67SJohn Polstra.Rs 58181b380a8SRuslan Ermilov.%A "C. Rigney, et al" 58242635956SRuslan Ermilov.%T "Remote Authentication Dial In User Service (RADIUS)" 583b4b831efSRuslan Ermilov.%O "RFC 2865" 584082bfe67SJohn Polstra.Re 5850981dfefSJohn Polstra.Rs 58681b380a8SRuslan Ermilov.%A "C. Rigney" 58781b380a8SRuslan Ermilov.%T "RADIUS Accounting" 588b4b831efSRuslan Ermilov.%O "RFC 2866" 589b4b831efSRuslan Ermilov.Re 590b4b831efSRuslan Ermilov.Rs 591b4b831efSRuslan Ermilov.%A G. Zorn 592b4b831efSRuslan Ermilov.%T "Microsoft Vendor-specific RADIUS attributes" 593b4b831efSRuslan Ermilov.%O RFC 2548 594b4b831efSRuslan Ermilov.Re 595b4b831efSRuslan Ermilov.Rs 596b4b831efSRuslan Ermilov.%A C. Rigney, et al 597b4b831efSRuslan Ermilov.%T "RADIUS extensions" 598b4b831efSRuslan Ermilov.%O RFC 2869 5990981dfefSJohn Polstra.Re 600082bfe67SJohn Polstra.Sh AUTHORS 60181b380a8SRuslan Ermilov.An -nosplit 6020981dfefSJohn PolstraThis software was originally written by 603082bfe67SJohn Polstra.An John Polstra , 604b5c508fbSRuslan Ermilovand donated to the 605b5c508fbSRuslan Ermilov.Fx 606b5c508fbSRuslan Ermilovproject by Juniper Networks, Inc. 60781b380a8SRuslan Ermilov.An Oleg Semyonov 60881b380a8SRuslan Ermilovsubsequently added the ability to perform RADIUS 6090981dfefSJohn Polstraaccounting. 610b4b831efSRuslan ErmilovLater additions and changes by 611b4b831efSRuslan Ermilov.An Michael Bretterklieber . 6123fc0b61cSAlexander MotinServer mode support was added by 6133fc0b61cSAlexander Motin.An Alexander Motin . 614