Provided by: libradcli-dev_1.2.11-1build1_amd64 bug

NAME

       rc_aaa_ctx_server -

SYNOPSIS

       #include <radcli/radcli.h>

       int rc_aaa_ctx_server(
           rc_handle        *rh,
           RC_AAA_CTX      **ctx,
           SERVER           *aaaserver,
           rc_type           type,
           uint32_t          client_port,
           VALUE_PAIR       *send,
           VALUE_PAIR      **received,
           char             *msg,
           int               add_nas_port,
           rc_standard_codes request_type
       );

DESCRIPTION

       Builds  an  authentication/accounting request for port id client_port with the value_pairs
       send and submits it to a specified server. This function keeps its state in  ctx  after  a
       successful operation. It can be deallocated using rc_aaa_ctx_free().

PARAMETERS

       rh     a handle to parsed configuration.

       ctx    if non-NULL it will contain the context of the request; Its initial value should be
              NULL and it must be released using rc_aaa_ctx_free().

       aaaserver
              a non-NULL SERVER to send the message to.

       type

       client_port
              the client port number to use (may be zero to use any available).

       send   a VALUE_PAIR array of values (e.g., PW_USER_NAME).

       received
              an allocated array of received values.

       msg    must be an array of PW_MAX_MSG_SIZE or NULL; will contain the concatenation of  any
              PW_REPLY_MESSAGE received.

       add_nas_port
              if non-zero it will include PW_NAS_PORT in sent pairs.

       request_type
              one of standard RADIUS codes (e.g., PW_ACCESS_REQUEST).

STRUCTURES


       this  structure  directly, it is included for backwards compatibility only. Several of its
       fields have been deprecated.

              struct server {
                int      max;
                char    *name;
                uint16_t port;
                char    *secret;
                double   deadtime_ends; // unused
              };

       this structure directly. Use the rc_avpair_get_ functions.

              struct rc_value_pair {
                char                   name;      // attribute name if known.
                unsigned               attribute; // attribute numeric value of type rc_attr_id.
                rc_attr_type           type;      // attribute type.
                uint32_t               lvalue;    // attribute value if type is PW_TYPE_INTEGER, PW_TYPE_DATE or PW_TYPE_IPADDR.
                char                   strvalue;  // contains attribute value in other cases.
                struct rc_value_pair  *next;
                char                   pad;       // unused pad
              };

       this structure directly. Use the rc_avpair_get_ functions.

              struct rc_value_pair {
                char                   name;      // attribute name if known.
                unsigned               attribute; // attribute numeric value of type rc_attr_id.
                rc_attr_type           type;      // attribute type.
                uint32_t               lvalue;    // attribute value if type is PW_TYPE_INTEGER, PW_TYPE_DATE or PW_TYPE_IPADDR.
                char                   strvalue;  // contains attribute value in other cases.
                struct rc_value_pair  *next;
                char                   pad;       // unused pad
              };

RETURN VALUE

       received value_pairs in received, messages from  the  server  in  msg  and  OK_RC  (0)  on
       success,  CHALLENGE_RC  (3)  on  Access-Challenge  received, negative on failure as return
       value.

SEE ALSO

       radcli.h(3), rc_aaa(3), rc_aaa_ctx(3), rc_aaa_ctx_free(3), rc_aaa_ctx_get_secret(3),
       rc_aaa_ctx_get_vector(3), rc_aaa_ctx_server(3), rc_acct(3), rc_acct_proxy(3),
       rc_add_config(3), rc_apply_config(3), rc_auth(3), rc_auth_proxy(3), rc_avpair_add(3),
       rc_avpair_assign(3), rc_avpair_copy(3), rc_avpair_free(3), rc_avpair_gen(3),
       rc_avpair_get(3), rc_avpair_get_attr(3), rc_avpair_get_in6(3), rc_avpair_get_raw(3),
       rc_avpair_get_uint32(3), rc_avpair_insert(3), rc_avpair_log(3), rc_avpair_new(3),
       rc_avpair_next(3), rc_avpair_parse(3), rc_avpair_remove(3), rc_avpair_tostr(3),
       rc_buildreq(3), rc_check(3), rc_check_tls(3), rc_conf_int(3), rc_conf_srv(3),
       rc_conf_str(3), rc_config_free(3), rc_config_init(3), rc_destroy(3), rc_dict_findattr(3),
       rc_dict_findval(3), rc_dict_findvend(3), rc_dict_free(3), rc_dict_getattr(3),
       rc_dict_getval(3), rc_dict_getvend(3), rc_find_server_addr(3), rc_get_socket_type(3),
       rc_get_srcaddr(3), rc_getport(3), rc_mksid(3), rc_new(3), rc_openlog(3),
       rc_own_hostname(3), rc_read_config(3), rc_read_dictionary(3),
       rc_read_dictionary_from_buffer(3), rc_send_server(3), rc_setdebug(3), rc_test_config(3),
       rc_tls_fd(3), rc_aaa_ctx_free()