1rc_aaa_ctx_server(3) Radius client library rc_aaa_ctx_server(3)
2
3
4
6 rc_aaa_ctx_server -
7
9 #include <radcli/radcli.h>
10
11 int rc_aaa_ctx_server(
12 rc_handle *rh,
13 RC_AAA_CTX **ctx,
14 SERVER *aaaserver,
15 rc_type type,
16 uint32_t client_port,
17 VALUE_PAIR *send,
18 VALUE_PAIR **received,
19 char *msg,
20 int add_nas_port,
21 rc_standard_codes request_type
22 );
23
25 Builds an authentication/accounting request for port id client_port
26 with the value_pairs send and submits it to a specified server. This
27 function keeps its state in ctx after a successful operation. It can be
28 deallocated using rc_aaa_ctx_free().
29
31 rh a handle to parsed configuration.
32
33
34 ctx if non-NULL it will contain the context of the request; Its ini‐
35 tial value should be NULL and it must be released using
36 rc_aaa_ctx_free().
37
38
39 aaaserver
40 a non-NULL SERVER to send the message to.
41
42
43 type
44
45
46 client_port
47 the client port number to use (may be zero to use any avail‐
48 able).
49
50
51 send a VALUE_PAIR array of values (e.g., PW_USER_NAME).
52
53
54 received
55 an allocated array of received values.
56
57
58 msg must be an array of PW_MAX_MSG_SIZE or NULL; will contain the
59 concatenation of any PW_REPLY_MESSAGE received.
60
61
62 add_nas_port
63 if non-zero it will include PW_NAS_PORT in sent pairs.
64
65
66 request_type
67 one of standard RADIUS codes (e.g., PW_ACCESS_REQUEST).
68
69
71
72 this structure directly, it is included for backwards compatibility
73 only. Several of its fields have been deprecated.
74
75 struct server {
76 int max;
77 char *name;
78 uint16_t port;
79 char *secret;
80 double deadtime_ends; // unused
81 };
82
83
84 this structure directly. Use the rc_avpair_get_ functions.
85
86 struct rc_value_pair {
87 char name; // attribute name if known.
88 unsigned attribute; // attribute numeric value of type rc_attr_id.
89 rc_attr_type type; // attribute type.
90 uint32_t lvalue; // attribute value if type is PW_TYPE_INTEGER, PW_TYPE_DATE or PW_TYPE_IPADDR.
91 char strvalue; // contains attribute value in other cases.
92 struct rc_value_pair *next;
93 char pad; // unused pad
94 };
95
96
97 this structure directly. Use the rc_avpair_get_ functions.
98
99 struct rc_value_pair {
100 char name; // attribute name if known.
101 unsigned attribute; // attribute numeric value of type rc_attr_id.
102 rc_attr_type type; // attribute type.
103 uint32_t lvalue; // attribute value if type is PW_TYPE_INTEGER, PW_TYPE_DATE or PW_TYPE_IPADDR.
104 char strvalue; // contains attribute value in other cases.
105 struct rc_value_pair *next;
106 char pad; // unused pad
107 };
108
110 received value_pairs in received, messages from the server in msg and
111 OK_RC (0) on success, CHALLENGE_RC (3) on Access-Challenge received,
112 negative on failure as return value.
113
115 radcli.h(3), rc_aaa(3), rc_aaa_ctx(3), rc_aaa_ctx_free(3),
116 rc_aaa_ctx_get_secret(3), rc_aaa_ctx_get_vector(3),
117 rc_aaa_ctx_server(3), rc_acct(3), rc_acct_proxy(3), rc_add_config(3),
118 rc_apply_config(3), rc_auth(3), rc_auth_proxy(3), rc_avpair_add(3),
119 rc_avpair_assign(3), rc_avpair_copy(3), rc_avpair_free(3),
120 rc_avpair_gen(3), rc_avpair_get(3), rc_avpair_get_attr(3),
121 rc_avpair_get_in6(3), rc_avpair_get_raw(3), rc_avpair_get_uint32(3),
122 rc_avpair_insert(3), rc_avpair_log(3), rc_avpair_new(3),
123 rc_avpair_next(3), rc_avpair_parse(3), rc_avpair_remove(3),
124 rc_avpair_tostr(3), rc_buildreq(3), rc_check(3), rc_check_tls(3),
125 rc_conf_int(3), rc_conf_srv(3), rc_conf_str(3), rc_config_free(3),
126 rc_config_init(3), rc_destroy(3), rc_dict_findattr(3),
127 rc_dict_findval(3), rc_dict_findvend(3), rc_dict_free(3),
128 rc_dict_getattr(3), rc_dict_getval(3), rc_dict_getvend(3),
129 rc_find_server_addr(3), rc_get_socket_type(3), rc_get_srcaddr(3),
130 rc_getport(3), rc_mksid(3), rc_new(3), rc_openlog(3),
131 rc_own_hostname(3), rc_read_config(3), rc_read_dictionary(3),
132 rc_send_server(3), rc_setdebug(3), rc_test_config(3), rc_tls_fd(3),
133 rc_aaa_ctx_free()
134
135
136
137radcli 2018-05-08 rc_aaa_ctx_server(3)