The FreeRADIUS server $Id: 15bac2a4c627c01d1aa2047687b3418955ac7f00 $
|
Code to apply fctx and finalisation steps to a dictionary. More...
#include <freeradius-devel/util/dict.h>
#include <freeradius-devel/util/file.h>
#include <freeradius-devel/util/sbuff.h>
#include <freeradius-devel/util/strerror.h>
#include <freeradius-devel/util/types.h>
#include <freeradius-devel/util/talloc.h>
#include <freeradius-devel/util/value.h>
#include "dict_fixup_priv.h"
Go to the source code of this file.
Data Structures | |
struct | dict_fixup_alias_t |
Add an enumeration value to an attribute that wasn't defined at the time the value was parsed. More... | |
struct | dict_fixup_clone_t |
Clone operation from one tree node to another. More... | |
struct | dict_fixup_common_t |
Common fields for every fixup structure. More... | |
struct | dict_fixup_enumv_t |
Add an enumeration value to an attribute that wasn't defined at the time the value was parsed. More... | |
struct | dict_fixup_group_t |
Resolve a group reference. More... | |
struct | dict_fixup_hash_t |
Dictionary attribute namespaces need their hash tables finalised. More... | |
struct | dict_fixup_vsa_t |
Run fixup callbacks for a VSA. More... | |
Macros | |
#define | APPLY_FIXUP(_fctx, _list, _func, _type) |
Functions | |
static int | _dict_attr_fixup_hash_tables (fr_dict_attr_t const *da, UNUSED void *uctx) |
Fixup all hash tables in the dictionary so they're suitable for threaded access. | |
static int | dict_fixup_alias_apply (UNUSED dict_fixup_ctx_t *fctx, dict_fixup_alias_t *fixup) |
int | dict_fixup_alias_enqueue (dict_fixup_ctx_t *fctx, char const *filename, int line, fr_dict_attr_t *alias_parent, char const *alias, fr_dict_attr_t *ref_parent, char const *ref) |
Resolve a group reference. | |
int | dict_fixup_apply (dict_fixup_ctx_t *fctx) |
Apply all outstanding fixes to a set of dictionaries. | |
int | dict_fixup_clone (fr_dict_attr_t **dst_p, fr_dict_attr_t const *src) |
Clone a dictionary attribute from a ref. | |
static int | dict_fixup_clone_apply (UNUSED dict_fixup_ctx_t *fctx, dict_fixup_clone_t *fixup) |
Clone one are of a tree into another. | |
int | dict_fixup_clone_enqueue (dict_fixup_ctx_t *fctx, fr_dict_attr_t *da, char const *ref) |
Clone one area of a tree into another. | |
static int | dict_fixup_clone_enum_apply (UNUSED dict_fixup_ctx_t *fctx, dict_fixup_clone_t *fixup) |
Clone one are of a tree into another. | |
int | dict_fixup_clone_enum_enqueue (dict_fixup_ctx_t *fctx, fr_dict_attr_t *da, char const *ref) |
Clone enumeration values from one attribute to another. | |
static int | dict_fixup_common (fr_dlist_head_t *fixup_list, dict_fixup_common_t *common) |
Initialise common fields in fixup struct, and add it to a fixup list. | |
static int | dict_fixup_enumv_apply (UNUSED dict_fixup_ctx_t *fctx, dict_fixup_enumv_t *fixup) |
Add a previously defined enumeration value to an existing attribute. | |
int | dict_fixup_enumv_enqueue (dict_fixup_ctx_t *fctx, char const *filename, int line, char const *attr, size_t attr_len, char const *name, size_t name_len, char const *value, size_t value_len, fr_dict_attr_t const *parent) |
Add an enumeration value to an attribute which has not yet been defined. | |
static int | dict_fixup_group_apply (UNUSED dict_fixup_ctx_t *fctx, dict_fixup_group_t *fixup) |
Resolve a group reference. | |
int | dict_fixup_group_enqueue (dict_fixup_ctx_t *fctx, fr_dict_attr_t *da, char const *ref) |
Resolve a group reference. | |
int | dict_fixup_init (TALLOC_CTX *ctx, dict_fixup_ctx_t *fctx) |
Initialise a fixup ctx. | |
static int | dict_fixup_vsa_apply (UNUSED dict_fixup_ctx_t *fctx, dict_fixup_vsa_t *fixup) |
Run VSA fixups. | |
int | dict_fixup_vsa_enqueue (dict_fixup_ctx_t *fctx, fr_dict_attr_t *da) |
Push a fixup for a VSA. | |
void | dict_hash_tables_finalise (fr_dict_t *dict) |
Walk a dictionary finalising the hash tables in all attributes with a distinct namespace. | |
fr_dict_attr_t const * | dict_protocol_reference (fr_dict_attr_t const *rel, char const *ref, bool absolute_root) |
Resolve a ref= or copy= value to a dictionary. | |
Code to apply fctx and finalisation steps to a dictionary.
Definition in file dict_fixup.c.
struct dict_fixup_alias_t |
Add an enumeration value to an attribute that wasn't defined at the time the value was parsed.
Definition at line 46 of file dict_fixup.c.
Data Fields | ||
---|---|---|
char * | alias | we need to create. |
fr_dict_attr_t * | alias_parent | Where to add the alias. |
dict_fixup_common_t | common | Common fields. |
char * | filename | where the line being fixed up. |
int | line | ditto. |
char * | ref | what the alias references. |
fr_dict_attr_t * | ref_parent | Parent attribute to resolve the 'attribute' string in. |
struct dict_fixup_clone_t |
Clone operation from one tree node to another.
Definition at line 89 of file dict_fixup.c.
Data Fields | ||
---|---|---|
dict_fixup_common_t | common | Common fields. |
fr_dict_attr_t * | da | to populate with cloned information. |
char * | ref | the target attribute to clone |
struct dict_fixup_common_t |
Common fields for every fixup structure.
Definition at line 39 of file dict_fixup.c.
Data Fields | ||
---|---|---|
fr_dlist_t | entry | Entry in linked list of fctx. |
struct dict_fixup_enumv_t |
Add an enumeration value to an attribute that wasn't defined at the time the value was parsed.
Definition at line 62 of file dict_fixup.c.
Data Fields | ||
---|---|---|
char * | attribute | we couldn't find (and will need to resolve later). |
dict_fixup_common_t | common | Common fields. |
char * | filename | where the line being fixed up. |
int | line | ditto. |
char * | name | Raw enum name. |
fr_dict_attr_t const * | parent | Parent attribute to resolve the 'attribute' string in. |
char * | value |
Raw enum value. We can't do anything with this until we know the attribute type, which we only find out later. |
struct dict_fixup_group_t |
Resolve a group reference.
Definition at line 79 of file dict_fixup.c.
Data Fields | ||
---|---|---|
dict_fixup_common_t | common | Common fields. |
fr_dict_attr_t * | da | FR_TYPE_GROUP to fix. |
char * | ref | the reference name |
struct dict_fixup_hash_t |
Dictionary attribute namespaces need their hash tables finalised.
Definition at line 108 of file dict_fixup.c.
Data Fields | ||
---|---|---|
dict_fixup_common_t | common | Common fields. |
fr_hash_table_t * | hash | We need to finalise. |
struct dict_fixup_vsa_t |
Run fixup callbacks for a VSA.
Definition at line 99 of file dict_fixup.c.
Data Fields | ||
---|---|---|
dict_fixup_common_t | common | Common fields. |
fr_dict_attr_t * | da | FR_TYPE_VSA to fix. |
#define APPLY_FIXUP | ( | _fctx, | |
_list, | |||
_func, | |||
_type | |||
) |
|
static |
Fixup all hash tables in the dictionary so they're suitable for threaded access.
Definition at line 876 of file dict_fixup.c.
|
inlinestatic |
Definition at line 791 of file dict_fixup.c.
int dict_fixup_alias_enqueue | ( | dict_fixup_ctx_t * | fctx, |
char const * | filename, | ||
int | line, | ||
fr_dict_attr_t * | alias_parent, | ||
char const * | alias, | ||
fr_dict_attr_t * | ref_parent, | ||
char const * | ref | ||
) |
Resolve a group reference.
This is required as the reference may point to another dictionary which hasn't been loaded yet.
[in] | fctx | Holds current dictionary parsing information. |
[in] | filename | this fixup relates to. |
[in] | line | this fixup relates to. |
[in] | alias_parent | where to add the alias. |
[in] | alias | alias to add. |
[in] | ref_parent | attribute that should contain the reference. |
[in] | ref | OID string representing what the group references. |
Definition at line 765 of file dict_fixup.c.
int dict_fixup_apply | ( | dict_fixup_ctx_t * | fctx | ) |
Apply all outstanding fixes to a set of dictionaries.
Definition at line 835 of file dict_fixup.c.
int dict_fixup_clone | ( | fr_dict_attr_t ** | dst_p, |
fr_dict_attr_t const * | src | ||
) |
Clone a dictionary attribute from a ref.
[in] | dst_p | will either be inserted directly, with fields from the clone, or will be cloned, and then inserted. In this case the original dst da will be freed and the new cloned attribute will be written back to dst_p. |
[in] | src | to clone. |
Definition at line 427 of file dict_fixup.c.
|
inlinestatic |
Clone one are of a tree into another.
[in] | fctx | Holds current dictionary parsing information. |
[in] | fixup | Containing source/destination of the clone. |
Definition at line 577 of file dict_fixup.c.
int dict_fixup_clone_enqueue | ( | dict_fixup_ctx_t * | fctx, |
fr_dict_attr_t * | da, | ||
char const * | ref | ||
) |
Clone one area of a tree into another.
These must be processed later to ensure that we've finished building an attribute by the time it has been cloned.
[in] | fctx | Holds current dictionary parsing information. |
[in] | da | The group dictionary attribute. |
[in] | ref | OID string representing what the group references.. |
Definition at line 394 of file dict_fixup.c.
|
inlinestatic |
Clone one are of a tree into another.
[in] | fctx | Holds current dictionary parsing information. |
[in] | fixup | Containing source/destination of the clone. |
Definition at line 634 of file dict_fixup.c.
int dict_fixup_clone_enum_enqueue | ( | dict_fixup_ctx_t * | fctx, |
fr_dict_attr_t * | da, | ||
char const * | ref | ||
) |
Clone enumeration values from one attribute to another.
These must be processed later to ensure that we've finished building an attribute by the time it has been cloned.
[in] | fctx | Holds current dictionary parsing information. |
[in] | da | The group dictionary attribute. |
[in] | ref | OID string representing what the group references.. |
Definition at line 603 of file dict_fixup.c.
|
inlinestatic |
Initialise common fields in fixup struct, and add it to a fixup list.
[in] | fixup_list | to add fixup to. |
[in] | common | common header to populate. |
Definition at line 122 of file dict_fixup.c.
|
inlinestatic |
Add a previously defined enumeration value to an existing attribute.
[in] | fctx | Holds current dictionary parsing information. |
[in] | fixup | Hash table to fill. |
Definition at line 283 of file dict_fixup.c.
int dict_fixup_enumv_enqueue | ( | dict_fixup_ctx_t * | fctx, |
char const * | filename, | ||
int | line, | ||
char const * | attr, | ||
size_t | attr_len, | ||
char const * | name, | ||
size_t | name_len, | ||
char const * | value, | ||
size_t | value_len, | ||
fr_dict_attr_t const * | parent | ||
) |
Add an enumeration value to an attribute which has not yet been defined.
[in] | fctx | Holds current dictionary parsing information. |
[in] | filename | this fixup relates to. |
[in] | line | this fixup relates to. |
[in] | attr | The OID string pointing to the attribute to add the enumeration value to. |
[in] | attr_len | The length of the attr string. |
[in] | name | The name of the enumv. |
[in] | name_len | Length of the name string. |
[in] | value | Value string. This is kept as a string until we know what type we want to transform it into. |
[in] | value_len | Length of the value string. |
[in] | parent | of this attribute. |
Definition at line 246 of file dict_fixup.c.
|
inlinestatic |
Resolve a group reference.
[in] | fctx | Holds current dictionary parsing information. |
[in] | fixup | Hash table to fill. |
Definition at line 355 of file dict_fixup.c.
int dict_fixup_group_enqueue | ( | dict_fixup_ctx_t * | fctx, |
fr_dict_attr_t * | da, | ||
char const * | ref | ||
) |
Resolve a group reference.
This is required as the reference may point to another dictionary which hasn't been loaded yet.
[in] | fctx | Holds current dictionary parsing information. |
[in] | da | The group dictionary attribute. |
[in] | ref | OID string representing what the group references. |
Definition at line 330 of file dict_fixup.c.
int dict_fixup_init | ( | TALLOC_CTX * | ctx, |
dict_fixup_ctx_t * | fctx | ||
) |
Initialise a fixup ctx.
[in] | ctx | to allocate the fixup pool in. |
[in] | fctx | to initialise. |
Definition at line 816 of file dict_fixup.c.
|
inlinestatic |
Run VSA fixups.
[in] | fctx | Holds current dictionary parsing information. |
[in] | fixup | entry for fixup |
Definition at line 729 of file dict_fixup.c.
int dict_fixup_vsa_enqueue | ( | dict_fixup_ctx_t * | fctx, |
fr_dict_attr_t * | da | ||
) |
Push a fixup for a VSA.
This is required so that we can define VENDORs for all VSAs, even if the dictionary doesn't contain VENDOR children for that VSA. This fixup means that we can define VENDORs elsewhere, and then use them in all VSA definitions. It means that we don't have to do these lookups at run-time.
[in] | fctx | Holds current dictionary parsing information. |
[in] | da | The group dictionary attribute. |
Definition at line 705 of file dict_fixup.c.
void dict_hash_tables_finalise | ( | fr_dict_t * | dict | ) |
Walk a dictionary finalising the hash tables in all attributes with a distinct namespace.
[in] | dict | to finalise namespaces for. |
Definition at line 902 of file dict_fixup.c.
fr_dict_attr_t const * dict_protocol_reference | ( | fr_dict_attr_t const * | rel, |
char const * | ref, | ||
bool | absolute_root | ||
) |
Resolve a ref= or copy= value to a dictionary.
Resolve a reference string to a dictionary attribute
[in] | rel | Relative attribute to resolve from. |
[in] | ref | Reference string. |
[in] | absolute_root | If true, and there is no '.' prefix, searching will begin from the root of the dictionary, else we pretend there was a '.' and search from rel. |
Definition at line 139 of file dict_fixup.c.