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

NAME

6       rc_auth_proxy -
7

SYNOPSIS

9       #include <radcli/radcli.h>
10
11       int rc_auth_proxy(
12           rc_handle    *rh,
13           VALUE_PAIR   *send,
14           VALUE_PAIR  **received,
15           char         *msg
16       );
17

DESCRIPTION

19       Builds an authentication request for proxying
20
21       Builds  an authentication request with the value_pairs send and submits
22       it to a server. Works for a proxy; does not add IP  address,  and  does
23       does not rely on config file.
24

PARAMETERS

26       rh     a handle to parsed configuration.
27
28
29       send   a VALUE_PAIR array of values (e.g., PW_USER_NAME).
30
31
32       received
33              an allocated array of received values.
34
35
36       msg    must  be  an  array of PW_MAX_MSG_SIZE or NULL; will contain the
37              concatenation of any PW_REPLY_MESSAGE received.
38
39

STRUCTURES

41
42       Avoid using this structure directly. Use the rc_avpair_get_ functions.
43
44              struct rc_value_pair {
45                char                   name[RC_NAME_LENGTH+1];      // attribute name if known.
46                uint64_t               attribute; // attribute numeric value of type rc_attr_id including vendor; use VENDOR() and ATTRID() to separate.
47                rc_attr_type           type;      // attribute type.
48                uint32_t               lvalue;    // attribute value if type is PW_TYPE_INTEGER, PW_TYPE_DATE or PW_TYPE_IPADDR.
49                char                   strvalue[AUTH_STRING_LEN+1];  // contains attribute value in other cases.
50                struct rc_value_pair  *next;
51                char                   pad[32];       // unused pad
52              };
53
54
55       Avoid using this structure directly. Use the rc_avpair_get_ functions.
56
57              struct rc_value_pair {
58                char                   name[RC_NAME_LENGTH+1];      // attribute name if known.
59                uint64_t               attribute; // attribute numeric value of type rc_attr_id including vendor; use VENDOR() and ATTRID() to separate.
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[AUTH_STRING_LEN+1];  // contains attribute value in other cases.
63                struct rc_value_pair  *next;
64                char                   pad[32];       // unused pad
65              };
66

RETURN VALUE

68       received value_pairs in received, messages from the server in  msg  (if
69       non-NULL)  and  OK_RC  (0) on success, CHALLENGE_RC (3) on Access-Chal‐
70       lenge received, negative on failure as return value.
71

SEE ALSO

73       radcli.h(3), rc_aaa(3), rc_aaa_ctx(3), rc_aaa_ctx_free(3),
74       rc_aaa_ctx_get_secret(3), rc_aaa_ctx_get_vector(3),
75       rc_aaa_ctx_server(3), rc_acct(3), rc_acct_proxy(3), rc_add_config(3),
76       rc_apply_config(3), rc_auth(3), rc_auth_proxy(3), rc_avpair_add(3),
77       rc_avpair_assign(3), rc_avpair_copy(3), rc_avpair_free(3),
78       rc_avpair_gen(3), rc_avpair_get(3), rc_avpair_get_attr(3),
79       rc_avpair_get_in6(3), rc_avpair_get_raw(3), rc_avpair_get_uint32(3),
80       rc_avpair_insert(3), rc_avpair_log(3), rc_avpair_new(3),
81       rc_avpair_next(3), rc_avpair_parse(3), rc_avpair_remove(3),
82       rc_avpair_tostr(3), rc_buildreq(3), rc_check(3), rc_check_tls(3),
83       rc_conf_int(3), rc_conf_srv(3), rc_conf_str(3), rc_config_free(3),
84       rc_config_init(3), rc_destroy(3), rc_dict_addattr(3),
85       rc_dict_addval(3), rc_dict_addvend(3), rc_dict_findattr(3),
86       rc_dict_findval(3), rc_dict_findvend(3), rc_dict_free(3),
87       rc_dict_getattr(3), rc_dict_getval(3), rc_dict_getvend(3),
88       rc_find_server_addr(3), rc_get_socket_type(3), rc_get_srcaddr(3),
89       rc_getport(3), rc_mksid(3), rc_new(3), rc_openlog(3),
90       rc_own_hostname(3), rc_read_config(3), rc_read_dictionary(3),
91       rc_read_dictionary_from_buffer(3), rc_send_server(3), rc_setdebug(3),
92       rc_test_config(3), rc_tls_fd(3)
93
94
95
96radcli                            2023-01-29                  rc_auth_proxy(3)
Impressum