1radcli.h(3)                  Radius client library                 radcli.h(3)
2
3
4

NAME

6       radcli.h -
7

SYNOPSIS

9       #include <radcli/radcli.h>
10

DESCRIPTION

12              int            rc_aaa(rc_handle *, uint32_t, VALUE_PAIR *, VALUE_PAIR **, char *, int, rc_standard_codes);
13              int            rc_aaa_ctx(rc_handle *, RC_AAA_CTX **, uint32_t, VALUE_PAIR *, VALUE_PAIR **, char *, int, rc_standard_codes);
14              void           rc_aaa_ctx_free(RC_AAA_CTX *);
15              const char    *rc_aaa_ctx_get_secret(RC_AAA_CTX *);
16              const void    *rc_aaa_ctx_get_vector(RC_AAA_CTX *);
17              int            rc_aaa_ctx_server(rc_handle *, RC_AAA_CTX **, SERVER *, rc_type, uint32_t, VALUE_PAIR *, VALUE_PAIR **, char *, int, rc_standard_codes);
18              int            rc_acct(rc_handle *, uint32_t, VALUE_PAIR *);
19              int            rc_acct_proxy(rc_handle *, VALUE_PAIR *);
20              int            rc_add_config(rc_handle *, char const *, char const *, char const *, int);
21              int            rc_apply_config(rc_handle *);
22              int            rc_auth(rc_handle *, uint32_t, VALUE_PAIR *, VALUE_PAIR **, char *);
23              int            rc_auth_proxy(rc_handle *, VALUE_PAIR *, VALUE_PAIR **, char *);
24              VALUE_PAIR    *rc_avpair_add(rc_handle const *, VALUE_PAIR **, int, void const *, int, int);
25              int            rc_avpair_assign(VALUE_PAIR *, void const *, int);
26              VALUE_PAIR    *rc_avpair_copy(VALUE_PAIR *);
27              void           rc_avpair_free(VALUE_PAIR *);
28              VALUE_PAIR    *rc_avpair_gen(rc_handle const *, VALUE_PAIR *, unsigned char const *, int, int);
29              VALUE_PAIR    *rc_avpair_get(VALUE_PAIR *, int, int);
30              void           rc_avpair_get_attr(VALUE_PAIR *, unsigned *, unsigned *);
31              int            rc_avpair_get_in6(VALUE_PAIR *, struct in6_addr *, unsigned *);
32              int            rc_avpair_get_raw(VALUE_PAIR *, char **, unsigned *);
33              int            rc_avpair_get_uint32(VALUE_PAIR *, uint32_t *);
34              void           rc_avpair_insert(VALUE_PAIR **, VALUE_PAIR *, VALUE_PAIR *);
35              char          *rc_avpair_log(rc_handle const *, VALUE_PAIR *, char *, size_t);
36              VALUE_PAIR    *rc_avpair_new(rc_handle const *, int, void const *, int, int);
37              VALUE_PAIR    *rc_avpair_next(VALUE_PAIR *);
38              int            rc_avpair_parse(rc_handle const *, char const *, VALUE_PAIR **);
39              void           rc_avpair_remove(VALUE_PAIR **, int, int);
40              int            rc_avpair_tostr(rc_handle const *, VALUE_PAIR *, char *, int, char *, int);
41              void           rc_buildreq(rc_handle const *, SEND_DATA *, int, char *, unsigned short, char *, int, int);
42              int            rc_check(rc_handle *, char *, char *, unsigned short, char *);
43              int            rc_check_tls(rc_handle *);
44              int            rc_conf_int(rc_handle const *, char const *);
45              SERVER        *rc_conf_srv(rc_handle const *, char const *);
46              char          *rc_conf_str(rc_handle const *, char const *);
47              void           rc_config_free(rc_handle *);
48              rc_handle     *rc_config_init(rc_handle *);
49              void           rc_destroy(rc_handle *);
50              DICT_ATTR     *rc_dict_findattr(rc_handle const *, char const *);
51              DICT_VALUE    *rc_dict_findval(rc_handle const *, char const *);
52              DICT_VENDOR   *rc_dict_findvend(rc_handle const *, char const *);
53              void           rc_dict_free(rc_handle *);
54              DICT_ATTR     *rc_dict_getattr(rc_handle const *, int);
55              DICT_VALUE    *rc_dict_getval(rc_handle const *, uint32_t, char const *);
56              DICT_VENDOR   *rc_dict_getvend(rc_handle const *, int);
57              int            rc_find_server_addr(rc_handle const *, char const *, struct addrinfo **, char *, rc_type);
58              rc_socket_type rc_get_socket_type(rc_handle *);
59              int            rc_get_srcaddr(struct sockaddr *, const struct sockaddr *);
60              unsigned short rc_getport(int);
61              char          *rc_mksid(void);
62              rc_handle     *rc_new(void);
63              void           rc_openlog(char const *);
64              int            rc_own_hostname(char *, int);
65              rc_handle     *rc_read_config(char const *);
66              int            rc_read_dictionary(rc_handle *, char const *);
67              int            rc_read_dictionary_from_buffer(rc_handle *, char const *, size_t);
68              int            rc_send_server(rc_handle *, SEND_DATA *, char *, rc_type);
69              void           rc_setdebug(int);
70              int            rc_test_config(rc_handle *, char const *);
71              int            rc_tls_fd(rc_handle *);
72
73
74       this structure directly. Use the rc_avpair_get_ functions.
75
76              struct rc_value_pair {
77                char                   name;      // attribute name if known.
78                unsigned               attribute; // attribute numeric value of type rc_attr_id.
79                rc_attr_type           type;      // attribute type.
80                uint32_t               lvalue;    // attribute value if type is PW_TYPE_INTEGER, PW_TYPE_DATE or PW_TYPE_IPADDR.
81                char                   strvalue;  // contains attribute value in other cases.
82                struct rc_value_pair  *next;
83                char                   pad;       // unused pad
84              };
85
86
87              struct send_data {
88                uint8_t      code;          // RADIUS packet code.
89                uint8_t      seq_nbr;       // Packet sequence number.
90                char        *server;        // Name/addrress of RADIUS server.
91                int          svc_port;      // RADIUS protocol destination port.
92                char        *secret;        // Shared secret of RADIUS server.
93                int          timeout;       // Session timeout in seconds.
94                int          retries;
95                VALUE_PAIR  *send_pairs;    // More a/v pairs to send.
96                VALUE_PAIR  *receive_pairs; // Where to place received a/v pairs.
97              };
98
99
100       this  structure  directly,  it  is included for backwards compatibility
101       only. Several of its fields have been deprecated.
102
103              struct server {
104                int      max;
105                char    *name;
106                uint16_t port;
107                char    *secret;
108                double   deadtime_ends; // unused
109              };
110

