1rc_aaa_ctx(3) Radius client library rc_aaa_ctx(3)
2
3
4
6 rc_aaa_ctx -
7
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
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
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
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
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
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)