The FreeRADIUS server  $Id: 15bac2a4c627c01d1aa2047687b3418955ac7f00 $
Functions | Variables
rlm_radius.c File Reference

A RADIUS client library. More...

#include <freeradius-devel/io/application.h>
#include <freeradius-devel/server/modpriv.h>
#include <freeradius-devel/util/debug.h>
#include <freeradius-devel/util/dlist.h>
#include "rlm_radius.h"
+ Include dependency graph for rlm_radius.c:

Go to the source code of this file.

Functions

static int mod_bootstrap (module_inst_ctx_t const *mctx)
 
static int mod_load (void)
 
static unlang_action_t mod_process (rlm_rcode_t *p_result, module_ctx_t const *mctx, request_t *request)
 Send packets outbound. More...
 
static void mod_radius_signal (module_ctx_t const *mctx, request_t *request, fr_signal_t action)
 
static void mod_unload (void)
 
static void radius_fixups (rlm_radius_t const *inst, request_t *request)
 Do any RADIUS-layer fixups for proxying. More...
 
static int status_check_type_parse (TALLOC_CTX *ctx, void *out, UNUSED void *parent, CONF_ITEM *ci, conf_parser_t const *rule)
 
static int status_check_type_parse (UNUSED TALLOC_CTX *ctx, void *out, UNUSED void *parent, CONF_ITEM *ci, UNUSED conf_parser_t const *rule)
 Allow for Status-Server ping checks. More...
 
static int status_check_update_parse (TALLOC_CTX *ctx, void *out, UNUSED void *parent, CONF_ITEM *ci, conf_parser_t const *rule)
 
static int status_check_update_parse (TALLOC_CTX *ctx, void *out, UNUSED void *parent, CONF_ITEM *ci, UNUSED conf_parser_t const *rule)
 Allow the admin to set packet contents for Status-Server ping checks. More...
 
static int type_parse (TALLOC_CTX *ctx, void *out, UNUSED void *parent, CONF_ITEM *ci, conf_parser_t const *rule)
 
static int type_parse (UNUSED TALLOC_CTX *ctx, void *out, UNUSED void *parent, CONF_ITEM *ci, UNUSED conf_parser_t const *rule)
 Set which types of packets we can parse. More...
 

Variables

static conf_parser_t acct_config []
 
static fr_dict_attr_t const * attr_chap_challenge
 
static fr_dict_attr_t const * attr_chap_password
 
static fr_dict_attr_t const * attr_packet_type
 
static fr_dict_attr_t const * attr_proxy_state
 
static conf_parser_t auth_config []
 
static conf_parser_t coa_config []
 
static fr_dict_t const * dict_radius
 
static conf_parser_t disconnect_config []
 
static conf_parser_t const module_config []
 
module_rlm_t rlm_radius
 
fr_dict_autoload_t rlm_radius_dict []
 
fr_dict_attr_autoload_t rlm_radius_dict_attr []
 
static conf_parser_t const status_check_config []
 
static conf_parser_t const status_check_update_config []
 
static conf_parser_t status_config []
 
static conf_parser_t const type_interval_config [FR_RADIUS_CODE_MAX]
 

Detailed Description

A RADIUS client library.

Id
c04c443728feb3ce42241322e8fb2ea6125eee19

Definition in file rlm_radius.c.

Function Documentation

◆ mod_bootstrap()

static int mod_bootstrap ( module_inst_ctx_t const *  mctx)
static

Definition at line 455 of file rlm_radius.c.

+ Here is the call graph for this function:

◆ mod_load()

static int mod_load ( void  )
static

Definition at line 630 of file rlm_radius.c.

+ Here is the call graph for this function:

◆ mod_process()

static unlang_action_t mod_process ( rlm_rcode_t p_result,
module_ctx_t const *  mctx,
request_t request 
)
static

Send packets outbound.

Definition at line 390 of file rlm_radius.c.

+ Here is the call graph for this function:

◆ mod_radius_signal()

static void mod_radius_signal ( module_ctx_t const *  mctx,
request_t request,
fr_signal_t  action 
)
static

Definition at line 333 of file rlm_radius.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ mod_unload()

static void mod_unload ( void  )
static

Definition at line 639 of file rlm_radius.c.

+ Here is the call graph for this function:

◆ radius_fixups()

static void radius_fixups ( rlm_radius_t const *  inst,
request_t request 
)
static

Do any RADIUS-layer fixups for proxying.

Definition at line 355 of file rlm_radius.c.

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ status_check_type_parse() [1/2]