SEE ALSO

112       rc_aaa(3), rc_aaa_ctx(3), rc_aaa_ctx_free(3), rc_aaa_ctx_get_secret(3),
113       rc_aaa_ctx_get_vector(3), rc_aaa_ctx_server(3), rc_acct(3),
114       rc_acct_proxy(3), rc_add_config(3), rc_apply_config(3), rc_auth(3),
115       rc_auth_proxy(3), rc_avpair_add(3), rc_avpair_assign(3),
116       rc_avpair_copy(3), rc_avpair_free(3), rc_avpair_gen(3),
117       rc_avpair_get(3), rc_avpair_get_attr(3), rc_avpair_get_in6(3),
118       rc_avpair_get_raw(3), rc_avpair_get_uint32(3), rc_avpair_insert(3),
119       rc_avpair_log(3), rc_avpair_new(3), rc_avpair_next(3),
120       rc_avpair_parse(3), rc_avpair_remove(3), rc_avpair_tostr(3),
121       rc_buildreq(3), rc_check(3), rc_check_tls(3), rc_conf_int(3),
122       rc_conf_srv(3), rc_conf_str(3), rc_config_free(3), rc_config_init(3),
123       rc_destroy(3), rc_dict_findattr(3), rc_dict_findval(3),
124       rc_dict_findvend(3), rc_dict_free(3), rc_dict_getattr(3),
125       rc_dict_getval(3), rc_dict_getvend(3), rc_find_server_addr(3),
126       rc_get_socket_type(3), rc_get_srcaddr(3), rc_getport(3), rc_mksid(3),
127       rc_new(3), rc_openlog(3), rc_own_hostname(3), rc_read_config(3),
128       rc_read_dictionary(3), rc_read_dictionary_from_buffer(3),
129       rc_send_server(3), rc_setdebug(3), rc_test_config(3), rc_tls_fd(3)
130
131
132
133radcli                            2018-09-14                       radcli.h(3)
Impressum