The FreeRADIUS server  $Id: 15bac2a4c627c01d1aa2047687b3418955ac7f00 $
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  */
26 RCSIDH(conf_file_h, "$Id: da4a47ea5a14dea7badf696056e7da0ae1b1bc41 $")
27 
28 #ifdef __cplusplus
29 extern "C" {
30 #endif
31 
32 /*
33  * Export the minimum amount of information about these structs
34  */
35 typedef struct cf_item CONF_ITEM; //!< Generic configuration element, extended to become
36  ///< a #CONF_PAIR, a #CONF_SECTION or #CONF_DATA.
37 typedef struct cf_section CONF_SECTION; //!< #CONF_ITEM used to group multiple #CONF_PAIR and #CONF_SECTION, together.
38 typedef struct cf_pair CONF_PAIR; //!< #CONF_ITEM with an attribute, an operator and a value.
39 typedef 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 
76 typedef 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))
84 void _cf_item_add(CONF_ITEM *parent, CONF_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)
93 CONF_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)
96 CONF_ITEM *_cf_item_prev(CONF_ITEM const *ci, CONF_ITEM const *prev);
97 
98 #define cf_root(_cf) _cf_root(CF_TO_ITEM(_cf))
99 CONF_SECTION *_cf_root(CONF_ITEM const *ci);
100 
101 #define cf_parent(_cf) _cf_parent(CF_TO_ITEM(_cf))
102 CONF_ITEM *_cf_parent(CONF_ITEM const *ci);
103 
104 #define cf_lineno(_cf) _cf_lineno(CF_TO_ITEM(_cf))
105 int _cf_lineno(CONF_ITEM const *ci);
106 
107 #define cf_filename(_cf) _cf_filename(CF_TO_ITEM(_cf))
108 char const *_cf_filename(CONF_ITEM const *ci);
109 
110 bool cf_item_is_section(CONF_ITEM const *ci);
111 bool cf_item_is_pair(CONF_ITEM const *ci);
112 bool 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)
129 void _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)
132 void _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);
149 CONF_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 */
159 CONF_SECTION *cf_section_next(CONF_SECTION const *cs, CONF_SECTION const *curr);
160 
161 /** @hidecallergraph */
162 CONF_SECTION *cf_section_prev(CONF_SECTION const *cs, CONF_SECTION const *curr);
163 
164 /** @hidecallergraph */
165 CONF_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 
180 char const *cf_section_value_find(CONF_SECTION const *, char const *attr);
181 
182 int8_t cf_section_name_cmp(CONF_SECTION const *cs, char const *name1, char const *name2);
183 /** @hidecallergraph */
184 char const *cf_section_name1(CONF_SECTION const *cs);
185 /** @hidecallergraph */
186 char const *cf_section_name2(CONF_SECTION const *cs);
187 /** @hidecallergraph */
188 char const *cf_section_name(CONF_SECTION const *cs);
189 char const *cf_section_argv(CONF_SECTION const *cs, int argc);
191 fr_token_t cf_section_argv_quote(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  */
202 CONF_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 
205 CONF_PAIR *cf_pair_dup(CONF_SECTION *parent, CONF_PAIR *cp, bool copy_meta);
206 
207 int cf_pair_replace(CONF_SECTION *cs, CONF_PAIR *cp, char const *value);
208 
210 
211 bool cf_pair_is_parsed(CONF_PAIR *cp);
212 
214 
215 CONF_PAIR *cf_pair_next(CONF_SECTION const *cs, CONF_PAIR const *curr);
216 
217 CONF_PAIR *cf_pair_prev(CONF_SECTION const *cs, CONF_PAIR const *curr);
218 
219 CONF_PAIR *cf_pair_find(CONF_SECTION const *cs, char const *name);
220 
221 CONF_PAIR *cf_pair_find_next(CONF_SECTION const *cs, CONF_PAIR const *prev, char const *name);
222 
223 CONF_PAIR *cf_pair_find_in_parent(CONF_SECTION const *cs, char const *attr);
224 
225 unsigned int cf_pair_count_descendents(CONF_SECTION const *cs);
226 
227 unsigned int cf_pair_count(CONF_SECTION const *cs, char const *attr);
228 
229 fr_slen_t cf_pair_values_concat(fr_sbuff_t *sbuff, CONF_SECTION const *cs, char const *attr, char const *sep);
230 
231 /** @hidecallergraph */
232 char const *cf_pair_attr(CONF_PAIR const *pair);
233 /** @hidecallergraph */
234 char 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)
245 CONF_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)
248 CONF_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)
251 CONF_DATA *_cf_data_find_in_parent(CONF_ITEM const *ci, char const *type, char const *name);
252 
253 void *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__)
256 CONF_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__)
259 CONF_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)
275 void *_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)
278 int _cf_data_walk(CONF_ITEM *ci, char const *type, cf_walker_t cb, void *ctx);
279 
280 /*
281  * Validation
282  */
283 int 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__)
293 void _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));
294 void _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 
299 void _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));
302 void _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__)
307 void _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__)
354 void _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 
357 void _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))
362 void _cf_item_debug(CONF_ITEM const *ci);
363 
364 void 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)
368 void _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:482
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
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
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_item_remove(CONF_ITEM *parent, CONF_ITEM *child)
Remove item from parent and fixup trees.
Definition: cf_util.c:447
bool cf_item_is_pair(CONF_ITEM const *ci)
Determine if CONF_ITEM is a CONF_PAIR.
Definition: cf_util.c:632
CONF_PAIR * cf_item_to_pair(CONF_ITEM const *ci)
Cast a CONF_ITEM to a CONF_PAIR.
Definition: cf_util.c:664
CONF_ITEM * cf_section_to_item(CONF_SECTION const *cs)
Cast a CONF_SECTION to a CONF_ITEM.
Definition: cf_util.c:738
fr_token_t cf_pair_attr_quote(CONF_PAIR const *pair)
Return the value (lhs) quoting of a pair.
Definition: cf_util.c:1623
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_pair_attr(CONF_PAIR const *pair)
Return the attr of a CONF_PAIR.
Definition: cf_util.c:1578
void * _cf_data_remove(CONF_ITEM *ci, CONF_DATA const *_cd)
Remove data from a configuration section.
Definition: cf_util.c:1872
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
CONF_PAIR * cf_pair_prev(CONF_SECTION const *cs, CONF_PAIR const *curr)
Return the next child that's a CONF_PAIR.
Definition: cf_util.c:1426
void cf_section_debug(CONF_SECTION *cs)
Ease of use from debugger.
Definition: cf_util.c:2406
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
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
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
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
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
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
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_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
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_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_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
char const * cf_section_name2(CONF_SECTION const *cs)
Return the second identifier of a CONF_SECTION.
Definition: cf_util.c:1185
CONF_SECTION * cf_section_first(CONF_SECTION const *cs)
Return the first child in a CONF_SECTION.
Definition: cf_util.c:984
char const * cf_pair_value(CONF_PAIR const *pair)
Return the value of a CONF_PAIR.
Definition: cf_util.c:1594
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_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
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
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
void cf_pair_mark_parsed(CONF_PAIR *cp)
Mark a pair as parsed.
Definition: cf_util.c:1376
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_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_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
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
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
void * cf_data_value(CONF_DATA const *cd)
Return the user assigned value of CONF_DATA.
Definition: cf_util.c:1763
CONF_SECTION * _cf_root(CONF_ITEM const *ci)
Return the top level CONF_SECTION holding all other CONF_ITEM.
Definition: cf_util.c:558
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
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
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
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
CONF_ITEM * cf_pair_to_item(CONF_PAIR const *cp)
Cast a CONF_PAIR to a CONF_ITEM.
Definition: cf_util.c:722
bool cf_pair_is_parsed(CONF_PAIR *cp)
Return whether a pair has already been parsed.
Definition: cf_util.c:1388
char const * _cf_filename(CONF_ITEM const *ci)
Return the filename the CONF_ITEM was parsed in.
Definition: cf_util.c:604
CONF_SECTION * cf_item_to_section(CONF_ITEM const *ci)
Cast a CONF_ITEM to a CONF_SECTION.
Definition: cf_util.c:684
fr_token_t cf_pair_value_quote(CONF_PAIR const *pair)
Return the value (rhs) quoting of a pair.
Definition: cf_util.c:1638
void _cf_canonicalize_error(CONF_ITEM *ci, ssize_t slen, char const *msg, char const *str)
Definition: cf_util.c:2429
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
bool cf_item_is_section(CONF_ITEM const *ci)
Determine if CONF_ITEM is a CONF_SECTION.
Definition: cf_util.c:618
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_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
int _cf_lineno(CONF_ITEM const *ci)
Return the lineno the CONF_ITEM was parsed at.
Definition: cf_util.c:590
CONF_PAIR * cf_pair_first(CONF_SECTION const *cs)
Return the next child that's a CONF_PAIR.
Definition: cf_util.c:1400
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
CONF_PAIR * cf_pair_dup(CONF_SECTION *parent, CONF_PAIR *cp, bool copy_meta)
Duplicate a CONF_PAIR.
Definition: cf_util.c:1321
fr_token_t cf_section_name2_quote(CONF_SECTION const *cs)
Return the quoting of the name2 identifier.
Definition: cf_util.c:1230
CONF_ITEM * _cf_parent(CONF_ITEM const *ci)
Return the parent of a CONF_ITEM.
Definition: cf_util.c:576
char const * cf_section_name1(CONF_SECTION const *cs)
Return the second identifier of a CONF_SECTION.
Definition: cf_util.c:1171
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_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
char const * cf_section_name(CONF_SECTION const *cs)
Return name2 if set, else name1.
Definition: cf_util.c:1197
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_ITEM * cf_data_to_item(CONF_DATA const *cs)
Cast CONF_DATA to a CONF_ITEM.
Definition: cf_util.c:754
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_section_argv(CONF_SECTION const *cs, int argc)
Return variadic argument at the specified index.
Definition: cf_util.c:1213
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
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
Definition: merged_model.c:24
ssize_t fr_slen_t
Definition: merged_model.c:35
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
int format(printf, 5, 0))
static size_t char ** out
Definition: value.h:997