static int status_check_type_parse ( TALLOC_CTX *  ctx,
void *  out,
UNUSED void *  parent,
CONF_ITEM ci,
conf_parser_t const *  rule 
)
static

◆ status_check_type_parse() [2/2]

static int status_check_type_parse ( UNUSED TALLOC_CTX *  ctx,
void *  out,
UNUSED void *  parent,
CONF_ITEM ci,
UNUSED conf_parser_t const *  rule 
)
static

Allow for Status-Server ping checks.

Parameters
[in]ctxto allocate data in (instance of proto_radius).
[out]outWhere to write our parsed data.
[in]parentBase structure address.
[in]ciCONF_PAIR specifying the name of the type module.
[in]ruleunused.
Returns
  • 0 on success.
  • -1 on failure.

Definition at line 231 of file rlm_radius.c.

+ Here is the call graph for this function:

◆ status_check_update_parse() [1/2]

static int status_check_update_parse ( TALLOC_CTX *  ctx,
void *  out,
UNUSED void *  parent,
CONF_ITEM ci,
conf_parser_t const *  rule 
)
static

◆ status_check_update_parse() [2/2]

static int status_check_update_parse ( TALLOC_CTX *  ctx,
void *  out,
UNUSED void *  parent,
CONF_ITEM ci,
UNUSED conf_parser_t const *  rule 
)
static

Allow the admin to set packet contents for Status-Server ping checks.

Parameters
[in]ctxto allocate data in (instance of proto_radius).
[out]outWhere to write our parsed data
[in]parentBase structure address.
[in]ciCONF_SECTION specifying the things to update
[in]ruleunused.
Returns
  • 0 on success.
  • -1 on failure.

Definition at line 289 of file rlm_radius.c.

+ Here is the call graph for this function:

◆ type_parse() [1/2]

static int type_parse ( TALLOC_CTX *  ctx,
void *  out,
UNUSED void *  parent,
CONF_ITEM ci,
conf_parser_t const *  rule 
)
static

◆ type_parse() [2/2]

static int type_parse ( UNUSED TALLOC_CTX *  ctx,
void *  out,
UNUSED void *  parent,
CONF_ITEM ci,
UNUSED conf_parser_t const *  rule 
)
static

Set which types of packets we can parse.

Parameters
[in]ctxto allocate data in (instance of rlm_radius).
[out]outWhere to write the parsed data.
[in]parentBase structure address.
[in]ciCONF_PAIR specifying the name of the type module.
[in]ruleunused.
Returns
  • 0 on success.
  • -1 on failure.

Definition at line 171 of file rlm_radius.c.

+ Here is the call graph for this function:

Variable Documentation

◆ acct_config

conf_parser_t acct_config[]
static
Initial value:
= {
{ FR_CONF_OFFSET("initial_rtx_time", rlm_radius_t, retry[FR_RADIUS_CODE_ACCOUNTING_REQUEST].irt), .dflt = STRINGIFY(2) },
{ FR_CONF_OFFSET("max_rtx_time", rlm_radius_t, retry[FR_RADIUS_CODE_ACCOUNTING_REQUEST].mrt), .dflt = STRINGIFY(5) },
{ FR_CONF_OFFSET("max_rtx_count", rlm_radius_t, retry[FR_RADIUS_CODE_ACCOUNTING_REQUEST].mrc), .dflt = STRINGIFY(1) },
{ FR_CONF_OFFSET("max_rtx_duration", rlm_radius_t, retry[FR_RADIUS_CODE_ACCOUNTING_REQUEST].mrd), .dflt = STRINGIFY(30) },
}
#define STRINGIFY(x)
Definition: build.h:195
#define CONF_PARSER_TERMINATOR
Definition: cf_parse.h:626
#define FR_CONF_OFFSET(_name, _struct, _field)
conf_parser_t which parses a single CONF_PAIR, writing the result to a field in a struct
Definition: cf_parse.h:268
@ FR_RADIUS_CODE_ACCOUNTING_REQUEST
RFC2866 - Accounting-Request.
Definition: defs.h:36

Definition at line 65 of file rlm_radius.c.

◆ attr_chap_challenge

fr_dict_attr_t const* attr_chap_challenge
static

Definition at line 146 of file rlm_radius.c.

◆ attr_chap_password

fr_dict_attr_t const* attr_chap_password
static

Definition at line 147 of file rlm_radius.c.

◆ attr_packet_type

fr_dict_attr_t const* attr_packet_type
static

Definition at line 148 of file rlm_radius.c.

◆ attr_proxy_state

fr_dict_attr_t const* attr_proxy_state
static

Definition at line 149 of file rlm_radius.c.

◆ auth_config

