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

NAME

6       rc_aaa_ctx -
7

SYNOPSIS

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

DESCRIPTION

23       Builds  an  authentication/accounting request for port id nas_port with
24       the value_pairs send and submits it to a server.  This  function  keeps
25       its  state  in  ctx after a successful operation. It can be deallocated
26       using rc_aaa_ctx_free().
27

PARAMETERS

29       rh     a handle to parsed configuration.
30
31
32       ctx    if non-NULL it will contain the context of the request; Its ini‐
33              tial  value  should  be  NULL  and  it  must  be  released using
34              rc_aaa_ctx_free().
35
36
37       client_port
38
39
40       send   a VALUE_PAIR array of values (e.g., PW_USER_NAME).
41
42
43       received
44              an allocated array of received values.
45
46
47       msg    must be an array of PW_MAX_MSG_SIZE or NULL;  will  contain  the
48              concatenation of any PW_REPLY_MESSAGE received.
49
50
51       add_nas_port
52              this  should be zero; if non-zero it will include PW_NAS_PORT in
53              sent pairs.
54
55
56       request_type
57              one of standard RADIUS codes (e.g., PW_ACCESS_REQUEST).
58
59

STRUCTURES

61
62       Avoid using this structure directly. Use the rc_avpair_get_ functions.
63
64              struct rc_value_pair {
65                char                   name[RC_NAME_LENGTH+1];      // attribute name if known.
66                uint64_t               attribute; // attribute numeric value of type rc_attr_id including vendor; use VENDOR() and ATTRID() to separate.
67                rc_attr_type           type;      // attribute type.
68                uint32_t               lvalue;    // attribute value if type is PW_TYPE_INTEGER, PW_TYPE_DATE or PW_TYPE_IPADDR.
69                char                   strvalue[AUTH_STRING_LEN+1];  // contains attribute value in other cases.
70                struct rc_value_pair  *next;
71                char                   pad[32];       // unused pad
72              };
73
74
75       Avoid using this structure directly. Use the rc_avpair_get_ functions.
76
77              struct rc_value_pair {
78                char                   name[RC_NAME_LENGTH+1];      // attribute name if known.
79                uint64_t               attribute; // attribute numeric value of type rc_attr_id including vendor; use VENDOR() and ATTRID() to separate.
80                rc_attr_type           type;      // attribute type.
81                uint32_t               lvalue;    // attribute value if type is PW_TYPE_INTEGER, PW_TYPE_DATE or PW_TYPE_IPADDR.
82                char                   strvalue[AUTH_STRING_LEN+1];  // contains attribute value in other cases.
83                struct rc_value_pair  *next;
84                char                   pad[32];       // unused pad
85              };
86

RETURN VALUE

88       received value_pairs in received, messages from the server in  msg  and
89       OK_RC  (0)  on  success, CHALLENGE_RC (3) on Access-Challenge received,
90       negative on failure as return value.
91

SEE ALSO

93       radcli.h(3), rc_aaa(3), rc_aaa_ctx(3), rc_aaa_ctx_free(3),
94       rc_aaa_ctx_get_secret(3), rc_aaa_ctx_get_vector(3),
95       rc_aaa_ctx_server(3), rc_acct(3), rc_acct_proxy(3), rc_add_config(3),
96       rc_apply_config(3), rc_auth(3), rc_auth_proxy(3), rc_avpair_add(3),
97       rc_avpair_assign(3), rc_avpair_copy(3), rc_avpair_free(3),
98       rc_avpair_gen(3), rc_avpair_get(3), rc_avpair_get_attr(3),
99       rc_avpair_get_in6(3), rc_avpair_get_raw(3), rc_avpair_get_uint32(3),
100       rc_avpair_insert(3), rc_avpair_log(3), rc_avpair_new(3),
101       rc_avpair_next(3), rc_avpair_parse(3), rc_avpair_remove(3),
102       rc_avpair_tostr(3), rc_buildreq(3), rc_check(3), rc_check_tls(3),
103       rc_conf_int(3), rc_conf_srv(3), rc_conf_str(3), rc_config_free(3),
104       rc_config_init(3), rc_destroy(3), rc_dict_addattr(3),
105       rc_dict_addval(3), rc_dict_addvend(3), rc_dict_findattr(3),
106       rc_dict_findval(3), rc_dict_findvend(3), rc_dict_free(3),
107       rc_dict_getattr(3), rc_dict_getval(3), rc_dict_getvend(3),
108       rc_find_server_addr(3), rc_get_socket_type(3), rc_get_srcaddr(3),
109       rc_getport(3), rc_mksid(3), rc_new(3), rc_openlog(3),
110       rc_own_hostname(3), rc_read_config(3), rc_read_dictionary(3),
111       rc_read_dictionary_from_buffer(3), rc_send_server(3), rc_setdebug(3),
112       rc_test_config(3), rc_tls_fd(3), rc_aaa_ctx_free()
113
114
115
116radcli                            2023-01-29                     rc_aaa_ctx(3)
Impressum