The FreeRADIUS server $Id: 15bac2a4c627c01d1aa2047687b3418955ac7f00 $
Loading...
Searching...
No Matches
cf_util.h
Go to the documentation of this file.
1#pragma once
2/*
3 * This program is free software; you can redistribute it and/or modify
4 * it under the terms of the GNU General Public License as published by
5 * the Free Software Foundation; either version 2 of the License, or
6 * (at your option) any later version.
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program; if not, write to the Free Software
15 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
16 */
17
18/**
19 * $Id: da4a47ea5a14dea7badf696056e7da0ae1b1bc41 $
20 *
21 * @file lib/server/cf_util.h
22 * @brief API to create and manipulate internal format configurations.
23 *
24 * @copyright 2017 The FreeRADIUS server project
25 */
26RCSIDH(conf_file_h, "$Id: da4a47ea5a14dea7badf696056e7da0ae1b1bc41 $")
27
28#ifdef __cplusplus
29extern "C" {
30#endif
31
32/*
33 * Export the minimum amount of information about these structs
34 */
35typedef struct cf_item CONF_ITEM; //!< Generic configuration element, extended to become
36 ///< a #CONF_PAIR, a #CONF_SECTION or #CONF_DATA.
37typedef struct cf_section CONF_SECTION; //!< #CONF_ITEM used to group multiple #CONF_PAIR and #CONF_SECTION, together.
38typedef struct cf_pair CONF_PAIR; //!< #CONF_ITEM with an attribute, an operator and a value.
39typedef struct cf_data CONF_DATA; //!< #CONF_ITEM used to associate arbitrary data
40 ///< with a #CONF_PAIR or #CONF_SECTION.
41
42#include <stddef.h>
43#include <stdint.h>
44#include <stdbool.h>
45#include <unistd.h>
46#include <sys/time.h>
47
48#include <freeradius-devel/util/rb.h>
49#include <freeradius-devel/util/table.h>
50#include <freeradius-devel/util/token.h>
51#include <freeradius-devel/util/log.h>
52
53#define FR_TIMEVAL_TO_MS(_x) (((_x)->tv_usec / 1000) + ((_x)->tv_sec * (uint64_t)1000))
54#define FR_TIMESPEC_TO_MS(_x) (((_x)->tv_usec / 1000000) + ((_x)->tv_sec * (uint64_t)1000))
55
56/** Auto cast from the input type to CONF_ITEM (which is the base type)
57 *
58 * Automatically casts:
59 * - #CONF_SECTION
60 * - #CONF_PAIR
61 * - #CONF_DATA
62 *
63 * To a #CONF_ITEM, whilst performing talloc type checks.
64 */
65#define CF_TO_ITEM(_cf) \
66_Generic((_cf), \
67 CONF_SECTION * : cf_section_to_item((CONF_SECTION const *)_cf), \
68 CONF_SECTION const * : cf_section_to_item((CONF_SECTION const *)_cf), \
69 CONF_PAIR * : cf_pair_to_item((CONF_PAIR const *)_cf), \
70 CONF_PAIR const * : cf_pair_to_item((CONF_PAIR const *)_cf), \
71 CONF_DATA * : cf_data_to_item((CONF_DATA const *)_cf), \
72 CONF_DATA const * : cf_data_to_item((CONF_DATA const *)_cf), \
73 default: _cf \
74)
75
76typedef int (*cf_walker_t)(void *data, void *ctx);
77
78#define CF_IDENT_ANY ((void *) (-1))
79
80/*
81 * Generic functions that apply to all types of #CONF_ITEM
82 */
83#define cf_item_add(_parent, _child) _cf_item_add(CF_TO_ITEM(_parent), CF_TO_ITEM(_child))
85
86#define cf_item_insert_after(_parent, _prev, _child) _cf_item_insert_after(CF_TO_ITEM(_parent), CF_TO_ITEM(_prev), CF_TO_ITEM(_child))
88
89#define cf_item_remove(_parent, _child) _cf_item_remove(CF_TO_ITEM(_parent), CF_TO_ITEM(_child))
91
92#define cf_item_next(_ci, _curr) _cf_item_next(CF_TO_ITEM(_ci), _curr)
93CONF_ITEM *_cf_item_next(CONF_ITEM const *ci, CONF_ITEM const *curr);
94
95#define cf_item_prev(_ci, _curr) _cf_item_prev(CF_TO_ITEM(_ci), _curr)
96CONF_ITEM *_cf_item_prev(CONF_ITEM const *ci, CONF_ITEM const *prev);
97
98#define cf_root(_cf) _cf_root(CF_TO_ITEM(_cf))
100
101#define cf_parent(_cf) _cf_parent(CF_TO_ITEM(_cf))
102CONF_ITEM *_cf_parent(CONF_ITEM const *ci);
103
104#define cf_lineno(_cf) _cf_lineno(CF_TO_ITEM(_cf))
105int _cf_lineno(CONF_ITEM const *ci);
106
107#define cf_filename(_cf) _cf_filename(CF_TO_ITEM(_cf))
108char const *_cf_filename(CONF_ITEM const *ci);
109
110bool cf_item_is_section(CONF_ITEM const *ci);
111bool cf_item_is_pair(CONF_ITEM const *ci);
112bool cf_item_is_data(CONF_ITEM const *ci);
113
114/** @hidecallergraph */
116/** @hidecallergraph */
118/** @hidecallergraph */
120
121/** @hidecallergraph */
123/** @hidecallergraph */
125/** @hidecallergraph */
127
128#define cf_filename_set(_ci, _filename) _cf_filename_set(CF_TO_ITEM(_ci), _filename)
129void _cf_filename_set(CONF_ITEM *cs, char const *filename);
130
131#define cf_lineno_set(_ci, _lineno) _cf_lineno_set(CF_TO_ITEM(_ci), _lineno)
132void _cf_lineno_set(CONF_ITEM *cs, int lineno);
133
135
136/*
137 * Section manipulation and searching
138 */
139#ifndef NDEBUG
140# define cf_section_alloc(_ctx, _parent, _name1, _name2) \
141 _cf_section_alloc(_ctx, _parent, _name1, _name2, __FILE__, __LINE__)
142#else
143# define cf_section_alloc(_ctx, _parent, _name1, _name2) \
144 _cf_section_alloc(_ctx, _parent, _name1, _name2, NULL, 0)
145#endif
147 char const *name1, char const *name2,
148 char const *filename, int lineno);
149CONF_SECTION *cf_section_dup(TALLOC_CTX *ctx, CONF_SECTION *parent, CONF_SECTION const *cs,
150 char const *name1, char const *name2, bool copy_meta);
151
152#define cf_section_foreach(_parent, _iter) \
153 for (CONF_SECTION *_iter = cf_section_first(_parent); _iter; _iter = cf_section_next(_parent, _iter))
154
155/** @hidecallergraph */
157
158/** @hidecallergraph */
160
161/** @hidecallergraph */
163
164/** @hidecallergraph */
165CONF_SECTION *cf_section_find(CONF_SECTION const *cs, char const *name1, char const *name2);
166/** @hidecallergraph */
168 char const *name1, char const *name2);
169
170#define cf_section_find_in_parent(_cf, _name1, _name2) \
171 _cf_section_find_in_parent(CF_TO_ITEM(_cf), _name1, _name2)
173 char const *name1, char const *name2);
174
175#define cf_section_find_parent(_cf, _name1, _name2) \
176 _cf_section_find_parent(CF_TO_ITEM(_cf), _name1, _name2)
178 char const *name1, char const *name2);
179
180char const *cf_section_value_find(CONF_SECTION const *, char const *attr);
181
182int8_t cf_section_name_cmp(CONF_SECTION const *cs, char const *name1, char const *name2);
183/** @hidecallergraph */
184char const *cf_section_name1(CONF_SECTION const *cs);
185/** @hidecallergraph */
186char const *cf_section_name2(CONF_SECTION const *cs);
187/** @hidecallergraph */
188char const *cf_section_name(CONF_SECTION const *cs);
189char const *cf_section_argv(CONF_SECTION const *cs, int argc);
192
193// only for rewrite_update
195
196#define cf_section_free_children(_x) cf_item_free_children(cf_section_to_item(_x))
197
198
199/*
200 * Pair manipulation and searching
201 */
202CONF_PAIR *cf_pair_alloc(CONF_SECTION *parent, char const *attr, char const *value,
203 fr_token_t op, fr_token_t lhs_type, fr_token_t rhs_type);
204
205CONF_PAIR *cf_pair_dup(CONF_SECTION *parent, CONF_PAIR *cp, bool copy_meta);
206
207int cf_pair_replace(CONF_SECTION *cs, CONF_PAIR *cp, char const *value);
208
210
212
214
215CONF_PAIR *cf_pair_next(CONF_SECTION const *cs, CONF_PAIR const *curr);
216
217CONF_PAIR *cf_pair_prev(CONF_SECTION const *cs, CONF_PAIR const *curr);
218
219CONF_PAIR *cf_pair_find(CONF_SECTION const *cs, char const *name);
220
221CONF_PAIR *cf_pair_find_next(CONF_SECTION const *cs, CONF_PAIR const *prev, char const *name);
222
223CONF_PAIR *cf_pair_find_in_parent(CONF_SECTION const *cs, char const *attr);
224
225unsigned int cf_pair_count_descendents(CONF_SECTION const *cs);
226
227unsigned int cf_pair_count(CONF_SECTION const *cs, char const *attr);
228
229fr_slen_t cf_pair_values_concat(fr_sbuff_t *sbuff, CONF_SECTION const *cs, char const *attr, char const *sep);
230
231/** @hidecallergraph */
232char const *cf_pair_attr(CONF_PAIR const *pair);
233/** @hidecallergraph */
234char const *cf_pair_value(CONF_PAIR const *pair);
235/** @hidecallergraph */
237
240
241/*
242 * Data manipulation and searching
243 */
244#define cf_data_find(_cf, _type, _name) _cf_data_find(CF_TO_ITEM(_cf), #_type, _name)
245CONF_DATA const *_cf_data_find(CONF_ITEM const *ci, char const *type, char const *name);
246
247#define cf_data_find_next(_cf, _prev, _type, _name) _cf_data_find_next(CF_TO_ITEM(_cf), CF_TO_ITEM(_prev), #_type, _name)
248CONF_DATA const *_cf_data_find_next(CONF_ITEM const *ci, CONF_ITEM const *prev, char const *type, char const *name);
249
250#define cf_data_find_in_parent(_cf, _type, _name) _cf_data_find_in_parent(CF_TO_ITEM(_cf), #_type, _name)
251CONF_DATA *_cf_data_find_in_parent(CONF_ITEM const *ci, char const *type, char const *name);
252
253void *cf_data_value(CONF_DATA const *cd);
254
255#define cf_data_add(_cf, _data, _name, _free) _cf_data_add(CF_TO_ITEM(_cf), (void const *) _data, _name, _free, __FILE__, __LINE__)
256CONF_DATA const *_cf_data_add(CONF_ITEM *ci, void const *data, char const *name, bool free, char const *filename, int lineno);
257
258#define cf_data_add_static(_cf, _data, _type, _name) _cf_data_add_static(CF_TO_ITEM(_cf), _data, #_type, _name, __FILE__, __LINE__)
259CONF_DATA const *_cf_data_add_static(CONF_ITEM *ci, void const *data, char const *type, char const *name, char const *filename, int lineno);
260
261/** Remove an item from a parent by type and name
262 *
263 * @param[in] _cf conf section or pair to remove data from.
264 * @param[in] _type of data to remove.
265 * @param[in] _name of data to remove.
266 */
267#define cf_data_remove(_cf, _type, _name) _cf_data_remove(CF_TO_ITEM(_cf), cf_data_find(_cf, _type, _name))
268
269/** Remove an item from a parent
270 *
271 * @param[in] _cf conf section or pair to remove data from.
272 * @param[in] _cd conf data to remove.
273 */
274#define cf_data_remove_by_data(_cf, _cd) _cf_data_remove(CF_TO_ITEM(_cf), _cd)
275void *_cf_data_remove(CONF_ITEM *ci, CONF_DATA const *_cd);
276
277#define cf_data_walk(_cf, _type, _cb, _ctx) _cf_data_walk(CF_TO_ITEM(_cf), #_type, _cb, _ctx)
278int _cf_data_walk(CONF_ITEM *ci, char const *type, cf_walker_t cb, void *ctx);
279
280/*
281 * Validation
282 */
283int cf_pair_in_table(int32_t *out, fr_table_num_sorted_t const *table, size_t table_len, CONF_PAIR *cp);
284
285/*
286 * Error logging
287 */
288
289#define cf_log_err(_cf, _fmt, ...) _cf_log(L_ERR, CF_TO_ITEM(_cf), __FILE__, __LINE__, _fmt, ## __VA_ARGS__)
290#define cf_log_warn(_cf, _fmt, ...) _cf_log(L_WARN, CF_TO_ITEM(_cf), __FILE__, __LINE__, _fmt, ## __VA_ARGS__)
291#define cf_log_info(_cf, _fmt, ...) _cf_log(L_INFO, CF_TO_ITEM(_cf), __FILE__, __LINE__, _fmt, ## __VA_ARGS__)
292#define cf_log_debug(_cf, _fmt, ...) _cf_log(L_DBG, CF_TO_ITEM(_cf), __FILE__, __LINE__, _fmt, ## __VA_ARGS__)
293void _cf_vlog(fr_log_type_t type, CONF_ITEM const *ci, char const *file, int line, char const *fmt, va_list ap) CC_HINT(format (printf, 5, 0));
294void _cf_log(fr_log_type_t type, CONF_ITEM const *ci, char const *file, int line, char const *fmt, ...) CC_HINT(format (printf, 5, 6));
295
296#define cf_log_perr(_cf, _fmt, ...) _cf_log_perr(L_ERR, CF_TO_ITEM(_cf), __FILE__, __LINE__, NULL, _fmt, ## __VA_ARGS__)
297#define cf_log_pwarn(_cf, _fmt, ...) _cf_log_perr(L_WARN, CF_TO_ITEM(_cf), __FILE__, __LINE__, NULL, _fmt, ## __VA_ARGS__)
298
299void _cf_vlog_perr(fr_log_type_t type, CONF_ITEM const *ci, char const *file, int line,
300 fr_log_perror_format_t const *f_rules, char const *fmt, va_list ap)
301 CC_HINT(format (printf, 6, 0));
302void _cf_log_perr(fr_log_type_t type, CONF_ITEM const *ci, char const *file, int line,
303 fr_log_perror_format_t const *f_rules, char const *fmt, ...)
304 CC_HINT(format (printf, 6, 7));
305
306#define cf_log_debug_prefix(_cf, _fmt, ...) _cf_log_with_filename(L_DBG, CF_TO_ITEM(_cf), __FILE__, __LINE__, _fmt, ## __VA_ARGS__)
307void _cf_log_with_filename(fr_log_type_t type, CONF_ITEM const *ci, char const *file, int line, char const *fmt, ...) CC_HINT(format (printf, 5, 6));
308
309/** Log an error message against a specified child
310 *
311 * @param[in] _parent CONF_SECTION.
312 * @param[in] _child string identifier.
313 * @param[in] _fmt of message.
314 * @param[in] ... arguments.
315 */
316#define cf_log_err_by_child(_parent, _child, _fmt, ...) _cf_log_by_child(L_ERR, _parent, _child, __FILE__, __LINE__, _fmt, ## __VA_ARGS__)
317
318/** Log an error message against a specified child, draining the thread local error stack
319 *
320 * @param[in] _parent CONF_SECTION.
321 * @param[in] _child string identifier.
322 * @param[in] _f_rules Line prefixes.
323 * @param[in] _fmt of message.
324 * @param[in] ... arguments.
325 */
326#define cf_log_perr_by_child(_parent, _child, _f_rules, _fmt, ...) _cf_log_perr_by_child(L_ERR, _parent, _child, __FILE__, __LINE__, _f_rules, _fmt, ## __VA_ARGS__)
327
328/** Log a warning message against a specified child
329 *
330 * @param[in] _parent CONF_SECTION.
331 * @param[in] _child string identifier.
332 * @param[in] _fmt of message.
333 * @param[in] ... arguments.
334 */
335#define cf_log_warn_by_child(_parent, _child, _fmt, ...) _cf_log_by_child(L_WARN, _parent, _child, __FILE__, __LINE__, _fmt, ## __VA_ARGS__)
336
337/** Log an info message against a specified child
338 *
339 * @param[in] _parent CONF_SECTION.
340 * @param[in] _child string identifier.
341 * @param[in] _fmt of message.
342 * @param[in] ... arguments.
343 */
344#define cf_log_info_by_child(_parent, _child, _fmt, ...) _cf_log_by_child(L_INFO, _parent, _child, __FILE__, __LINE__, _fmt, ## __VA_ARGS__)
345
346/** Log a debug message against a specified child
347 *
348 * @param[in] _parent CONF_SECTION.
349 * @param[in] _child string identifier.
350 * @param[in] _fmt of message.
351 * @param[in] ... arguments.
352 */
353#define cf_log_debug_by_child(_parent, _child, _fmt, ...) _cf_log_by_child(L_DBG, _parent, _child, __FILE__, __LINE__, _fmt, ## __VA_ARGS__)
354void _cf_log_by_child(fr_log_type_t type, CONF_SECTION const *parent, char const *child,
355 char const *file, int line, char const *fmt, ...) CC_HINT(format (printf, 6, 7));
356
357void _cf_log_perr_by_child(fr_log_type_t type, CONF_SECTION const *parent, char const *child,
358 char const *file, int line, fr_log_perror_format_t const *f_rules,
359 char const *fmt, ...) CC_HINT(format (printf, 7, 8));
360
361#define cf_item_debug(_cf) _cf_item_debug(CF_TO_ITEM(_cf))
362void _cf_item_debug(CONF_ITEM const *ci);
363
364void cf_pair_debug(CONF_PAIR *cp);
366
367#define cf_canonicalize_error(_ci, _slen, _msg, _str) _cf_canonicalize_error(CF_TO_ITEM(_ci), _slen, _msg, _str)
368void _cf_canonicalize_error(CONF_ITEM *ci, ssize_t slen, char const *msg, char const *str);
369
370#ifdef __cplusplus
371}
372#endif
int const char * file
Definition acutest.h:702
log_entry msg
Definition acutest.h:794
static int const char * fmt
Definition acutest.h:573
int const char int line
Definition acutest.h:702
#define RCSIDH(h, id)
Definition build.h:484
Internal data that is associated with a configuration section.
Definition cf_priv.h:124
Common header for all CONF_* types.
Definition cf_priv.h:49
Configuration AVP similar to a fr_pair_t.
Definition cf_priv.h:70
A section grouping multiple CONF_PAIR.
Definition cf_priv.h:101
void _cf_log_with_filename(fr_log_type_t type, CONF_ITEM const *ci, char const *file, int line, char const *fmt,...))
Log a debug message relating to a CONF_ITEM.
Definition cf_util.c:2180
CONF_ITEM * cf_data_to_item(CONF_DATA const *cs)
Cast CONF_DATA to a CONF_ITEM.
Definition cf_util.c:754
bool cf_item_is_pair(CONF_ITEM const *ci)
Determine if CONF_ITEM is a CONF_PAIR.
Definition cf_util.c:632
fr_token_t cf_pair_attr_quote(CONF_PAIR const *pair)
Return the value (lhs) quoting of a pair.
Definition cf_util.c:1623
CONF_SECTION * _cf_section_find_parent(CONF_ITEM const *ci, char const *name1, char const *name2)
Find a parent CONF_SECTION with name1 and optionally name2.
Definition cf_util.c:1096
int _cf_data_walk(CONF_ITEM *ci, char const *type, cf_walker_t cb, void *ctx)
Walk over a specific type of CONF_DATA.
Definition cf_util.c:1897
unsigned int cf_pair_count_descendents(CONF_SECTION const *cs)
Count the number of conf pairs beneath a section.
Definition cf_util.c:1505
void cf_section_debug(CONF_SECTION *cs)
Ease of use from debugger.
Definition cf_util.c:2406
CONF_DATA * _cf_data_find_in_parent(CONF_ITEM const *ci, char const *type, char const *name)
Find matching data in the specified section or one of its parents.
Definition cf_util.c:1744
CONF_ITEM * _cf_item_remove(CONF_ITEM *parent, CONF_ITEM *child)
Remove item from parent and fixup trees.
Definition cf_util.c:447
void _cf_vlog_perr(fr_log_type_t type, CONF_ITEM const *ci, char const *file, int line, fr_log_perror_format_t const *f_rules, char const *fmt, va_list ap))
Log an error message relating to a CONF_ITEM.
Definition cf_util.c:2068
CONF_DATA const * _cf_data_find(CONF_ITEM const *ci, char const *type, char const *name)
Find user data in a config section.
Definition cf_util.c:1710
CONF_PAIR * cf_pair_alloc(CONF_SECTION *parent, char const *attr, char const *value, fr_token_t op, fr_token_t lhs_type, fr_token_t rhs_type)
Allocate a CONF_PAIR.
Definition cf_util.c:1279
fr_token_t cf_section_argv_quote(CONF_SECTION const *cs, int argc)
Return the quoting for one of the variadic arguments.
Definition cf_util.c:1260
unsigned int cf_pair_count(CONF_SECTION const *cs, char const *attr)
Count the number of times an attribute occurs in a parent section.
Definition cf_util.c:1520
int cf_pair_in_table(int32_t *out, fr_table_num_sorted_t const *table, size_t table_len, CONF_PAIR *cp)
Check to see if the CONF_PAIR value is present in the specified table.
Definition cf_util.c:1966
CONF_PAIR * cf_pair_dup(CONF_SECTION *parent, CONF_PAIR *cp, bool copy_meta)
Duplicate a CONF_PAIR.
Definition cf_util.c:1321
void _cf_item_insert_after(CONF_ITEM *parent, CONF_ITEM *prev, CONF_ITEM *child)
Insert a child after a given one.
Definition cf_util.c:409
void _cf_log_by_child(fr_log_type_t type, CONF_SECTION const *parent, char const *child, char const *file, int line, char const *fmt,...))
Log an error message in the context of a child pair of the specified parent.
Definition cf_util.c:2219
void cf_item_free_children(CONF_ITEM *ci)
Definition cf_util.c:2416
char const * cf_section_value_find(CONF_SECTION const *, char const *attr)
Find a pair in a CONF_SECTION.
Definition cf_util.c:1120
char const * cf_section_name2(CONF_SECTION const *cs)
Return the second identifier of a CONF_SECTION.
Definition cf_util.c:1185
int8_t cf_section_name_cmp(CONF_SECTION const *cs, char const *name1, char const *name2)
Check if a given section matches the specified name1/name2 identifiers.
Definition cf_util.c:1139
void * cf_data_value(CONF_DATA const *cd)
Return the user assigned value of CONF_DATA.
Definition cf_util.c:1763
CONF_ITEM * cf_section_to_item(CONF_SECTION const *cs)
Cast a CONF_SECTION to a CONF_ITEM.
Definition cf_util.c:738
void _cf_vlog(fr_log_type_t type, CONF_ITEM const *ci, char const *file, int line, char const *fmt, va_list ap))
Log an error message relating to a CONF_ITEM.
Definition cf_util.c:2006
void _cf_log_perr(fr_log_type_t type, CONF_ITEM const *ci, char const *file, int line, fr_log_perror_format_t const *f_rules, char const *fmt,...))
Log an error message relating to a CONF_ITEM.
Definition cf_util.c:2157
CONF_ITEM * _cf_parent(CONF_ITEM const *ci)
Return the parent of a CONF_ITEM.
Definition cf_util.c:576
CONF_SECTION * cf_section_next(CONF_SECTION const *cs, CONF_SECTION const *curr)
Return the next child that's a CONF_SECTION.
Definition cf_util.c:997
void cf_pair_mark_parsed(CONF_PAIR *cp)
Mark a pair as parsed.
Definition cf_util.c:1376
char const * cf_section_name1(CONF_SECTION const *cs)
Return the second identifier of a CONF_SECTION.
Definition cf_util.c:1171
void _cf_filename_set(CONF_ITEM *cs, char const *filename)
Set the filename of a CONF_ITEM.
Definition cf_util.c:894
CONF_SECTION * _cf_section_alloc(TALLOC_CTX *ctx, CONF_SECTION *parent, char const *name1, char const *name2, char const *filename, int lineno)
Allocate a CONF_SECTION.
Definition cf_util.c:787
CONF_SECTION * cf_section_find(CONF_SECTION const *cs, char const *name1, char const *name2)
Find a CONF_SECTION with name1 and optionally name2.
Definition cf_util.c:1028
CONF_SECTION * cf_item_to_section(CONF_ITEM const *ci)
Cast a CONF_ITEM to a CONF_SECTION.
Definition cf_util.c:684
CONF_ITEM * _cf_item_prev(CONF_ITEM const *ci, CONF_ITEM const *prev)
Return the next child of cs.
Definition cf_util.c:525
CONF_DATA * cf_item_to_data(CONF_ITEM const *ci)
Cast CONF_ITEM to CONF_DATA performing a type check.
Definition cf_util.c:704
CONF_SECTION * _cf_root(CONF_ITEM const *ci)
Return the top level CONF_SECTION holding all other CONF_ITEM.
Definition cf_util.c:558
fr_slen_t cf_pair_values_concat(fr_sbuff_t *sbuff, CONF_SECTION const *cs, char const *attr, char const *sep)
Concatenate the values of any pairs with name attr.
Definition cf_util.c:1540
CONF_DATA const * _cf_data_add_static(CONF_ITEM *ci, void const *data, char const *type, char const *name, char const *filename, int lineno)
Add non-talloced user data to a config section.
Definition cf_util.c:1828
CONF_PAIR * cf_pair_find(CONF_SECTION const *cs, char const *name)
Search for a CONF_PAIR with a specific name.
Definition cf_util.c:1439
char const * cf_section_name(CONF_SECTION const *cs)
Return name2 if set, else name1.
Definition cf_util.c:1197
char const * _cf_filename(CONF_ITEM const *ci)
Return the filename the CONF_ITEM was parsed in.
Definition cf_util.c:604
void cf_section_add_name2_quote(CONF_SECTION *cs, fr_token_t token)
Set the quoting of the name2 identifier.
Definition cf_util.c:1242
CONF_DATA const * _cf_data_add(CONF_ITEM *ci, void const *data, char const *name, bool free, char const *filename, int lineno)
Add talloced user data to a config section.
Definition cf_util.c:1786
bool cf_item_is_data(CONF_ITEM const *ci)
Determine if CONF_ITEM is CONF_DATA.
Definition cf_util.c:646
void _cf_item_debug(CONF_ITEM const *ci)
Print out debugging information about a CONFIG_ITEM.
Definition cf_util.c:2274
fr_token_t cf_pair_operator(CONF_PAIR const *pair)
Return the operator of a pair.
Definition cf_util.c:1608
bool cf_pair_is_parsed(CONF_PAIR *cp)
Return whether a pair has already been parsed.
Definition cf_util.c:1388
CONF_PAIR * cf_pair_find_next(CONF_SECTION const *cs, CONF_PAIR const *prev, char const *name)
Find a pair with a name matching attr, after specified pair.
Definition cf_util.c:1453
fr_token_t cf_pair_value_quote(CONF_PAIR const *pair)
Return the value (rhs) quoting of a pair.
Definition cf_util.c:1638
CONF_PAIR * cf_pair_first(CONF_SECTION const *cs)
Return the first child that's a CONF_PAIR.
Definition cf_util.c:1400
CONF_SECTION * cf_section_find_next(CONF_SECTION const *cs, CONF_SECTION const *subcs, char const *name1, char const *name2)
Return the next matching section.
Definition cf_util.c:1049
CONF_PAIR * cf_pair_next(CONF_SECTION const *cs, CONF_PAIR const *curr)
Return the next child that's a CONF_PAIR.
Definition cf_util.c:1413
void _cf_canonicalize_error(CONF_ITEM *ci, ssize_t slen, char const *msg, char const *str)
Definition cf_util.c:2429
CONF_SECTION * _cf_section_find_in_parent(CONF_ITEM const *ci, char const *name1, char const *name2)
Find an ancestor of the passed CONF_ITEM which has a child matching a specific name1 and optionally n...
Definition cf_util.c:1072
CONF_DATA const * _cf_data_find_next(CONF_ITEM const *ci, CONF_ITEM const *prev, char const *type, char const *name)
Return the next item of user data.
Definition cf_util.c:1728
bool cf_item_is_section(CONF_ITEM const *ci)
Determine if CONF_ITEM is a CONF_SECTION.
Definition cf_util.c:618
CONF_SECTION * cf_section_dup(TALLOC_CTX *ctx, CONF_SECTION *parent, CONF_SECTION const *cs, char const *name1, char const *name2, bool copy_meta)
Duplicate a configuration section.
Definition cf_util.c:928
CONF_PAIR * cf_pair_find_in_parent(CONF_SECTION const *cs, char const *attr)
Find a pair with a name matching attr in the specified section or one of its parents.
Definition cf_util.c:1467
char const * cf_section_argv(CONF_SECTION const *cs, int argc)
Return variadic argument at the specified index.
Definition cf_util.c:1213
CONF_PAIR * cf_pair_prev(CONF_SECTION const *cs, CONF_PAIR const *curr)
Return the previous child that's a CONF_PAIR.
Definition cf_util.c:1426
CONF_ITEM * _cf_item_next(CONF_ITEM const *ci, CONF_ITEM const *curr)
Return the next child of the CONF_ITEM.
Definition cf_util.c:510
int _cf_lineno(CONF_ITEM const *ci)
Return the lineno the CONF_ITEM was parsed at.
Definition cf_util.c:590
CONF_SECTION * cf_section_first(CONF_SECTION const *cs)
Return the first child in a CONF_SECTION.
Definition cf_util.c:984
CONF_PAIR * cf_item_to_pair(CONF_ITEM const *ci)
Cast a CONF_ITEM to a CONF_PAIR.
Definition cf_util.c:664
fr_token_t cf_section_name2_quote(CONF_SECTION const *cs)
Return the quoting of the name2 identifier.
Definition cf_util.c:1230
void * _cf_data_remove(CONF_ITEM *ci, CONF_DATA const *_cd)
Remove data from a configuration section.
Definition cf_util.c:1872
char const * cf_pair_value(CONF_PAIR const *pair)
Return the value of a CONF_PAIR.
Definition cf_util.c:1594
int cf_pair_replace(CONF_SECTION *cs, CONF_PAIR *cp, char const *value)
Replace pair in a given section with a new pair, of the given value.
Definition cf_util.c:1350
void _cf_item_add(CONF_ITEM *parent, CONF_ITEM *child)
Add a child.
Definition cf_util.c:382
void cf_pair_debug(CONF_PAIR *cp)
Ease of use from debugger.
Definition cf_util.c:2399
CONF_ITEM * cf_pair_to_item(CONF_PAIR const *cp)
Cast a CONF_PAIR to a CONF_ITEM.
Definition cf_util.c:722
void _cf_log(fr_log_type_t type, CONF_ITEM const *ci, char const *file, int line, char const *fmt,...))
Log an error message relating to a CONF_ITEM.
Definition cf_util.c:2045
void _cf_log_perr_by_child(fr_log_type_t type, CONF_SECTION const *parent, char const *child, char const *file, int line, fr_log_perror_format_t const *f_rules, char const *fmt,...))
Log an error message in the context of a child pair of the specified parent.
Definition cf_util.c:2250
CONF_SECTION * cf_section_prev(CONF_SECTION const *cs, CONF_SECTION const *curr)
Return the previous child that's a CONF_SECTION.
Definition cf_util.c:1010
void _cf_lineno_set(CONF_ITEM *cs, int lineno)
Set the line number of a CONF_ITEM.
Definition cf_util.c:906
char const * cf_pair_attr(CONF_PAIR const *pair)
Return the attr of a CONF_PAIR.
Definition cf_util.c:1578
int(* cf_walker_t)(void *data, void *ctx)
Definition cf_util.h:76
Test enumeration values.
Definition dict_test.h:92
free(array)
fr_log_type_t
Definition log.h:54
long int ssize_t
ssize_t fr_slen_t
static char const * name
fr_aka_sim_id_type_t type
An element in a lexicographically sorted array of name to num mappings.
Definition table.h:49
enum fr_token fr_token_t
static fr_slen_t parent
Definition pair.h:851
static fr_slen_t data
Definition value.h:1265
static size_t char ** out
Definition value.h:997