conf_parser_t auth_config[]
static
Initial value:
= {
{ FR_CONF_OFFSET("initial_rtx_time", rlm_radius_t, retry[FR_RADIUS_CODE_ACCESS_REQUEST].irt), .dflt = STRINGIFY(2) },
{ FR_CONF_OFFSET("max_rtx_time", rlm_radius_t, retry[FR_RADIUS_CODE_ACCESS_REQUEST].mrt), .dflt = STRINGIFY(16) },
{ FR_CONF_OFFSET("max_rtx_count", rlm_radius_t, retry[FR_RADIUS_CODE_ACCESS_REQUEST].mrc), .dflt = STRINGIFY(5) },
{ FR_CONF_OFFSET("max_rtx_duration", rlm_radius_t, retry[FR_RADIUS_CODE_ACCESS_REQUEST].mrd), .dflt = STRINGIFY(30) },
}
@ FR_RADIUS_CODE_ACCESS_REQUEST
RFC2865 - Access-Request.
Definition: defs.h:33

Definition at line 57 of file rlm_radius.c.

◆ coa_config

conf_parser_t coa_config[]
static
Initial value:
= {
{ FR_CONF_OFFSET("initial_rtx_time", rlm_radius_t, retry[FR_RADIUS_CODE_COA_REQUEST].irt), .dflt = STRINGIFY(2) },
{ FR_CONF_OFFSET("max_rtx_time", rlm_radius_t, retry[FR_RADIUS_CODE_COA_REQUEST].mrt), .dflt = STRINGIFY(16) },
{ FR_CONF_OFFSET("max_rtx_count", rlm_radius_t, retry[FR_RADIUS_CODE_COA_REQUEST].mrc), .dflt = STRINGIFY(5) },
{ FR_CONF_OFFSET("max_rtx_duration", rlm_radius_t, retry[FR_RADIUS_CODE_COA_REQUEST].mrd), .dflt = STRINGIFY(30) },
}
@ FR_RADIUS_CODE_COA_REQUEST
RFC3575/RFC5176 - CoA-Request.
Definition: defs.h:49

Definition at line 81 of file rlm_radius.c.

◆ dict_radius

fr_dict_t const* dict_radius
static

Definition at line 138 of file rlm_radius.c.

◆ disconnect_config

conf_parser_t disconnect_config[]
static
Initial value:
= {
{ FR_CONF_OFFSET("initial_rtx_time", rlm_radius_t, retry[FR_RADIUS_CODE_DISCONNECT_REQUEST].irt), .dflt = STRINGIFY(2) },
{ FR_CONF_OFFSET("max_rtx_time", rlm_radius_t, retry[FR_RADIUS_CODE_DISCONNECT_REQUEST].mrt), .dflt = STRINGIFY(16) },
{ FR_CONF_OFFSET("max_rtx_count", rlm_radius_t, retry[FR_RADIUS_CODE_DISCONNECT_REQUEST].mrc), .dflt = STRINGIFY(5) },
{ FR_CONF_OFFSET("max_rtx_duration", rlm_radius_t, retry[FR_RADIUS_CODE_DISCONNECT_REQUEST].mrd), .dflt = STRINGIFY(30) },
}
@ FR_RADIUS_CODE_DISCONNECT_REQUEST
RFC3575/RFC5176 - Disconnect-Request.
Definition: defs.h:46

Definition at line 89 of file rlm_radius.c.

◆ module_config

