1rc_aaa(3)                    Radius client library                   rc_aaa(3)
2
3
4

NAME

6       rc_aaa -
7

SYNOPSIS

9       #include <radcli/radcli.h>
10
11       int rc_aaa(
12           rc_handle        *rh,
13           uint32_t          client_port,
14           VALUE_PAIR       *send,
15           VALUE_PAIR      **received,
16           char             *msg,
17           int               add_nas_port,
18           rc_standard_codes request_type
19       );
20

DESCRIPTION

22       Builds  an  authentication/accounting  request  for port id client_port
23       with the value_pairs send and submits it to a server
24

PARAMETERS

26       rh     a handle to parsed configuration.
27
28
29       client_port
30              the client port number to use (may be zero  to  use  any  availā€
31              able).
32
33
34       send   a VALUE_PAIR array of values (e.g., PW_USER_NAME).
35
36
37       received
38              an allocated array of received values.
39
40
41       msg    must  be  an  array of PW_MAX_MSG_SIZE or NULL; will contain the
42              concatenation of any PW_REPLY_MESSAGE received.
43
44
45       add_nas_port
46              if non-zero it will include PW_NAS_PORT in sent pairs.
47
48
49       request_type
50              one of standard RADIUS codes (e.g., PW_ACCESS_REQUEST).
51
52

STRUCTURES

54
55       this structure directly. Use the rc_avpair_get_ functions.
56
57              struct rc_value_pair {
58                char                   name;      // attribute name if known.
59                unsigned               attribute; // attribute numeric value of type rc_attr_id.
60                rc_attr_type           type;      // attribute type.
61                uint32_t               lvalue;    // attribute value if type is PW_TYPE_INTEGER, PW_TYPE_DATE or PW_TYPE_IPADDR.
62                char                   strvalue;  // contains attribute value in other cases.
63                struct rc_value_pair  *next;
64                char                   pad;       // unused pad
65              };
66
67
68       this structure directly. Use the rc_avpair_get_ functions.
69
70              struct rc_value_pair {
71                char                   name;      // attribute name if known.
72                unsigned               attribute; // attribute numeric value of type rc_attr_id.
73                rc_attr_type           type;      // attribute type.
74                uint32_t               lvalue;    // attribute value if type is PW_TYPE_INTEGER, PW_TYPE_DATE or PW_TYPE_IPADDR.
75                char                   strvalue;  // contains attribute value in other cases.
76                struct rc_value_pair  *next;
77                char                   pad;       // unused pad
78              };
79

RETURN VALUE

81       received value_pairs in received, messages from the server in  msg  and
82       OK_RC  (0)  on  success, CHALLENGE_RC (3) on Access-Challenge received,
83       negative on failure as return value.
84

SEE ALSO

86       radcli.h(3), rc_aaa(3), rc_aaa_ctx(3), rc_aaa_ctx_free(3),
87       rc_aaa_ctx_get_secret(3), rc_aaa_ctx_get_vector(3),
88       rc_aaa_ctx_server(3), rc_acct(3), rc_acct_proxy(3), rc_add_config(3),
89       rc_apply_config(3), rc_auth(3), rc_auth_proxy(3), rc_avpair_add(3),
90       rc_avpair_assign(3), rc_avpair_copy(3), rc_avpair_free(3),
91       rc_avpair_gen(3), rc_avpair_get(3), rc_avpair_get_attr(3),
92       rc_avpair_get_in6(3), rc_avpair_get_raw(3), rc_avpair_get_uint32(3),
93       rc_avpair_insert(3), rc_avpair_log(3), rc_avpair_new(3),
94       rc_avpair_next(3), rc_avpair_parse(3), rc_avpair_remove(3),
95       rc_avpair_tostr(3), rc_buildreq(3), rc_check(3), rc_check_tls(3),
96       rc_conf_int(3), rc_conf_srv(3), rc_conf_str(3), rc_config_free(3),
97       rc_config_init(3), rc_destroy(3), rc_dict_findattr(3),
98       rc_dict_findval(3), rc_dict_findvend(3), rc_dict_free(3),
99       rc_dict_getattr(3), rc_dict_getval(3), rc_dict_getvend(3),
100       rc_find_server_addr(3), rc_get_socket_type(3), rc_get_srcaddr(3),
101       rc_getport(3), rc_mksid(3), rc_new(3), rc_openlog(3),
102       rc_own_hostname(3), rc_read_config(3), rc_read_dictionary(3),
103       rc_send_server(3), rc_setdebug(3), rc_test_config(3), rc_tls_fd(3)
104
105
106
107radcli                            2018-05-08                         rc_aaa(3)
Impressum