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

NAME

6       rc_avpair_assign -
7

SYNOPSIS

9       #include <radcli/radcli.h>
10
11       int rc_avpair_assign(
12           VALUE_PAIR  *vp,
13           void const  *pval,
14           int          len
15       );
16

DESCRIPTION

18       Assigns the given value to an attribute-value pair
19
20       If  the value is of type PW_TYPE_STRING it must either be a null termi‐
21       nated string with len set to -1, or raw data with length properly  set.
22       For  PW_TYPE_DATE, PW_TYPE_INTEGER, and PW_TYPE_IPADDR an uint32_t num‐
23       ber should be set at pval. For IPv4 addresses it should be in host byte
24       order.
25
26       For  PW_TYPE_IPV6ADDR  type a 16-byte long address is expected, and for
27       PW_TYPE_IPV6PREFIX the rfc3162 prefix format is expected.  Simply  that
28       is  a  zero  byte, a byte with the value of prefix (e.g., 112), and the
29       remaining bytes are the IPv6 address.
30

PARAMETERS

32       vp     a pointer to a VALUE_PAIR structure.
33
34
35       pval   the value (e.g., the actual username).
36
37
38       len    the length of pval, or -1 if to calculate (in case of strings).
39
40

STRUCTURES

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

RETURN VALUE

56       0 on success or -1 on failure.
57

SEE ALSO

59       radcli.h(3), rc_aaa(3), rc_aaa_ctx(3), rc_aaa_ctx_free(3),
60       rc_aaa_ctx_get_secret(3), rc_aaa_ctx_get_vector(3),
61       rc_aaa_ctx_server(3), rc_acct(3), rc_acct_proxy(3), rc_add_config(3),
62       rc_apply_config(3), rc_auth(3), rc_auth_proxy(3), rc_avpair_add(3),
63       rc_avpair_assign(3), rc_avpair_copy(3), rc_avpair_free(3),
64       rc_avpair_gen(3), rc_avpair_get(3), rc_avpair_get_attr(3),
65       rc_avpair_get_in6(3), rc_avpair_get_raw(3), rc_avpair_get_uint32(3),
66       rc_avpair_insert(3), rc_avpair_log(3), rc_avpair_new(3),
67       rc_avpair_next(3), rc_avpair_parse(3), rc_avpair_remove(3),
68       rc_avpair_tostr(3), rc_buildreq(3), rc_check(3), rc_check_tls(3),
69       rc_conf_int(3), rc_conf_srv(3), rc_conf_str(3), rc_config_free(3),
70       rc_config_init(3), rc_destroy(3), rc_dict_addattr(3),
71       rc_dict_addval(3), rc_dict_addvend(3), rc_dict_findattr(3),
72       rc_dict_findval(3), rc_dict_findvend(3), rc_dict_free(3),
73       rc_dict_getattr(3), rc_dict_getval(3), rc_dict_getvend(3),
74       rc_find_server_addr(3), rc_get_socket_type(3), rc_get_srcaddr(3),
75       rc_getport(3), rc_mksid(3), rc_new(3), rc_openlog(3),
76       rc_own_hostname(3), rc_read_config(3), rc_read_dictionary(3),
77       rc_read_dictionary_from_buffer(3), rc_send_server(3), rc_setdebug(3),
78       rc_test_config(3), rc_tls_fd(3)
79
80
81
82radcli                            2023-01-29               rc_avpair_assign(3)
Impressum