conf_parser_t const module_config[]
static
Initial value:
= {
{ FR_CONF_OFFSET_TYPE_FLAGS("transport", FR_TYPE_VOID, 0, rlm_radius_t, io_submodule),
.func = type_parse },
{ FR_CONF_OFFSET("replicate", rlm_radius_t, replicate) },
{ FR_CONF_OFFSET("synchronous", rlm_radius_t, synchronous) },
{ FR_CONF_OFFSET("originate", rlm_radius_t, originate) },
{ FR_CONF_POINTER("status_check", 0, CONF_FLAG_SUBSECTION, NULL), .subcs = (void const *) status_check_config },
{ FR_CONF_OFFSET("max_attributes", rlm_radius_t, max_attributes), .dflt = STRINGIFY(RADIUS_MAX_ATTRIBUTES) },
{ FR_CONF_OFFSET("response_window", rlm_radius_t, response_window), .dflt = STRINGIFY(20) },
{ FR_CONF_OFFSET("zombie_period", rlm_radius_t, zombie_period), .dflt = STRINGIFY(40) },
{ FR_CONF_OFFSET("revive_interval", rlm_radius_t, revive_interval) },
}
#define FR_CONF_POINTER(_name, _type, _flags, _res_p)
conf_parser_t which parses a single CONF_PAIR producing a single global result
Definition: cf_parse.h:310
#define FR_CONF_OFFSET_FLAGS(_name, _flags, _struct, _field)
conf_parser_t which parses a single CONF_PAIR, writing the result to a field in a struct
Definition: cf_parse.h:256
#define FR_CONF_OFFSET_SUBSECTION(_name, _flags, _struct, _field, _subcs)
conf_parser_t which populates a sub-struct using a CONF_SECTION
Definition: cf_parse.h:297
@ CONF_FLAG_REQUIRED
Error out if no matching CONF_PAIR is found, and no dflt value is set.
Definition: cf_parse.h:406
@ CONF_FLAG_MULTI
CONF_PAIR can have multiple copies.
Definition: cf_parse.h:420
@ CONF_FLAG_NOT_EMPTY
CONF_PAIR is required to have a non zero length value.
Definition: cf_parse.h:421
@ CONF_FLAG_SUBSECTION
Instead of putting the information into a configuration structure, the configuration file routines MA...
Definition: cf_parse.h:400
#define FR_CONF_OFFSET_TYPE_FLAGS(_name, _type, _flags, _struct, _field)
conf_parser_t which parses a single CONF_PAIR, writing the result to a field in a struct
Definition: cf_parse.h:241
@ FR_TYPE_VOID
User data.
Definition: merged_model.c:127
int module_rlm_submodule_parse(TALLOC_CTX *ctx, void *out, void *parent, CONF_ITEM *ci, conf_parser_t const *rule)
Generic conf_parser_t func for loading drivers.
Definition: module_rlm.c:913
#define RADIUS_MAX_ATTRIBUTES
Definition: radius.h:39
static int type_parse(TALLOC_CTX *ctx, void *out, UNUSED void *parent, CONF_ITEM *ci, conf_parser_t const *rule)
static conf_parser_t const status_check_config[]
Definition: rlm_radius.c:38
conf_parser_t const fr_trunk_config[]
Config parser definitions to populate a fr_trunk_conf_t.
Definition: trunk.c:306

Definition at line 101 of file rlm_radius.c.

◆ rlm_radius

module_rlm_t rlm_radius
Initial value:
= {
.common = {
.name = "radius",
.inst_size = sizeof(rlm_radius_t),
.onload = mod_load,
.unload = mod_unload,
.bootstrap = mod_bootstrap,
},
.method_names = (module_method_name_t[]){
{ .name1 = CF_IDENT_ANY, .name2 = CF_IDENT_ANY, .method = mod_process },
},
}
#define CF_IDENT_ANY
Definition: cf_util.h:78
#define MODULE_MAGIC_INIT
Stop people using different module/library/server versions together.
Definition: dl_module.h:65
Specifies a module method identifier.
Definition: module_method.c:36
static const conf_parser_t config[]
Definition: base.c:188
static int mod_load(void)
Definition: rlm_radius.c:630
static unlang_action_t mod_process(rlm_rcode_t *p_result, module_ctx_t const *mctx, request_t *request)
Send packets outbound.
Definition: rlm_radius.c:390
static int mod_bootstrap(module_inst_ctx_t const *mctx)
Definition: rlm_radius.c:455
static void mod_unload(void)
Definition: rlm_radius.c:639
static conf_parser_t const module_config[]
Definition: rlm_radius.c:101
struct rlm_radius_s rlm_radius_t
Definition: rlm_radius.h:36
@ MODULE_TYPE_RESUMABLE
does yield / resume
Definition: module.h:52
@ MODULE_TYPE_THREAD_SAFE
Module is threadsafe.
Definition: module.h:49
#define MODULE_NAME_TERMINATOR
Definition: module.h:135

Definition at line 654 of file rlm_radius.c.

◆ rlm_radius_dict

fr_dict_autoload_t rlm_radius_dict
Initial value:
= {
{ .out = &dict_radius, .proto = "radius" },
{ NULL }
}
static fr_dict_t const * dict_radius
Definition: rlm_radius.c:138

Definition at line 141 of file rlm_radius.c.

◆ rlm_radius_dict_attr

