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

NAME

6       rc_aaa_ctx_server -
7

SYNOPSIS

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

DESCRIPTION

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

PARAMETERS

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

STRUCTURES

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

RETURN VALUE

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

SEE ALSO

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)
Impressum