fr_dict_attr_autoload_t rlm_radius_dict_attr
Initial value:
= {
{ .out = &attr_chap_challenge, .name = "CHAP-Challenge", .type = FR_TYPE_OCTETS, .dict = &dict_radius},
{ .out = &attr_chap_password, .name = "CHAP-Password", .type = FR_TYPE_OCTETS, .dict = &dict_radius},
{ .out = &attr_packet_type, .name = "Packet-Type", .type = FR_TYPE_UINT32, .dict = &dict_radius },
{ .out = &attr_proxy_state, .name = "Proxy-State", .type = FR_TYPE_OCTETS, .dict = &dict_radius},
{ NULL }
}
@ FR_TYPE_UINT32
32 Bit unsigned integer.
Definition: merged_model.c:99
@ FR_TYPE_OCTETS
Raw octets.
Definition: merged_model.c:84
static fr_dict_attr_t const * attr_packet_type
Definition: rlm_radius.c:148
static fr_dict_attr_t const * attr_chap_password
Definition: rlm_radius.c:147
static fr_dict_attr_t const * attr_chap_challenge
Definition: rlm_radius.c:146
static fr_dict_attr_t const * attr_proxy_state
Definition: rlm_radius.c:149

Definition at line 152 of file rlm_radius.c.

◆ status_check_config

conf_parser_t const status_check_config[]
static
Initial value:
= {
{ FR_CONF_OFFSET_TYPE_FLAGS("type", FR_TYPE_VOID, 0, rlm_radius_t, status_check),
}
static int status_check_type_parse(TALLOC_CTX *ctx, void *out, UNUSED void *parent, CONF_ITEM *ci, conf_parser_t const *rule)

Definition at line 38 of file rlm_radius.c.

◆ status_check_update_config

conf_parser_t const status_check_update_config[]
static
Initial value:
= {
.name2 = CF_IDENT_ANY,
{ FR_CONF_OFFSET("num_answers_to_alive", rlm_radius_t, num_answers_to_alive), .dflt = STRINGIFY(3) },
}
static int status_check_update_parse(TALLOC_CTX *ctx, void *out, UNUSED void *parent, CONF_ITEM *ci, conf_parser_t const *rule)

Definition at line 45 of file rlm_radius.c.

◆ status_config

conf_parser_t status_config[]
static
Initial value:
= {
{ FR_CONF_OFFSET("initial_rtx_time", rlm_radius_t, retry[FR_RADIUS_CODE_STATUS_SERVER].irt), .dflt = STRINGIFY(2) },
{ FR_CONF_OFFSET("max_rtx_time", rlm_radius_t, retry[FR_RADIUS_CODE_STATUS_SERVER].mrt), .dflt = STRINGIFY(5) },
{ FR_CONF_OFFSET("max_rtx_count", rlm_radius_t, retry[FR_RADIUS_CODE_STATUS_SERVER].mrc), .dflt = STRINGIFY(5) },
{ FR_CONF_OFFSET("max_rtx_duration", rlm_radius_t, retry[FR_RADIUS_CODE_STATUS_SERVER].mrd), .dflt = STRINGIFY(30) },
}
@ FR_RADIUS_CODE_STATUS_SERVER
RFC2865/RFC5997 - Status Server (request)
Definition: defs.h:44

Definition at line 73 of file rlm_radius.c.

◆ type_interval_config

conf_parser_t const type_interval_config[FR_RADIUS_CODE_MAX]
static
Initial value:
= {
[FR_RADIUS_CODE_ACCESS_REQUEST] = { FR_CONF_POINTER("Access-Request", 0, CONF_FLAG_SUBSECTION, NULL), .subcs = (void const *) auth_config },
[FR_RADIUS_CODE_ACCOUNTING_REQUEST] = { FR_CONF_POINTER("Accounting-Request", 0, CONF_FLAG_SUBSECTION, NULL), .subcs = (void const *) acct_config },
[FR_RADIUS_CODE_STATUS_SERVER] = { FR_CONF_POINTER("Status-Server", 0, CONF_FLAG_SUBSECTION, NULL), .subcs = (void const *) status_config },
[FR_RADIUS_CODE_COA_REQUEST] = { FR_CONF_POINTER("CoA-Request", 0, CONF_FLAG_SUBSECTION, NULL), .subcs = (void const *) coa_config },
[FR_RADIUS_CODE_DISCONNECT_REQUEST] = { FR_CONF_POINTER("Disconnect-Request", 0, CONF_FLAG_SUBSECTION, NULL), .subcs = (void const *) disconnect_config },
}
static conf_parser_t coa_config[]
Definition: rlm_radius.c:81
static conf_parser_t disconnect_config[]
Definition: rlm_radius.c:89
static conf_parser_t status_config[]
Definition: rlm_radius.c:73
static conf_parser_t auth_config[]
Definition: rlm_radius.c:57
static conf_parser_t acct_config[]
Definition: rlm_radius.c:65

Definition at line 129 of file rlm_radius.c.