The FreeRADIUS server $Id: 15bac2a4c627c01d1aa2047687b3418955ac7f00 $
Loading...
Searching...
No Matches
tmpl.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: 73804b593eaad5b598f5e39a56faf1e38eaffcd0 $
20 *
21 * @file lib/server/tmpl.h
22 * @brief Structures and prototypes for templates
23 *
24 * These functions are used to work with #tmpl_t structs.
25 *
26 * #tmpl_t (VPTs) specify either a data source, or a data sink.
27 *
28 * Examples of sources are #TMPL_TYPE_XLAT_UNRESOLVED, #TMPL_TYPE_EXEC and #TMPL_TYPE_ATTR.
29 * Examples of sinks are #TMPL_TYPE_ATTR.
30 *
31 * VPTs are used to gather values or attributes for evaluation, or copying, and to specify
32 * where values or #fr_pair_t should be copied to.
33 *
34 * To create new #tmpl_t use one of the tmpl_*from_* functions. These parse
35 * strings into VPTs. The main parsing function is #tmpl_afrom_substr, which can produce
36 * most types of VPTs. It uses the type of quoting (passed as an #fr_token_t) to determine
37 * what type of VPT to parse the string as. For example a #T_DOUBLE_QUOTED_STRING will
38 * produce either a #TMPL_TYPE_XLAT_UNRESOLVED or a #TMPL_TYPE_DATA_UNRESOLVED (depending if the string
39 * contained a non-literal expansion).
40 *
41 * @see tmpl_afrom_substr
42 * @see tmpl_afrom_attr_str
43 *
44 * In the case of #TMPL_TYPE_ATTR, there are special cursor overlay
45 * functions which can be used to iterate over only the #fr_pair_t that match a
46 * tmpl_t in a given list.
47 *
48 * @see tmpl_dcursor_init
49 * @see tmpl_cursor_next
50 *
51 * Or for simplicity, there are functions which wrap the cursor functions, to copy or
52 * return the #fr_pair_t that match the VPT.
53 *
54 * @see tmpl_copy_pairs
55 * @see tmpl_find_vp
56 *
57 * If you just need the string value of whatever the VPT refers to, the tmpl_*expand
58 * functions may be used. These functions evaluate the VPT, execing, and xlat expanding
59 * as necessary. In the case of #TMPL_TYPE_ATTR, and #FR_TYPE_STRING or #FR_TYPE_OCTETS
60 * #tmpl_expand will return a pointer to the raw #fr_pair_t buffer. This can be very
61 * useful when using the #CONF_FLAG_TMPL type in #conf_parser_t structs, as it allows the
62 * user to determine whether they want the module to sanitise the value using presentation
63 * format specific #xlat_escape_legacy_t function, or to operate on the raw value.
64 *
65 * @see tmpl_expand
66 * @see tmpl_aexpand
67 *
68 * @copyright 2014-2015 The FreeRADIUS server project
69 */
70RCSIDH(tmpl_h, "$Id: 73804b593eaad5b598f5e39a56faf1e38eaffcd0 $")
71
72#ifdef __cplusplus
73extern "C" {
74#endif
75
76#include <freeradius-devel/util/table.h>
77#include <freeradius-devel/util/dlist.h>
78#include <freeradius-devel/util/value.h>
79
80#include <freeradius-devel/server/tmpl_escape.h>
81
82/** The maximum number of request references allowed
83 *
84 */
85#define TMPL_MAX_REQUEST_REF_NESTING 10
86
88extern size_t pair_list_table_len;
89
90typedef enum requests_ref_e {
91 REQUEST_CURRENT = 0, //!< The current request (default).
92 REQUEST_OUTER, //!< #request_t containing the outer layer of the EAP
93 //!< conversation. Usually the RADIUS request sent
94 //!< by the NAS.
95
96 REQUEST_PARENT, //!< Parent (whatever it is).
97 REQUEST_UNKNOWN //!< Unknown request.
99
101extern size_t tmpl_request_ref_table_len;
102
103/** Base data type is an attribute reference
104 *
105 */
106#define TMPL_FLAG_ATTR 0x01000000
107
108/** Base data type is an xlat expansion
109 *
110 */
111#define TMPL_FLAG_XLAT 0x02000000
112
113/** Is a type of regular expression
114 *
115 */
116#define TMPL_FLAG_REGEX 0x04000000
117
118/** Needs resolution
119 *
120 */
121#define TMPL_FLAG_UNRESOLVED 0x08000000
122
123/** Types of #tmpl_t
124 *
125 * Types may be compound types made up of multiple other types.
126 *
127 * Types which are used as part of compound types are:
128 * - XLAT_TYPE_XLAT - #tmpl_t contains xlat expansion.
129 * - XLAT_TYPE_UNRESOLVED - #tmpl_t contains unresolved elements such as xlat functions or other expansions.
130 */
131typedef enum tmpl_type_e {
132 /** Uninitialised
133 */
135
136 /** Has no value. Usually a placeholder in a binary expression that's really a unary expression
137 */
139
140 /** Value in native boxed format
141 */
143
144 /** Reference to one or more attributes
145 */
147
148 /** Pre-parsed xlat expansion
149 */
151
152 /** Callout to an external script or program
153 */
155
156 /** Compiled (and possibly JIT'd) regular expression
157 */
159
160 /** Regex where compilation is possible but hasn't been performed yet
161 */
163
164 /** A regex containing xlat expansions. Cannot be pre-compiled
165 */
167
168 /** @name unresolved types
169 *
170 * These are tmpls which could not immediately be transformed into
171 * their "resolved" form due to missing references or because
172 * additional parsing is required.
173 *
174 * @{
175 */
176
177 /** Unparsed literal string
178 *
179 * May be an intermediary phase where the tmpl is created as a
180 * temporary structure during parsing. The value here MUST be raw
181 * data, and cannot be anything else.
182 */
184
185 /** An attribute reference that we couldn't resolve but looked valid
186 *
187 * May be resolvable later once more attributes are defined.
188 */
190
191 /** An exec with unresolved xlat function or attribute references
192 */
194
195 /** A xlat expansion with unresolved xlat functions or attribute references
196 */
198
199 /** A regular expression with unresolved xlat functions or attribute references
200 */
202
203 TMPL_TYPE_MAX //!< Marker for the last tmpl type.
205
206/** Helpers to verify the type of #tmpl_t
207 */
208#define tmpl_is_uninitialised(vpt) ((vpt)->type == TMPL_TYPE_UNINITIALISED)
209
210#define tmpl_is_null(vpt) ((vpt)->type == TMPL_TYPE_NULL)
211#define tmpl_is_data(vpt) ((vpt)->type == TMPL_TYPE_DATA)
212
213#define tmpl_is_attr(vpt) ((vpt)->type == TMPL_TYPE_ATTR)
214
215#define tmpl_is_xlat(vpt) ((vpt)->type == TMPL_TYPE_XLAT)
216#define tmpl_is_exec(vpt) ((vpt)->type == TMPL_TYPE_EXEC)
217
218#define tmpl_is_regex(vpt) ((vpt)->type == TMPL_TYPE_REGEX)
219#define tmpl_is_regex_uncompiled(vpt) ((vpt)->type == TMPL_TYPE_REGEX_UNCOMPILED)
220#define tmpl_is_regex_xlat(vpt) ((vpt)->type == TMPL_TYPE_REGEX_XLAT)
221
222#define tmpl_is_data_unresolved(vpt) ((vpt)->type == TMPL_TYPE_DATA_UNRESOLVED)
223#define tmpl_is_exec_unresolved(vpt) ((vpt)->type == TMPL_TYPE_EXEC_UNRESOLVED)
224#define tmpl_is_attr_unresolved(vpt) ((vpt)->type == TMPL_TYPE_ATTR_UNRESOLVED)
225#define tmpl_is_xlat_unresolved(vpt) ((vpt)->type == TMPL_TYPE_XLAT_UNRESOLVED)
226#define tmpl_is_regex_xlat_unresolved(vpt) ((vpt)->type == TMPL_TYPE_REGEX_XLAT_UNRESOLVED)
227
228#define tmpl_needs_resolving(vpt) ((vpt)->type & TMPL_FLAG_UNRESOLVED)
229#define tmpl_contains_data(vpt) ((vpt)->type & TMPL_TYPE_DATA)
230#define tmpl_contains_attr(vpt) ((vpt)->type & TMPL_FLAG_ATTR)
231#define tmpl_contains_regex(vpt) ((vpt)->type & TMPL_FLAG_REGEX)
232#define tmpl_contains_xlat(vpt) ((vpt)->type & TMPL_FLAG_XLAT)
233
234
236extern size_t tmpl_type_table_len;
237
241typedef struct tmpl_literal_rules_s tmpl_literal_rules_t;
243typedef struct tmpl_s tmpl_t;
244
245#include <freeradius-devel/unlang/xlat.h>
246#include <freeradius-devel/unlang/xlat_ctx.h>
247#include <freeradius-devel/util/packet.h>
248#include <freeradius-devel/util/proto.h>
249#include <freeradius-devel/util/regex.h>
250
251/*
252 * Allow public and private versions of the same structures
253 */
254#ifdef _CONST
255# error _CONST can only be defined in the local header
256#endif
257#ifndef _TMPL_PRIVATE
258# define _CONST const
259#else
260# define _CONST
261#endif
262
263/** Specify whether attribute references require a prefix
264 *
265 */
266typedef enum {
267 TMPL_ATTR_REF_PREFIX_YES = 0, //!< Attribute refs must have '&' prefix.
268 TMPL_ATTR_REF_PREFIX_NO, //!< Attribute refs have no '&' prefix.
269 TMPL_ATTR_REF_PREFIX_AUTO //!< Attribute refs may have a '&' prefix.
271
272/** Specify whether attribute references can have a list (or parent) reference
273 *
274 */
275typedef enum {
276 TMPL_ATTR_LIST_ALLOW = 0, //!< Attribute refs are allowed to have a list
277 TMPL_ATTR_LIST_FORBID, //!< Attribute refs are forbidden from having a list
278 TMPL_ATTR_LIST_REQUIRE //!< Attribute refs are required to have a list.
280
281/** Define entry and head types for tmpl request references
282 *
283 */
284FR_DLIST_TYPES(tmpl_request_list)
285
287 fr_dict_t const *dict_def; //!< Default dictionary to use
288 ///< with unqualified attribute references.
289
290 fr_dict_attr_t const *namespace; //!< Point in dictionary tree to resume parsing
291 ///< from. If this is provided then dict_def
292 ///< request_def and list_def will be ignored
293 ///< and the presence of any of those qualifiers
294 ///< will be treated as an error.
295
296 FR_DLIST_HEAD(tmpl_request_list) _CONST *request_def; //!< Default request to use with
297 ///< unqualified attribute references.
298 ///< If NULL the request is assumed to
299 ///< but the current request.
300 ///< Usually this will be one of
301 ///< - tmpl_request_def_current
302 ///< - tmpl_request_def_outer
303 ///< - tmpl_request_def_parent
304 ///< If a custom list needs to be
305 ///< used it should be allocated on
306 ///< the stack and a pointer to it
307 ///< placed here.
308
309 fr_dict_attr_t const *list_def; //!< Default list to use with unqualified
310 ///< attribute reference.
311
312 tmpl_attr_prefix_t prefix; //!< Whether the attribute reference requires
313 ///< a prefix.
314
315 tmpl_attr_list_presence_t list_presence; //!< Whether the attribute reference can
316 ///< have a list, forbid it, or require it.
317
318 uint8_t allow_unknown:1; //!< Allow unknown attributes i.e. attributes
319 ///< defined by OID string.
320
321 uint8_t allow_unresolved:1; //!< Allow attributes that look valid but were
322 ///< not found in the dictionaries.
323 ///< This should be used as part of a multi-pass
324 ///< approach to parsing.
325
326 uint8_t allow_wildcard:1; //!< Allow the special case of .[*] representing
327 ///< all children of a structural attribute.
328
329 uint8_t allow_foreign:1; //!< Allow arguments not found in dict_def.
330
331 uint8_t disallow_filters:1; //!< disallow filters.
332
333 uint8_t xlat:1 ; //!< for %{User-Name}
334
335 uint8_t bare_word_enum:1; //!< for v3 compatibility.
336};
337
339 fr_event_list_t *runtime_el; //!< The eventlist to use for runtime instantiation
340 ///< of xlats.
341 bool new_functions; //!< new function syntax
342};
343
344/** Optional arguments passed to vp_tmpl functions
345 *
346 */
348 tmpl_rules_t const *parent; //!< for parent / child relationships
349
350 tmpl_attr_rules_t attr; //!< Rules/data for parsing attribute references.
351 tmpl_xlat_rules_t xlat; //!< Rules/data for parsing xlats.
352
353 fr_dict_attr_t const *enumv; //!< Enumeration attribute used to resolve enum values.
354
355 fr_type_t cast; //!< Whether there was an explicit cast.
356 ///< Used to determine if barewords or other values
357 ///< should be converted to an internal data type.
358
359 bool at_runtime; //!< Produce an ephemeral/runtime tmpl.
360 ///< Instantiated xlats are not added to the global
361 ///< trees, regexes are not JIT'd.
362 fr_value_box_safe_for_t literals_safe_for; //!< safe_for value assigned to literal values in
363 ///< xlats, execs, and data.
364 tmpl_escape_t escape; //!< How escaping should be handled during evaluation.
365};
366
367/** Similar to tmpl_rules_t, but used to specify parameters that may change during subsequent resolution passes
368 *
369 * When a tmpl is parsed initially the rules are stored in the #tmpl_t.
370 *
371 * During subsequent resolution phases where unresolved attributes are resolved to dictionary
372 * attributes the initial #tmpl_rules_t is used to control resolution.
373 *
374 * In some instances however (primarily policies), some rules may need change between initial
375 * parsing and subsequent resolution phases.
376 *
377 * This structure holds rules which may override the tmpl_rules_s during subsequent resolution passes.
378 */
380 fr_dict_t const *dict_def; //!< Alternative default dictionary to use if
381 ///< vpt->rules->dict_def is NULL.
382 //!< Will be written to vpt->rules->dict_def
383 ///< if used.
384
385 bool force_dict_def; //!< Use supplied dict_def even if original
386 ///< vpt->rules->dict_def was not NULL.
387
388 fr_dict_attr_t const *enumv; //!< for resolving T_BARE_WORD
389};
390
391typedef enum {
392 TMPL_ATTR_TYPE_NORMAL = 0, //!< Normal, resolved, attribute ref.
393 TMPL_ATTR_TYPE_UNSPEC, //!< No attribute was specified as this level
394 ///< only a filter.
395 TMPL_ATTR_TYPE_UNKNOWN, //!< We have an attribute number but
396 ///< it doesn't match anything in the
397 ///< dictionary, or isn't a child of
398 ///< the previous ref. May be resolved
399 ///< later.
400 TMPL_ATTR_TYPE_UNRESOLVED //!< We have a name, but nothing else
401 ///< to identify the attribute.
402 ///< may be resolved later.
404
405#define NUM_UNSPEC INT16_MIN
406#define NUM_ALL (INT16_MIN + 1)
407#define NUM_COUNT (INT16_MIN + 2)
408#define NUM_LAST (INT16_MIN + 3)
409
410/** Define entry and head types for attribute reference lists
411 *
412 */
413FR_DLIST_TYPES(tmpl_attr_list)
414
415/** Different types of filter that can be applied to an attribute reference
416 *
417 */
418typedef enum {
419 TMPL_ATTR_FILTER_TYPE_NONE = 0, //!< No filter present.
420 TMPL_ATTR_FILTER_TYPE_INDEX, //!< Filter is an index type.
421 TMPL_ATTR_FILTER_TYPE_CONDITION, //!< Filter is a condition
422 TMPL_ATTR_FILTER_TYPE_TMPL, //!< Filter is a tmpl
423 TMPL_ATTR_FILTER_TYPE_EXPR, //!< Filter is an expression
425
426typedef struct {
427 tmpl_attr_filter_type_t _CONST type; //!< Type of filter this is.
428 int16_t _CONST num; //!< For array references.
429
430 /*
431 * These are "union" because they are disjoint. The "num" field is arguably disjoint, too, but
432 * there is currently a lot of code in tmpl_tokenize.c which directly references ar->ar_num
433 * without checking the type.
434 */
435 union {
436 xlat_exp_head_t _CONST *cond; //!< xlat condition
437 tmpl_t _CONST *tmpl; //!< tmpl
438 xlat_exp_head_t _CONST *expr; //!< xlat expression
439 };
441
442/** An element in a list of nested attribute references
443 *
444 */
445typedef struct {
446 FR_DLIST_ENTRY(tmpl_attr_list) _CONST entry; //!< Entry in the doubly linked list
447 ///< of attribute references.
448
449 fr_dict_attr_t const * _CONST da; //!< Resolved dictionary attribute.
450
451 union {
452 struct {
453 fr_dict_attr_t * _CONST da; //!< Unknown dictionary attribute.
454 } unknown;
455
456 struct {
457 char * _CONST name; //!< Undefined reference type.
458 fr_dict_attr_t const * _CONST namespace; //!< Namespace we should be trying
459 ///< to resolve this attribute in.
460 } unresolved;
461 };
462
463 fr_dict_attr_t const * _CONST parent; //!< The parent we used when trying to
464 ///< resolve the attribute originally.
465 ///< Should point to the referenced
466 ///< attribute.
467
468 unsigned int _CONST resolve_only : 1; //!< This reference and those before it
469 ///< in the list can only be used for
470 ///< resolution, not building out trees.
471 unsigned int _CONST is_raw : 1; /// is a raw reference
472
473 tmpl_attr_type_t _CONST type; //!< Type of attribute reference.
474
475 tmpl_attr_filter_t _CONST filter; //!< Filter associated with the attribute reference.
477
478/** Define manipulation functions for the attribute reference list
479 *
480 */
481FR_DLIST_FUNCS(tmpl_attr_list, tmpl_attr_t, entry)
482
483/** An element in a list of request references
484 *
485 */
486typedef struct {
487 FR_DLIST_ENTRY(tmpl_request_list) _CONST entry; //!< Entry in the doubly linked list
488 ///< of request references.
489
492
493/** Define manipulation functions for the attribute reference list
494 *
495 */
496FR_DLIST_FUNCS(tmpl_request_list, tmpl_request_t, entry)
497
498/** How many additional headers to allocate in a pool for a tmpl_t
499 *
500 */
501#define TMPL_POOL_DEF_HEADERS 4
502
503/** How many additional bytes to allocate in a pool for a tmpl_t
504 *
505 */
506#define TMPL_POOL_DEF_LEN (sizeof(tmpl_t) + 64 + sizeof(tmpl_attr_t) + sizeof(tmpl_request_t))
507
508/** @name Field accessors for attribute references
509 *
510 * @{
511 */
512#define ar_type type
513#define ar_depth depth
514#define ar_da da
515#define ar_parent parent
516#define ar_unknown unknown.da
517#define ar_unresolved unresolved.name
518#define ar_unresolved_namespace unresolved.namespace
519
520#define ar_is_normal(_ar) ((_ar)->ar_type == TMPL_ATTR_TYPE_NORMAL)
521#define ar_is_unspecified(_ar) ((_ar)->ar_type == TMPL_ATTR_TYPE_UNSPEC)
522#define ar_is_unknown(_ar) ((_ar)->ar_type == TMPL_ATTR_TYPE_UNKNOWN)
523#define ar_is_unresolved(_ar) ((_ar)->ar_type == TMPL_ATTR_TYPE_UNRESOLVED)
524#define ar_is_raw(_ar) ((_ar)->is_raw)
525
526#define ar_num filter.num
527#define ar_cond filter.cond
528#define ar_tmpl filter.tmpl
529#define ar_expr filter.expr
530#define ar_filter_type filter.type
531
532#define ar_filter_is_none(_ar) ((_ar)->ar_filter_type == TMPL_ATTR_FILTER_TYPE_NONE)
533#define ar_filter_is_num(_ar) ((_ar)->ar_filter_type == TMPL_ATTR_FILTER_TYPE_INDEX)
534#define ar_filter_is_cond(_ar) ((_ar)->ar_filter_type == TMPL_ATTR_FILTER_TYPE_CONDITION)
535#define ar_filter_is_tmpl(_ar) ((_ar)->ar_filter_type == TMPL_ATTR_FILTER_TYPE_TMPL)
536#define ar_filter_is_expr(_ar) ((_ar)->ar_filter_type == TMPL_ATTR_FILTER_TYPE_EXPR)
537/** @} */
538
539/** A source or sink of value data.
540 *
541 * Is used as both the RHS and LHS of a map (both update, and conditional types)
542 *
543 * @section update_maps Use in update map_t
544 * When used on the LHS it describes an attribute to create and should be one of these types:
545 * - #TMPL_TYPE_ATTR
546 *
547 * When used on the RHS it describes the value to assign to the attribute being created and
548 * should be one of these types:
549 * - #TMPL_TYPE_DATA_UNRESOLVED
550 * - #TMPL_TYPE_XLAT_UNRESOLVED
551 * - #TMPL_TYPE_ATTR
552 * - #TMPL_TYPE_EXEC
553 * - #TMPL_TYPE_DATA
554 * - #TMPL_TYPE_XLAT (pre-parsed xlat)
555 *
556 * @section conditional_maps Use in conditional map_t
557 * When used as part of a condition it may be any of the RHS side types, as well as:
558 * - #TMPL_TYPE_REGEX (pre-parsed regex)
559 *
560 * @see map_t
561 */
562struct tmpl_s {
563 tmpl_type_t _CONST type; //!< What type of value tmpl refers to.
564
565 char const * _CONST name; //!< Raw string used to create the template.
566 ///< this string will have any escape sequences left intact.
567 size_t _CONST len; //!< Length of the raw string used to create the template.
568 fr_token_t _CONST quote; //!< What type of quoting was around the raw string.
569
570 union {
571 char *unescaped; //!< Unescaped form of the name, used for TMPL_TYPE_DATA_UNRESOLVED
572 ///< and TMPL_TYPE_REGEX_UNCOMPILED.
573
574 _CONST struct {
575 bool ref_prefix; //!< true if the reference was prefixed
576 ///< with a '&'.
577 FR_DLIST_HEAD(tmpl_request_list) rr; //!< Request to search or insert in.
578 FR_DLIST_HEAD(tmpl_attr_list) ar; //!< Head of the attribute reference list.
579 } attribute;
580
581 /*
582 * Attribute value. Typically used as the RHS of an update map.
583 */
584 fr_value_box_t literal; //!< Value data.
585
586 struct {
587 union {
588 _CONST struct {
589 xlat_exp_head_t *ex; //!< pre-parsed xlat expansion
590 ///< and expansion.
591 } xlat;
592#ifdef HAVE_REGEX
593 _CONST struct {
594 char *src; //!< Original unescaped source string.
595 regex_t *ex; //!< pre-parsed regex_t
596 bool subcaptures; //!< Whether the regex was compiled with
597 ///< subcaptures.
598 } reg;
599#endif
600 };
601 fr_regex_flags_t reg_flags; //!< Flags for regular expressions.
602 ///< Used by:
603 ///< - TMPL_TYPE_REGEX_XLAT
604 ///< - TMPL_TYPE_REGEX_UNCOMPILED
605 ///< - TMPL_TYPE_REGEX
606 ///< - TMPL_TYPE_REGEX_XLAT_UNRESOLVED
607 };
609
610 tmpl_rules_t _CONST rules; //!< The rules that were used when creating the tmpl.
611 ///< These are useful for multiple resolution passes as
612 ///< they ensure the correct parsing rules are applied.
613};
614
615/** Describes the current extents of a pair tree in relation to the tree described by a tmpl_t
616 *
617 */
618typedef struct {
619 fr_dlist_t entry; //!< Entry in the dlist of extents
620
621 tmpl_attr_t const *ar; //!< Attribute representing the ar
622 ///< after the deepest node that was found
623 ///< in the existing pair tree when evaluating
624 ///< this path. If this is NULL, then all ars
625 ///< were evaluated.
626
627 TALLOC_CTX *list_ctx; //!< Where to allocate new attributes if building
628 ///< out from the current extents of the tree.
629 fr_pair_list_t *list; //!< List that we tried to evaluate ar in and failed.
630 ///< Or if ar is NULL, the list that represents the
631 ///< deepest grouping or TLV attribute the chain of
632 ///< ars referenced.
634
635/** Convenience macro for printing a meaningful assert message when we get a bad tmpl type
636 */
637#define tmpl_assert_type(_cond) \
638 fr_assert_msg(_cond, "Unexpected tmpl type '%s'", \
639 tmpl_type_to_str(vpt->type))
640
641
642/** @name Functions for printing and parsing tmpl type names
643 *
644 * @{
645 */
646/** Return a static string containing the type name
647 *
648 * @param[in] type to return name for.
649 * @return name of the type
650 */
651static inline char const *tmpl_type_to_str(tmpl_type_t type)
652{
653 return fr_table_str_by_value(tmpl_type_table, type, "<INVALID>");
654}
655
656/** Return the constant value representing a type
657 *
658 * @param[in] type to return the constant value for.
659 * @return The constant type value or TMPL_TYPE_UNINITIALISED if no type matches.
660 */
665/** @} */
666
667/** @name Field accessors for #TMPL_TYPE_ATTR, #TMPL_TYPE_ATTR_UNRESOLVED
668 *
669 * @{
670 */
671 #define tmpl_attr(_tmpl) &(_tmpl)->data.attribute.ar
672
673static inline FR_DLIST_HEAD(tmpl_request_list) const *tmpl_request(tmpl_t const *vpt)
674{
677
678 return &vpt->data.attribute.rr;
679}
680
681/** The number of request references contained within a tmpl
682 *
683 */
684static inline size_t tmpl_request_ref_count(tmpl_t const *vpt)
685{
688
689 return tmpl_request_list_num_elements(&vpt->data.attribute.rr);
690}
691
692/** Return true if the tmpl_attr is one of the list types
693 *
694 * @hidecallergraph
695*/
696static inline bool tmpl_attr_is_list_attr(tmpl_attr_t const *ar)
697{
698 if (!ar || !ar_is_normal(ar)) return false;
699
700 return (ar->ar_da == request_attr_request) ||
701 (ar->ar_da == request_attr_reply) ||
702 (ar->ar_da == request_attr_control) ||
703 (ar->ar_da == request_attr_state) ||
704 (ar->ar_da == request_attr_local);
705}
706
707/** Return true if the head attribute reference is a list reference
708 *
709 * @hidecallergraph
710 */
711static inline bool tmpl_attr_head_is_list(tmpl_t const *vpt)
712{
713 tmpl_attr_t *ar;
714
716
717 ar = tmpl_attr_list_head(tmpl_attr(vpt));
718 if (unlikely(!ar)) return false;
719
720 return tmpl_attr_is_list_attr(ar);
721}
722
723/** Return true if the last attribute reference is "normal"
724 *
725 * @hidecallergraph
726 */
727static inline bool tmpl_attr_tail_is_normal(tmpl_t const *vpt)
728{
729 tmpl_attr_t *ar;
730
732
733 ar = tmpl_attr_list_tail(tmpl_attr(vpt));
734 if (unlikely(!ar)) return false;
735
736 return ar_is_normal(ar);
737}
738
739/** Return true if the last attribute reference is "unspecified"
740 *
741 * @hidecallergraph
742 */
743static inline bool tmpl_attr_tail_is_unspecified(tmpl_t const *vpt)
744{
745 tmpl_attr_t *ar;
746
748
749 ar = tmpl_attr_list_tail(tmpl_attr(vpt));
750 if (unlikely(!ar)) return false;
751
752 return ar_is_unspecified(ar);
753}
754
755/** Return true if the last attribute reference is "unknown"
756 *
757 * @hidecallergraph
758 */
759static inline bool tmpl_attr_tail_is_unknown(tmpl_t const *vpt)
760{
761 tmpl_attr_t *ar;
762
764
765 ar = tmpl_attr_list_tail(tmpl_attr(vpt));
766 if (unlikely(!ar)) return false;
767
768 return ar_is_unknown(ar);
769}
770
771/** Return true if the last attribute reference is "unresolved"
772 *
773 * @hidecallergraph
774 */
775static inline bool tmpl_attr_tail_is_unresolved(tmpl_t const *vpt)
776{
777 tmpl_attr_t *ar;
778
780
781 ar = tmpl_attr_list_tail(tmpl_attr(vpt));
782 if (unlikely(!ar)) return false;
783
784 return ar_is_unresolved(ar);
785}
786
787/** Return true if the last attribute reference is "raw"
788 *
789 * @hidecallergraph
790 */
791static inline bool tmpl_attr_tail_is_raw(tmpl_t const *vpt)
792{
793 tmpl_attr_t *ar;
794
796
797 ar = tmpl_attr_list_tail(tmpl_attr(vpt));
798 if (unlikely(!ar)) return false;
799
800 return ar_is_raw(ar);
801}
802
803/** Return the last attribute reference
804 *
805 * @hidecallergraph
806 */
807static inline tmpl_attr_t const *tmpl_attr_tail(tmpl_t const *vpt)
808{
810
811 return tmpl_attr_list_tail(tmpl_attr(vpt));
812}
813
814/** Return the last attribute reference da
815 *
816 * @hidecallergraph
817 */
818static inline fr_dict_attr_t const *tmpl_attr_tail_da(tmpl_t const *vpt)
819{
820 tmpl_attr_t *ar;
821
823
824 ar = tmpl_attr_list_tail(tmpl_attr(vpt));
825 if (!ar) return NULL;
826
827 return ar->ar_da;
828}
829
830/** Return true if the the last attribute reference is a leaf attribute
831 *
832 * @hidecallergraph
833 */
834static inline bool tmpl_attr_tail_da_is_leaf(tmpl_t const *vpt)
835{
836 tmpl_attr_t *ar;
837
839
840 ar = tmpl_attr_list_tail(tmpl_attr(vpt));
841 if (!ar) return false;
842
844
845 return fr_type_is_leaf(ar->ar_da->type);
846}
847
848/** Return true if the the last attribute reference is a structural attribute
849 *
850 * @hidecallergraph
851 */
853{
854 tmpl_attr_t *ar;
855
857
858 ar = tmpl_attr_list_tail(tmpl_attr(vpt));
859 if (!ar) return false;
860
862
863 return fr_type_is_structural(ar->ar_da->type);
864}
865
866/** Return the last attribute reference unknown da
867 *
868 * @hidecallergraph
869 */
871{
872 tmpl_attr_t *ar;
873
875
876 ar = tmpl_attr_list_tail(tmpl_attr(vpt));
877 if (!ar) return NULL;
878
879 return ar->ar_unknown;
880}
881
882/** Return the last attribute reference unresolved da
883 *
884 * @hidecallergraph
885 */
886static inline char const *tmpl_attr_tail_unresolved(tmpl_t const *vpt)
887{
888 tmpl_attr_t *ar;
889
891
892 ar = tmpl_attr_list_tail(tmpl_attr(vpt));
893 if (!ar) return NULL;
894
895 return ar->ar_unresolved;
896}
897
898/** Return the last attribute reference's attribute number
899 *
900 * @hidecallergraph
901 */
902static inline int16_t tmpl_attr_tail_num(tmpl_t const *vpt)
903{
906
907 return tmpl_attr_list_tail(tmpl_attr(vpt))->ar_num;
908}
909
910/** The number of attribute references contained within a tmpl
911 *
912 */
913static inline size_t tmpl_attr_num_elements(tmpl_t const *vpt)
914{
917
918 return tmpl_attr_list_num_elements(tmpl_attr(vpt));
919}
920
921static inline fr_dict_attr_t const *tmpl_list(tmpl_t const *vpt)
922{
923 if (!tmpl_attr_head_is_list(vpt)) return NULL;
924
925 return tmpl_attr_list_head(tmpl_attr(vpt))->ar_da;
926}
927/** @} */
928
929/** Return the name of a tmpl list or def if list not provided
930 *
931*/
932static inline char const *tmpl_list_name(fr_dict_attr_t const *list, char const *def)
933{
934 return (list ? list->name : def);
935}
936
937static inline bool tmpl_is_list(tmpl_t const *vpt)
938{
939 if (!tmpl_is_attr(vpt)) return false;
941}
942
943/** @name Field accessors for #TMPL_TYPE_XLAT
944 *
945 * @{
946 */
947#define tmpl_xlat(_tmpl) (_tmpl)->data.xlat.ex
948/** @} */
949
950/** @name Field accessors for #TMPL_TYPE_DATA
951 *
952 * @{
953 */
954#define tmpl_value(_tmpl) (&(_tmpl)->data.literal)
955#define tmpl_value_length(_tmpl) (_tmpl)->data.literal.vb_length
956#define tmpl_value_type(_tmpl) (_tmpl)->data.literal.type
957#define tmpl_value_enumv(_tmpl) (_tmpl)->data.literal.enumv
958
959#define tmpl_rules_cast(_tmpl) (_tmpl)->rules.cast
960#define tmpl_rules_enumv(_tmpl) (_tmpl)->rules.enumv
961/** @} */
962
963/** @name Field accessors for #TMPL_TYPE_REGEX and #TMPL_TYPE_REGEX_XLAT_UNRESOLVED
964 *
965 * @{
966 */
967#ifdef HAVE_REGEX
968# define tmpl_regex(_tmpl) (_tmpl)->data.reg.ex //!< #TMPL_TYPE_REGEX only.
969# define tmpl_regex_flags(_tmpl) (&(_tmpl)->data.reg_flags)
970#endif
971/** @} */
972
973#ifndef WITH_VERIFY_PTR
974# define TMPL_ATTR_VERIFY(_vpt)
975# define TMPL_VERIFY(_vpt)
976#else
977# define TMPL_ATTR_VERIFY(_vpt) tmpl_attr_verify(__FILE__, __LINE__, _vpt)
978# define TMPL_VERIFY(_vpt) tmpl_verify(__FILE__, __LINE__, _vpt)
979void tmpl_attr_verify(char const *file, int line, tmpl_t const *vpt);
980void tmpl_verify(char const *file, int line, tmpl_t const *vpt);
981#endif
982
983/** Determine the correct context and list head
984 *
985 * Used in conjunction with the fr_dcursor functions to determine the correct list
986 * and TALLOC_CTX for inserting fr_pair_ts.
987 *
988 * Example:
989 @code{.c}
990 TALLOC_CTX *ctx;
991 fr_pair_list_t *head;
992 fr_value_box_t value;
993
994 tmpl_pair_list_and_ctx(ctx, head, request, CURRENT_REQUEST, request_attr_request);
995 if (!list) return -1; // error
996
997 value.strvalue = talloc_typed_strdup(NULL, "my new username");
998 value.length = talloc_array_length(value.strvalue) - 1;
999 @endcode
1000 *
1001 * @param _ctx new #fr_pair_t s should be allocated in for the specified list.
1002 * @param _head of the #fr_pair_t list.
1003 * @param _request The current request.
1004 * @param _ref to resolve.
1005 * @param _list to resolve.
1006 */
1007#define tmpl_pair_list_and_ctx(_ctx, _head, _request, _ref, _list) \
1008do {\
1009 request_t *_rctx = _request; \
1010 if ((tmpl_request_ptr(&_rctx, _ref) < 0) || \
1011 !(_head = tmpl_list_head(_rctx, _list)) || \
1012 !(_ctx = tmpl_list_ctx(_rctx, _list))) {\
1013 _ctx = NULL; \
1014 _head = NULL; \
1015 }\
1016} while (0)
1017
1018typedef enum {
1019 TMPL_ATTR_ERROR_NONE = 0, //!< No error.
1020 TMPL_ATTR_ERROR_EMPTY, //!< Attribute ref contains no data.
1021 TMPL_ATTR_ERROR_BAD_PREFIX, //!< Missing '&' or has '&' when it shouldn't.
1022 TMPL_ATTR_ERROR_LIST_NOT_ALLOWED, //!< List qualifier is not allowed here.
1023 TMPL_ATTR_ERROR_LIST_MISSING, //!< List qualifier is required, but missing.
1024 TMPL_ATTR_ERROR_UNKNOWN_NOT_ALLOWED, //!< Attribute specified as OID, could not be
1025 ///< found in the dictionaries, and is disallowed
1026 ///< because 'disallow_internal' in tmpl_rules_t
1027 ///< is trie.
1028 TMPL_ATTR_ERROR_UNRESOLVED_NOT_ALLOWED, //!< Attribute couldn't be found in the dictionaries.
1029 TMPL_ATTR_ERROR_UNQUALIFIED_NOT_ALLOWED, //!< Attribute must be qualified to be used here.
1030 TMPL_ATTR_ERROR_INVALID_NAME, //!< Attribute ref length is zero, or longer than
1031 ///< the maximum.
1032 TMPL_ATTR_ERROR_INTERNAL_NOT_ALLOWED, //!< Attribute resolved to an internal attribute
1033 ///< which is disallowed.
1034 TMPL_ATTR_ERROR_FOREIGN_NOT_ALLOWED, //!< Attribute resolved in a dictionary different
1035 ///< to the one specified.
1036 TMPL_ATTR_ERROR_FILTER_NOT_ALLOWED, //!< Filters disallowed by rules.
1037 TMPL_ATTR_ERROR_INVALID_ARRAY_INDEX, //!< Invalid array index.
1039 TMPL_ATTR_ERROR_NESTING_TOO_DEEP, //!< Too many levels of nesting.
1040 TMPL_ATTR_ERROR_MISSING_TERMINATOR, //!< Unexpected text found after attribute reference
1041 TMPL_ATTR_ERROR_BAD_CAST //!< Specified cast was invalid.
1043
1044/** Map ptr type to a boxed type
1045 *
1046 */
1047#define FR_TYPE_FROM_PTR(_ptr) \
1048 _Generic((_ptr), \
1049 char **: FR_TYPE_STRING, \
1050 char const **: FR_TYPE_STRING, \
1051 uint8_t **: FR_TYPE_OCTETS, \
1052 uint8_t const **: FR_TYPE_OCTETS, \
1053 uint8_t *: FR_TYPE_UINT8, \
1054 uint16_t *: FR_TYPE_UINT16, \
1055 uint32_t *: FR_TYPE_UINT32, \
1056 uint64_t *: FR_TYPE_UINT64, \
1057 fr_value_box_t **: FR_TYPE_VALUE_BOX, \
1058 fr_value_box_t const **: FR_TYPE_VALUE_BOX)
1059
1060/** Expand a tmpl to a C type, using existing storage to hold variably sized types
1061 *
1062 * Expands a template using the _out ptr to determinate the cast type.
1063 *
1064 * @see _tmpl_to_type
1065 */
1066#define tmpl_expand(_out, _buff, _buff_len, _request, _vpt, _escape, _escape_ctx) \
1067 _tmpl_to_type((void *)(_out), (uint8_t *)_buff, _buff_len, \
1068 _request, _vpt, _escape, _escape_ctx, FR_TYPE_FROM_PTR(_out))
1069
1070/** Expand a tmpl to a C type, allocing a new buffer to hold the string
1071 *
1072 * Expands a template using the _out ptr to determinate the cast type.
1073 *
1074 * @see _tmpl_to_atype
1075 */
1076#define tmpl_aexpand(_ctx, _out, _request, _vpt, _escape, _escape_ctx) \
1077 _tmpl_to_atype(_ctx, (void *)(_out), _request, _vpt, _escape, _escape_ctx, FR_TYPE_FROM_PTR(_out))
1078
1079/** Expand a tmpl to a C type, allocing a new buffer to hold the string
1080 *
1081 * Takes an explicit type which must match the ctype pointed to by out.
1082 *
1083 * @see _tmpl_to_atype
1084 */
1085#define tmpl_aexpand_type(_ctx, _out, _type, _request, _vpt, _escape, _escape_ctx) \
1086 _tmpl_to_atype(_ctx, (void *)(_out), _request, _vpt, _escape, _escape_ctx, _type)
1087
1088void tmpl_debug(tmpl_t const *vpt) CC_HINT(nonnull);
1089
1091
1092fr_packet_t *tmpl_packet_ptr(request_t *request, fr_dict_attr_t const *list) CC_HINT(nonnull);
1093
1094TALLOC_CTX *tmpl_list_ctx(request_t *request, fr_dict_attr_t const *list);
1095
1097
1098tmpl_t *tmpl_init_printf(tmpl_t *vpt, tmpl_type_t type, fr_token_t quote, char const *fmt, ...) CC_HINT(nonnull(1,4));
1099
1101 char const *name, ssize_t len,
1102 tmpl_rules_t const *t_rules) CC_HINT(nonnull(1,4));
1103
1105 char const *name, ssize_t len,
1106 tmpl_rules_t const *t_rules) CC_HINT(nonnull(1,4));
1107
1108tmpl_t *tmpl_alloc(TALLOC_CTX *ctx, tmpl_type_t type, fr_token_t quote, char const *name, ssize_t len);
1109
1110/** @name Parse request qualifiers
1111 *
1112 * @{
1113 */
1114/** Static default request ref list for the current request
1115 *
1116 * Passed as request_def in tmpl_attr_rules_t.
1117 */
1118extern FR_DLIST_HEAD(tmpl_request_list) tmpl_request_def_current;
1119
1120/** Static default request ref list for the outer request
1121 *
1122 * Passed as request_def in tmpl_attr_rules_t.
1123 */
1124extern FR_DLIST_HEAD(tmpl_request_list) tmpl_request_def_outer;
1125
1126/** Static default request ref list for the parent request
1127 *
1128 * Passed as request_def in tmpl_attr_rules_t.
1129 */
1130extern FR_DLIST_HEAD(tmpl_request_list) tmpl_request_def_parent;
1131
1132int tmpl_request_ptr(request_t **request, FR_DLIST_HEAD(tmpl_request_list) const *rql) CC_HINT(nonnull);
1133
1134void tmpl_request_ref_list_debug(FR_DLIST_HEAD(tmpl_request_list) const *rql);
1135
1136int8_t tmpl_request_ref_list_cmp(FR_DLIST_HEAD(tmpl_request_list) const *a,
1137 FR_DLIST_HEAD(tmpl_request_list) const *b);
1138
1139/** Returns true if the specified qualifier list points to the current request
1140 *
1141 * @param[in] _list to check.
1142 * @return
1143 * - true if the list only contains a current request qualifier.
1144 * - false otherwise.
1145 */
1146#define tmpl_request_ref_is_current(_list) (tmpl_request_ref_list_cmp(_list, &tmpl_request_def_current) == 0)
1147
1148/** Returns true if the specified qualifier list points to the parent request
1149 *
1150 * @param[in] _list to check.
1151 * @return
1152 * - true if the list only contains a parent request qualifier.
1153 * - false otherwise.
1154 */
1155#define tmpl_request_ref_is_parent(_list) (tmpl_request_ref_list_cmp(_list, &tmpl_request_def_parent) == 0)
1156
1157/** Returns true if the specified qualifier list points to the outer request
1158 *
1159 * @param[in] _list to check.
1160 * @return
1161 * - true if the list only contains a outer request qualifier.
1162 * - false otherwise.
1163 */
1164#define tmpl_request_ref_is_outer(_list) (tmpl_request_ref_list_cmp(_list, &tmpl_request_def_outer) == 0)
1165
1166
1168 FR_DLIST_HEAD(tmpl_request_list) _CONST **out,
1169 fr_sbuff_t *in);
1170/** @} */
1171
1172void tmpl_set_name_printf(tmpl_t *vpt, fr_token_t quote, char const *fmt, ...) CC_HINT(nonnull(1,3));
1173
1174void tmpl_set_name_shallow(tmpl_t *vpt, fr_token_t quote, char const *name, ssize_t len) CC_HINT(nonnull);
1175
1176void tmpl_set_name(tmpl_t *vpt, fr_token_t quote, char const *name, ssize_t len) CC_HINT(nonnull);
1177
1178void tmpl_set_dict_def(tmpl_t *vpt, fr_dict_t const *dict) CC_HINT(nonnull);
1179
1180void tmpl_set_escape(tmpl_t *vpt, tmpl_escape_t const *escape) CC_HINT(nonnull);
1181
1182void tmpl_set_xlat(tmpl_t *vpt, xlat_exp_head_t *xlat) CC_HINT(nonnull);
1183
1184int tmpl_afrom_value_box(TALLOC_CTX *ctx, tmpl_t **out, fr_value_box_t *data, bool steal) CC_HINT(nonnull);
1185
1186void tmpl_attr_ref_debug(const tmpl_attr_t *ar, int idx) CC_HINT(nonnull);
1187
1188void tmpl_attr_ref_list_debug(FR_DLIST_HEAD(tmpl_attr_list) const *ar_head) CC_HINT(nonnull);
1189
1190void tmpl_attr_debug(tmpl_t const *vpt) CC_HINT(nonnull);
1191
1192int tmpl_attr_copy(tmpl_t *dst, tmpl_t const *src) CC_HINT(nonnull);
1193
1194int tmpl_attr_set_da(tmpl_t *vpt, fr_dict_attr_t const *da) CC_HINT(nonnull);
1195
1196int tmpl_attr_set_leaf_da(tmpl_t *vpt, fr_dict_attr_t const *da) CC_HINT(nonnull);
1197
1198void tmpl_attr_rewrite_leaf_num(tmpl_t *vpt, int16_t num) CC_HINT(nonnull);
1199
1200void tmpl_attr_set_request_ref(tmpl_t *vpt, FR_DLIST_HEAD(tmpl_request_list) const *request_def) CC_HINT(nonnull);
1201
1202void tmpl_attr_set_list(tmpl_t *vpt, fr_dict_attr_t const *list) CC_HINT(nonnull);
1203
1204int tmpl_attr_afrom_list(TALLOC_CTX *ctx, tmpl_t **out, tmpl_t const *list,
1205 fr_dict_attr_t const *da) CC_HINT(nonnull);
1206
1207/** @name Produce a #tmpl_t from a string or substring
1208 *
1209 * @{
1210 */
1213 fr_sbuff_parse_rules_t const *p_rules,
1214 tmpl_rules_t const *t_rules) CC_HINT(nonnull(3,4));
1215
1217 tmpl_t **out, char const *name,
1218 tmpl_rules_t const *rules) CC_HINT(nonnull (3, 4));
1219
1220ssize_t tmpl_afrom_substr(TALLOC_CTX *ctx, tmpl_t **out,
1221 fr_sbuff_t *in,
1222 fr_token_t quote,
1223 fr_sbuff_parse_rules_t const *p_rules,
1224 tmpl_rules_t const *t_rules) CC_HINT(nonnull(2,3));
1225
1226tmpl_t *tmpl_copy(TALLOC_CTX *ctx, tmpl_t const *in) CC_HINT(nonnull);
1227
1228ssize_t tmpl_cast_from_substr(tmpl_rules_t *t_rules, fr_sbuff_t *in) CC_HINT(nonnull(2)); /* Parses cast string */
1229
1230int tmpl_cast_set(tmpl_t *vpt, fr_type_t type) CC_HINT(nonnull); /* Sets cast type */
1231
1233{
1234 return vpt->rules.cast;
1235}
1236
1237#ifdef HAVE_REGEX
1238ssize_t tmpl_regex_flags_substr(tmpl_t *vpt, fr_sbuff_t *in,
1239 fr_sbuff_term_t const *terminals) CC_HINT(nonnull(1,2));
1240#endif
1241/** @} */
1242
1243/** @name Change a #tmpl_t type, usually by casting or resolving a reference
1244 * @{
1245 */
1246int tmpl_cast_in_place(tmpl_t *vpt, fr_type_t type, fr_dict_attr_t const *enumv) CC_HINT(nonnull(1));
1247
1248int tmpl_resolve(tmpl_t *vpt, tmpl_res_rules_t const *tr_rules) CC_HINT(nonnull(1));
1249
1250void tmpl_unresolve(tmpl_t *vpt) CC_HINT(nonnull);
1251
1252int tmpl_attr_to_xlat(TALLOC_CTX *ctx, tmpl_t **vpt_p) CC_HINT(nonnull);
1253
1254void tmpl_attr_to_raw(tmpl_t *vpt) CC_HINT(nonnull);
1255
1257
1259 fr_type_t type, fr_dict_attr_flags_t const *flags) CC_HINT(nonnull(1));
1260
1261#ifdef HAVE_REGEX
1262ssize_t tmpl_regex_compile(tmpl_t *vpt, bool subcaptures) CC_HINT(nonnull);
1263#endif
1264/** @} */
1265
1266/** @name Print the contents of a #tmpl_t
1267 * @{
1268 */
1269fr_slen_t tmpl_request_ref_list_print(fr_sbuff_t *out, FR_DLIST_HEAD(tmpl_request_list) const *rql)
1270 CC_HINT(nonnull(1,2));
1271
1272static inline fr_slen_t tmpl_request_ref_list_aprint(TALLOC_CTX *ctx, char **out, FR_DLIST_HEAD(tmpl_request_list) const *rql)
1274
1276
1277static inline fr_slen_t tmpl_attr_aprint(TALLOC_CTX *ctx, char **out, tmpl_t const *vpt, tmpl_attr_prefix_t ar_prefix)
1279
1281 tmpl_attr_prefix_t ar_prefix, fr_sbuff_escape_rules_t const *e_rules) CC_HINT(nonnull(1,2));
1282
1283static inline fr_slen_t tmpl_aprint(TALLOC_CTX *ctx, char **out, tmpl_t const *vpt,
1286
1288
1289static inline fr_slen_t tmpl_aprint_quoted(TALLOC_CTX *ctx, char **out, tmpl_t const *vpt, tmpl_attr_prefix_t ar_prefix)
1291/** @} */
1292
1293/** @name Expand the tmpl, returning one or more values
1294 * @{
1295 */
1297
1299 uint8_t *buff, size_t outlen,
1300 request_t *request,
1301 tmpl_t const *vpt,
1302 xlat_escape_legacy_t escape, void const *escape_ctx,
1303 fr_type_t dst_type)
1304 CC_HINT(nonnull (1, 4, 5));
1305
1306ssize_t _tmpl_to_atype(TALLOC_CTX *ctx, void *out,
1307 request_t *request,
1308 tmpl_t const *vpt,
1309 xlat_escape_legacy_t escape, void const *escape_ctx,
1310 fr_type_t dst_type)
1311 CC_HINT(nonnull (2, 3, 4));
1312
1313int tmpl_copy_pairs(TALLOC_CTX *ctx, fr_pair_list_t *out,
1314 request_t *request, tmpl_t const *vpt) CC_HINT(nonnull(2,3,4));
1315
1316int tmpl_copy_pair_children(TALLOC_CTX *ctx, fr_pair_list_t *out,
1317 request_t *request, tmpl_t const *vpt) CC_HINT(nonnull(2,3,4));
1318
1319int tmpl_find_vp(fr_pair_t **out, request_t *request, tmpl_t const *vpt) CC_HINT(nonnull(2,3));
1320
1321int tmpl_find_or_add_vp(fr_pair_t **out, request_t *request, tmpl_t const *vpt) CC_HINT(nonnull);
1322
1323int pair_append_by_tmpl_parent(TALLOC_CTX *ctx, fr_pair_t **out, fr_pair_list_t *list,
1324 tmpl_t const *vpt, bool skip_list) CC_HINT(nonnull(1,3,4));
1325
1326int tmpl_extents_find(TALLOC_CTX *ctx,
1327 fr_dlist_head_t *leaf, fr_dlist_head_t *interior,
1328 request_t *request, tmpl_t const *vpt) CC_HINT(nonnull(5));
1329
1331 tmpl_t const *vpt) CC_HINT(nonnull);
1332
1334
1335int tmpl_eval_pair(TALLOC_CTX *ctx, fr_value_box_list_t *out, request_t *request, tmpl_t const *vpt);
1336
1337int tmpl_eval(TALLOC_CTX *ctx, fr_value_box_list_t *out, request_t *request, tmpl_t const *vpt);
1338
1339int tmpl_eval_cast_in_place(fr_value_box_list_t *out, request_t *request, tmpl_t const *vpt);
1340/** @} */
1341
1342ssize_t tmpl_preparse(char const **out, size_t *outlen, char const *in, size_t inlen,
1343 fr_token_t *type) CC_HINT(nonnull(1,2,3,5));
1344
1345bool tmpl_async_required(tmpl_t const *vpt) CC_HINT(nonnull);
1346
1347int tmpl_value_list_insert_tail(fr_value_box_list_t *list, fr_value_box_t *vb, tmpl_t const *vpt) CC_HINT(nonnull);
1348
1349void tmpl_rules_child_init(TALLOC_CTX *ctx, tmpl_rules_t *out, tmpl_rules_t const *parent, tmpl_t *vpt) CC_HINT(nonnull);
1350
1351void tmpl_rules_debug(tmpl_rules_t const *rules) CC_HINT(nonnull);
1352
1353int tmpl_global_init(void);
1354
1355#undef _CONST
1356
1357#ifdef __cplusplus
1358}
1359#endif
int const char * file
Definition acutest.h:702
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
#define unlikely(_x)
Definition build.h:381
static fr_slen_t err
Definition dict.h:823
static fr_slen_t in
Definition dict.h:823
Values of the encryption flags.
#define FR_DLIST_TYPES(_name)
Define type specific wrapper structs for dlists.
Definition dlist.h:1129
#define FR_DLIST_FUNCS(_name, _element_type, _element_entry)
Define type specific wrapper functions for dlists.
Definition dlist.h:1152
#define FR_DLIST_HEAD(_name)
Expands to the type name used for the head wrapper structure.
Definition dlist.h:1122
Head of a doubly linked list.
Definition dlist.h:51
Entry in a doubly linked list.
Definition dlist.h:41
Stores all information relating to an event list.
Definition event.c:411
tmpl_attr_prefix_t
size_t(* xlat_escape_legacy_t)(request_t *request, char *out, size_t outlen, char const *in, void *arg)
fr_type_t
long int ssize_t
unsigned char uint8_t
ssize_t fr_slen_t
#define fr_assert(_expr)
Definition rad_assert.h:38
fr_dict_attr_t const * request_attr_request
Definition request.c:45
fr_dict_attr_t const * request_attr_control
Definition request.c:47
fr_dict_attr_t const * request_attr_local
Definition request.c:49
fr_dict_attr_t const * request_attr_state
Definition request.c:48
fr_dict_attr_t const * request_attr_reply
Definition request.c:46
static char const * name
#define SBUFF_OUT_TALLOC_FUNC_NO_LEN_DEF(_func,...)
Set of terminal elements.
int8_t tmpl_request_ref_list_cmp(FR_DLIST_HEAD(tmpl_request_list) const *a, FR_DLIST_HEAD(tmpl_request_list) const *b)
Compare a list of request qualifiers.
int tmpl_find_vp(fr_pair_t **out, request_t *request, tmpl_t const *vpt))
Returns the first VP matching a tmpl_t.
Definition tmpl_eval.c:889
static fr_slen_t tmpl_attr_aprint(TALLOC_CTX *ctx, char **out, tmpl_t const *vpt, tmpl_attr_prefix_t ar_prefix) 1(tmpl_attr_print
void tmpl_request_ref_list_debug(FR_DLIST_HEAD(tmpl_request_list) const *rql)
Dump a request list to stderr.
static fr_slen_t ar_prefix
Definition tmpl.h:1285
static tmpl_attr_t const * tmpl_attr_tail(tmpl_t const *vpt)
Return the last attribute reference.
Definition tmpl.h:807
static int16_t tmpl_attr_tail_num(tmpl_t const *vpt)
Return the last attribute reference's attribute number.
Definition tmpl.h:902
void tmpl_attr_set_list(tmpl_t *vpt, fr_dict_attr_t const *list)
tmpl_attr_prefix_t
Specify whether attribute references require a prefix.
Definition tmpl.h:266
@ TMPL_ATTR_REF_PREFIX_NO
Attribute refs have no '&' prefix.
Definition tmpl.h:268
@ TMPL_ATTR_REF_PREFIX_AUTO
Attribute refs may have a '&' prefix.
Definition tmpl.h:269
@ TMPL_ATTR_REF_PREFIX_YES
Attribute refs must have '&' prefix.
Definition tmpl.h:267
#define ar_is_unspecified(_ar)
Definition tmpl.h:521
static char const * tmpl_type_to_str(tmpl_type_t type)
Return a static string containing the type name.
Definition tmpl.h:651
void tmpl_unresolve(tmpl_t *vpt)
Reset the tmpl, leaving only the name in place.
#define tmpl_is_attr_unresolved(vpt)
Definition tmpl.h:224
enum requests_ref_e tmpl_request_ref_t
void tmpl_set_name_printf(tmpl_t *vpt, fr_token_t quote, char const *fmt,...))
Set the name on a pre-initialised tmpl.
static bool tmpl_attr_tail_is_unspecified(tmpl_t const *vpt)
Return true if the last attribute reference is "unspecified".
Definition tmpl.h:743
void tmpl_set_xlat(tmpl_t *vpt, xlat_exp_head_t *xlat)
Change the default dictionary in the tmpl's resolution rules.
void tmpl_attr_set_request_ref(tmpl_t *vpt, FR_DLIST_HEAD(tmpl_request_list) const *request_def)
Set the request for an attribute ref.
int tmpl_attr_set_da(tmpl_t *vpt, fr_dict_attr_t const *da)
Replace the current attribute reference.
fr_packet_t * tmpl_packet_ptr(request_t *request, fr_dict_attr_t const *list)
Resolve a list to the fr_packet_t holding the HEAD pointer for a fr_pair_t list.
Definition tmpl_eval.c:146
static fr_slen_t tmpl_aprint(TALLOC_CTX *ctx, char **out, tmpl_t const *vpt, tmpl_attr_prefix_t ar_prefix, fr_sbuff_escape_rules_t const *e_rules) 1(tmpl_print
static fr_slen_t vpt
Definition tmpl.h:1278
tmpl_escape_t escape
How escaping should be handled during evaluation.
Definition tmpl.h:364
static bool tmpl_attr_tail_is_normal(tmpl_t const *vpt)
Return true if the last attribute reference is "normal".
Definition tmpl.h:727
tmpl_t * tmpl_init(tmpl_t *vpt, tmpl_type_t type, fr_token_t quote, char const *name, ssize_t len, tmpl_rules_t const *t_rules))
Initialise a tmpl using a literal string to create the name.
int tmpl_resolve(tmpl_t *vpt, tmpl_res_rules_t const *tr_rules))
Attempt to resolve functions and attributes in xlats and attribute references.
TALLOC_CTX * list_ctx
Where to allocate new attributes if building out from the current extents of the tree.
Definition tmpl.h:627
fr_table_num_sorted_t const tmpl_request_ref_table[]
Map keywords to tmpl_request_ref_t values.
#define TMPL_FLAG_ATTR
Base data type is an attribute reference.
Definition tmpl.h:106
int tmpl_afrom_value_box(TALLOC_CTX *ctx, tmpl_t **out, fr_value_box_t *data, bool steal)
Create a tmpl_t from a fr_value_box_t.
#define ar_is_unknown(_ar)
Definition tmpl.h:522
tmpl_t * tmpl_alloc(TALLOC_CTX *ctx, tmpl_type_t type, fr_token_t quote, char const *name, ssize_t len)
Create a new heap allocated tmpl_t.
int tmpl_attr_unknown_add(tmpl_t *vpt)
Add an unknown fr_dict_attr_t specified by a tmpl_t to the main dictionary.
static bool tmpl_attr_tail_is_unknown(tmpl_t const *vpt)
Return true if the last attribute reference is "unknown".
Definition tmpl.h:759
int tmpl_extents_build_to_leaf_parent(fr_dlist_head_t *leaf, fr_dlist_head_t *interior, tmpl_t const *vpt)
Allocate interior pairs.
static tmpl_type_t tmpl_type_from_str(char const *type)
Return the constant value representing a type.
Definition tmpl.h:661
void tmpl_attr_ref_debug(const tmpl_attr_t *ar, int idx)
fr_value_box_safe_for_t literals_safe_for
safe_for value assigned to literal values in xlats, execs, and data.
Definition tmpl.h:362
void tmpl_set_escape(tmpl_t *vpt, tmpl_escape_t const *escape)
Set escape parameters for the tmpl output.
#define TMPL_FLAG_UNRESOLVED
Needs resolution.
Definition tmpl.h:121
#define ar_is_raw(_ar)
Definition tmpl.h:524
size_t pair_list_table_len
#define tmpl_is_attr(vpt)
Definition tmpl.h:213
bool tmpl_async_required(tmpl_t const *vpt)
Return whether or not async is required for this tmpl.
fr_dict_attr_t const * enumv
Enumeration attribute used to resolve enum values.
Definition tmpl.h:353
tmpl_rules_t const * parent
for parent / child relationships
Definition tmpl.h:348
void tmpl_rules_child_init(TALLOC_CTX *ctx, tmpl_rules_t *out, tmpl_rules_t const *parent, tmpl_t *vpt)
Initialize a set of rules from a parent set of rules, and a parsed tmpl_t.
static fr_dict_attr_t const * tmpl_list(tmpl_t const *vpt)
Definition tmpl.h:921
int16_t _CONST num
For array references.
Definition tmpl.h:428
static bool tmpl_attr_is_list_attr(tmpl_attr_t const *ar)
Return true if the tmpl_attr is one of the list types.
Definition tmpl.h:696
int tmpl_extents_find(TALLOC_CTX *ctx, fr_dlist_head_t *leaf, fr_dlist_head_t *interior, request_t *request, tmpl_t const *vpt))
Determines points where the reference list extends beyond the current pair tree.
ssize_t tmpl_afrom_attr_str(TALLOC_CTX *ctx, tmpl_attr_error_t *err, tmpl_t **out, char const *name, tmpl_rules_t const *rules))
Parse a string into a TMPL_TYPE_ATTR_* type tmpl_t.
static fr_slen_t tmpl_request_ref_list_aprint(TALLOC_CTX *ctx, char **out, FR_DLIST_HEAD(tmpl_request_list) const *rql) 1(tmpl_request_ref_list_print
int tmpl_eval_cast_in_place(fr_value_box_list_t *out, request_t *request, tmpl_t const *vpt)
Casts a value or list of values according to the tmpl.
Definition tmpl_eval.c:1349
void tmpl_set_name(tmpl_t *vpt, fr_token_t quote, char const *name, ssize_t len)
Set the name on a pre-initialised tmpl.
tmpl_type_e
Types of tmpl_t.
Definition tmpl.h:131
@ TMPL_TYPE_REGEX_UNCOMPILED
Regex where compilation is possible but hasn't been performed yet.
Definition tmpl.h:162
@ TMPL_TYPE_MAX
Marker for the last tmpl type.
Definition tmpl.h:203
@ TMPL_TYPE_ATTR_UNRESOLVED
An attribute reference that we couldn't resolve but looked valid.
Definition tmpl.h:189
@ TMPL_TYPE_ATTR
Reference to one or more attributes.
Definition tmpl.h:146
@ TMPL_TYPE_XLAT
Pre-parsed xlat expansion.
Definition tmpl.h:150
@ TMPL_TYPE_NULL
Has no value.
Definition tmpl.h:138
@ TMPL_TYPE_EXEC
Callout to an external script or program.
Definition tmpl.h:154
@ TMPL_TYPE_REGEX_XLAT_UNRESOLVED
A regular expression with unresolved xlat functions or attribute references.
Definition tmpl.h:201
@ TMPL_TYPE_DATA
Value in native boxed format.
Definition tmpl.h:142
@ TMPL_TYPE_REGEX
Compiled (and possibly JIT'd) regular expression.
Definition tmpl.h:158
@ TMPL_TYPE_DATA_UNRESOLVED
Unparsed literal string.
Definition tmpl.h:183
@ TMPL_TYPE_XLAT_UNRESOLVED
A xlat expansion with unresolved xlat functions or attribute references.
Definition tmpl.h:197
@ TMPL_TYPE_REGEX_XLAT
A regex containing xlat expansions.
Definition tmpl.h:166
@ TMPL_TYPE_EXEC_UNRESOLVED
An exec with unresolved xlat function or attribute references.
Definition tmpl.h:193
@ TMPL_TYPE_UNINITIALISED
Uninitialised.
Definition tmpl.h:134
int tmpl_attr_afrom_list(TALLOC_CTX *ctx, tmpl_t **out, tmpl_t const *list, fr_dict_attr_t const *da)
Create a new tmpl from a list tmpl and a da.
void tmpl_attr_to_raw(tmpl_t *vpt)
Convert the leaf attribute of a tmpl to a unknown/raw type.
static bool tmpl_attr_tail_da_is_leaf(tmpl_t const *vpt)
Return true if the the last attribute reference is a leaf attribute.
Definition tmpl.h:834
#define tmpl_assert_type(_cond)
Convenience macro for printing a meaningful assert message when we get a bad tmpl type.
Definition tmpl.h:637
#define tmpl_contains_attr(vpt)
Definition tmpl.h:230
int tmpl_eval(TALLOC_CTX *ctx, fr_value_box_list_t *out, request_t *request, tmpl_t const *vpt)
Gets the value of a tmpl.
Definition tmpl_eval.c:1221
tmpl_t * tmpl_copy(TALLOC_CTX *ctx, tmpl_t const *in)
Copy a tmpl.
static bool tmpl_attr_tail_da_is_structural(tmpl_t const *vpt)
Return true if the the last attribute reference is a structural attribute.
Definition tmpl.h:852
int tmpl_copy_pairs(TALLOC_CTX *ctx, fr_pair_list_t *out, request_t *request, tmpl_t const *vpt))
Copy pairs matching a tmpl_t in the current request_t.
Definition tmpl_eval.c:798
ssize_t _tmpl_to_atype(TALLOC_CTX *ctx, void *out, request_t *request, tmpl_t const *vpt, xlat_escape_legacy_t escape, void const *escape_ctx, fr_type_t dst_type))
Expand a template to a string, allocing a new buffer to hold the string.
Definition tmpl_eval.c:563
#define TMPL_FLAG_REGEX
Is a type of regular expression.
Definition tmpl.h:116
fr_pair_list_t * tmpl_list_head(request_t *request, fr_dict_attr_t const *list)
Resolve attribute fr_pair_list_t value to an attribute list.
Definition tmpl_eval.c:76
static size_t tmpl_request_ref_count(tmpl_t const *vpt)
The number of request references contained within a tmpl.
Definition tmpl.h:684
TALLOC_CTX * tmpl_list_ctx(request_t *request, fr_dict_attr_t const *list)
Return the correct TALLOC_CTX to alloc fr_pair_t in, for a list.
Definition tmpl_eval.c:116
ssize_t tmpl_afrom_substr(TALLOC_CTX *ctx, tmpl_t **out, fr_sbuff_t *in, fr_token_t quote, fr_sbuff_parse_rules_t const *p_rules, tmpl_rules_t const *t_rules))
Convert an arbitrary string into a tmpl_t.
tmpl_rules_t _CONST rules
The rules that were used when creating the tmpl.
Definition tmpl.h:610
static fr_slen_t e_rules fr_slen_t tmpl_print_quoted(fr_sbuff_t *out, tmpl_t const *vpt, tmpl_attr_prefix_t ar_prefix)
Print a tmpl_t to a string with quotes.
fr_dlist_t entry
Entry in the dlist of extents.
Definition tmpl.h:619
int tmpl_global_init(void)
Definition tmpl_eval.c:1483
tmpl_xlat_rules_t xlat
Rules/data for parsing xlats.
Definition tmpl.h:351
static char const * tmpl_attr_tail_unresolved(tmpl_t const *vpt)
Return the last attribute reference unresolved da.
Definition tmpl.h:886
bool at_runtime
Produce an ephemeral/runtime tmpl.
Definition tmpl.h:359
static bool tmpl_is_list(tmpl_t const *vpt)
Definition tmpl.h:937
static fr_slen_t rql fr_slen_t tmpl_attr_print(fr_sbuff_t *out, tmpl_t const *vpt, tmpl_attr_prefix_t ar_prefix))
Print an attribute or list tmpl_t to a string.
static fr_slen_t tmpl_aprint_quoted(TALLOC_CTX *ctx, char **out, tmpl_t const *vpt, tmpl_attr_prefix_t ar_prefix) 1(tmpl_print_quoted
ssize_t tmpl_afrom_attr_substr(TALLOC_CTX *ctx, tmpl_attr_error_t *err, tmpl_t **out, fr_sbuff_t *name, fr_sbuff_parse_rules_t const *p_rules, tmpl_rules_t const *t_rules))
Parse a string into a TMPL_TYPE_ATTR_* type tmpl_t.
bool new_functions
new function syntax
Definition tmpl.h:341
int tmpl_eval_pair(TALLOC_CTX *ctx, fr_value_box_list_t *out, request_t *request, tmpl_t const *vpt)
Gets the value of a real or virtual attribute.
Definition tmpl_eval.c:1077
static fr_slen_t ar_prefix fr_slen_t tmpl_print(fr_sbuff_t *out, tmpl_t const *vpt, tmpl_attr_prefix_t ar_prefix, fr_sbuff_escape_rules_t const *e_rules))
Print a tmpl_t to a string.
ssize_t _tmpl_to_type(void *out, uint8_t *buff, size_t outlen, request_t *request, tmpl_t const *vpt, xlat_escape_legacy_t escape, void const *escape_ctx, fr_type_t dst_type))
Expand a tmpl_t to a string writing the result to a buffer.
Definition tmpl_eval.c:284
int tmpl_cast_in_place(tmpl_t *vpt, fr_type_t type, fr_dict_attr_t const *enumv))
Convert tmpl_t of type TMPL_TYPE_DATA_UNRESOLVED or TMPL_TYPE_DATA to TMPL_TYPE_DATA of type specifie...
bool force_dict_def
Use supplied dict_def even if original vpt->rules->dict_def was not NULL.
Definition tmpl.h:385
void tmpl_debug(tmpl_t const *vpt)
void tmpl_set_name_shallow(tmpl_t *vpt, fr_token_t quote, char const *name, ssize_t len)
Set the name on a pre-initialised tmpl.
fr_dict_t const * dict_def
Alternative default dictionary to use if vpt->rules->dict_def is NULL.
Definition tmpl.h:380
static bool tmpl_attr_tail_is_unresolved(tmpl_t const *vpt)
Return true if the last attribute reference is "unresolved".
Definition tmpl.h:775
tmpl_type_t _CONST type
What type of value tmpl refers to.
Definition tmpl.h:563
#define _CONST
Definition tmpl.h:258
ssize_t tmpl_preparse(char const **out, size_t *outlen, char const *in, size_t inlen, fr_token_t *type))
Preparse a string in preparation for passing it to tmpl_afrom_substr()
static size_t tmpl_attr_num_elements(tmpl_t const *vpt)
The number of attribute references contained within a tmpl.
Definition tmpl.h:913
fr_slen_t tmpl_request_ref_list_afrom_substr(TALLOC_CTX *ctx, tmpl_attr_error_t *err, FR_DLIST_HEAD(tmpl_request_list) _CONST **out, fr_sbuff_t *in)
fr_table_num_ordered_t const pair_list_table[]
#define tmpl_attr(_tmpl)
Definition tmpl.h:671
void tmpl_attr_rewrite_leaf_num(tmpl_t *vpt, int16_t num)
Rewrite the leaf's instance number.
void tmpl_attr_ref_list_debug(FR_DLIST_HEAD(tmpl_attr_list) const *ar_head)
static fr_type_t tmpl_cast_get(tmpl_t *vpt)
Definition tmpl.h:1232
int tmpl_request_ptr(request_t **request, FR_DLIST_HEAD(tmpl_request_list) const *rql)
Resolve a tmpl_request_ref_t to a request_t.
Definition tmpl_eval.c:169
char const *_CONST name
Raw string used to create the template.
Definition tmpl.h:565
tmpl_attr_error_t
Definition tmpl.h:1018
@ TMPL_ATTR_ERROR_INVALID_ARRAY_INDEX
Invalid array index.
Definition tmpl.h:1037
@ TMPL_ATTR_ERROR_LIST_NOT_ALLOWED
List qualifier is not allowed here.
Definition tmpl.h:1022
@ TMPL_ATTR_ERROR_INTERNAL_NOT_ALLOWED
Attribute resolved to an internal attribute which is disallowed.
Definition tmpl.h:1032
@ TMPL_ATTR_ERROR_UNRESOLVED_NOT_ALLOWED
Attribute couldn't be found in the dictionaries.
Definition tmpl.h:1028
@ TMPL_ATTR_ERROR_INVALID_FILTER
Invalid filter.
Definition tmpl.h:1038
@ TMPL_ATTR_ERROR_BAD_CAST
Specified cast was invalid.
Definition tmpl.h:1041
@ TMPL_ATTR_ERROR_INVALID_NAME
Attribute ref length is zero, or longer than the maximum.
Definition tmpl.h:1030
@ TMPL_ATTR_ERROR_UNQUALIFIED_NOT_ALLOWED
Attribute must be qualified to be used here.
Definition tmpl.h:1029
@ TMPL_ATTR_ERROR_MISSING_TERMINATOR
Unexpected text found after attribute reference.
Definition tmpl.h:1040
@ TMPL_ATTR_ERROR_LIST_MISSING
List qualifier is required, but missing.
Definition tmpl.h:1023
@ TMPL_ATTR_ERROR_NONE
No error.
Definition tmpl.h:1019
@ TMPL_ATTR_ERROR_FOREIGN_NOT_ALLOWED
Attribute resolved in a dictionary different to the one specified.
Definition tmpl.h:1034
@ TMPL_ATTR_ERROR_UNKNOWN_NOT_ALLOWED
Attribute specified as OID, could not be found in the dictionaries, and is disallowed because 'disall...
Definition tmpl.h:1024
@ TMPL_ATTR_ERROR_FILTER_NOT_ALLOWED
Filters disallowed by rules.
Definition tmpl.h:1036
@ TMPL_ATTR_ERROR_EMPTY
Attribute ref contains no data.
Definition tmpl.h:1020
@ TMPL_ATTR_ERROR_NESTING_TOO_DEEP
Too many levels of nesting.
Definition tmpl.h:1039
@ TMPL_ATTR_ERROR_BAD_PREFIX
Missing '&' or has '&' when it shouldn't.
Definition tmpl.h:1021
fr_type_t cast
Whether there was an explicit cast.
Definition tmpl.h:355
tmpl_attr_rules_t attr
Rules/data for parsing attribute references.
Definition tmpl.h:350
union tmpl_s::@86 data
void tmpl_rules_debug(tmpl_rules_t const *rules)
int tmpl_attr_copy(tmpl_t *dst, tmpl_t const *src)
Copy a list of attribute and request references from one tmpl to another.
fr_pair_list_t * list
List that we tried to evaluate ar in and failed.
Definition tmpl.h:629
tmpl_t * tmpl_init_printf(tmpl_t *vpt, tmpl_type_t type, fr_token_t quote, char const *fmt,...))
Initialise a tmpl using a format string to create the name.
static fr_dict_attr_t const * tmpl_attr_tail_da(tmpl_t const *vpt)
Return the last attribute reference da.
Definition tmpl.h:818
tmpl_attr_list_presence_t
Specify whether attribute references can have a list (or parent) reference.
Definition tmpl.h:275
@ TMPL_ATTR_LIST_REQUIRE
Attribute refs are required to have a list.
Definition tmpl.h:278
@ TMPL_ATTR_LIST_ALLOW
Attribute refs are allowed to have a list.
Definition tmpl.h:276
@ TMPL_ATTR_LIST_FORBID
Attribute refs are forbidden from having a list.
Definition tmpl.h:277
void tmpl_extents_debug(fr_dlist_head_t *head)
#define ar_is_unresolved(_ar)
Definition tmpl.h:523
static bool tmpl_attr_head_is_list(tmpl_t const *vpt)
Return true if the head attribute reference is a list reference.
Definition tmpl.h:711
enum tmpl_type_e tmpl_type_t
Types of tmpl_t.
size_t tmpl_type_table_len
struct tmpl_literal_rules_s tmpl_literal_rules_t
Definition tmpl.h:241
#define ar_is_normal(_ar)
Definition tmpl.h:520
int tmpl_attr_set_leaf_da(tmpl_t *vpt, fr_dict_attr_t const *da)
Replace the leaf attribute only.
static fr_dict_attr_t const * tmpl_attr_tail_unknown(tmpl_t const *vpt)
Return the last attribute reference unknown da.
Definition tmpl.h:870
static char const * tmpl_list_name(fr_dict_attr_t const *list, char const *def)
Return the name of a tmpl list or def if list not provided.
Definition tmpl.h:932
static bool tmpl_attr_tail_is_raw(tmpl_t const *vpt)
Return true if the last attribute reference is "raw".
Definition tmpl.h:791
requests_ref_e
Definition tmpl.h:90
@ REQUEST_OUTER
request_t containing the outer layer of the EAP conversation.
Definition tmpl.h:92
@ REQUEST_PARENT
Parent (whatever it is).
Definition tmpl.h:96
@ REQUEST_UNKNOWN
Unknown request.
Definition tmpl.h:97
@ REQUEST_CURRENT
The current request (default).
Definition tmpl.h:91
fr_slen_t tmpl_request_ref_list_print(fr_sbuff_t *out, FR_DLIST_HEAD(tmpl_request_list) const *rql))
int tmpl_find_or_add_vp(fr_pair_t **out, request_t *request, tmpl_t const *vpt)
Returns the first VP matching a tmpl_t, or if no VPs match, creates a new one.
Definition tmpl_eval.c:918
int tmpl_value_list_insert_tail(fr_value_box_list_t *list, fr_value_box_t *vb, tmpl_t const *vpt)
Insert a value-box to a list, with casting.
Definition tmpl_eval.c:1052
void tmpl_set_dict_def(tmpl_t *vpt, fr_dict_t const *dict)
Change the default dictionary in the tmpl's resolution rules.
int tmpl_attr_tail_unresolved_add(fr_dict_t *dict, tmpl_t *vpt, fr_type_t type, fr_dict_attr_flags_t const *flags))
Add an unresolved fr_dict_attr_t specified by a tmpl_t to the main dictionary.
int tmpl_copy_pair_children(TALLOC_CTX *ctx, fr_pair_list_t *out, request_t *request, tmpl_t const *vpt))
Copy children of pairs matching a tmpl_t in the current request_t.
Definition tmpl_eval.c:841
fr_dict_attr_t const * enumv
for resolving T_BARE_WORD
Definition tmpl.h:388
size_t _CONST len
Length of the raw string used to create the template.
Definition tmpl.h:567
ssize_t tmpl_cast_from_substr(tmpl_rules_t *t_rules, fr_sbuff_t *in))
Parse a cast specifier.
int pair_append_by_tmpl_parent(TALLOC_CTX *ctx, fr_pair_t **out, fr_pair_list_t *list, tmpl_t const *vpt, bool skip_list))
Allocate and insert a leaf vp from a tmpl_t, building the parent vps if needed.
Definition tmpl_eval.c:974
tmpl_attr_type_t
Definition tmpl.h:391
@ TMPL_ATTR_TYPE_UNSPEC
No attribute was specified as this level only a filter.
Definition tmpl.h:393
@ TMPL_ATTR_TYPE_NORMAL
Normal, resolved, attribute ref.
Definition tmpl.h:392
@ TMPL_ATTR_TYPE_UNKNOWN
We have an attribute number but it doesn't match anything in the dictionary, or isn't a child of the ...
Definition tmpl.h:395
@ TMPL_ATTR_TYPE_UNRESOLVED
We have a name, but nothing else to identify the attribute.
Definition tmpl.h:400
#define TMPL_FLAG_XLAT
Base data type is an xlat expansion.
Definition tmpl.h:111
tmpl_attr_t const * ar
Attribute representing the ar after the deepest node that was found in the existing pair tree when ev...
Definition tmpl.h:621
int tmpl_attr_to_xlat(TALLOC_CTX *ctx, tmpl_t **vpt_p)
Convert an attribute reference to an xlat expansion.
fr_slen_t tmpl_attr_list_from_substr(fr_dict_attr_t const **da_p, fr_sbuff_t *in)
Parse one a single list reference.
tmpl_attr_filter_type_t
Define entry and head types for attribute reference lists.
Definition tmpl.h:418
@ TMPL_ATTR_FILTER_TYPE_TMPL
Filter is a tmpl.
Definition tmpl.h:422
@ TMPL_ATTR_FILTER_TYPE_INDEX
Filter is an index type.
Definition tmpl.h:420
@ TMPL_ATTR_FILTER_TYPE_CONDITION
Filter is a condition.
Definition tmpl.h:421
@ TMPL_ATTR_FILTER_TYPE_NONE
No filter present.
Definition tmpl.h:419
@ TMPL_ATTR_FILTER_TYPE_EXPR
Filter is an expression.
Definition tmpl.h:423
fr_event_list_t * runtime_el
The eventlist to use for runtime instantiation of xlats.
Definition tmpl.h:339
fr_table_num_ordered_t const tmpl_type_table[]
Map tmpl_type_t values to descriptive strings.
int tmpl_cast_set(tmpl_t *vpt, fr_type_t type)
Set a cast for a tmpl.
fr_token_t _CONST quote
What type of quoting was around the raw string.
Definition tmpl.h:568
void tmpl_attr_debug(tmpl_t const *vpt)
tmpl_t * tmpl_init_shallow(tmpl_t *vpt, tmpl_type_t type, fr_token_t quote, char const *name, ssize_t len, tmpl_rules_t const *t_rules))
Initialise a tmpl without copying the input name string.
fr_type_t tmpl_expanded_type(tmpl_t const *vpt)
Return the native data type of the expression.
Definition tmpl_eval.c:209
tmpl_attr_filter_type_t _CONST type
Type of filter this is.
Definition tmpl.h:427
size_t tmpl_request_ref_table_len
Describes the current extents of a pair tree in relation to the tree described by a tmpl_t.
Definition tmpl.h:618
Similar to tmpl_rules_t, but used to specify parameters that may change during subsequent resolution ...
Definition tmpl.h:379
Optional arguments passed to vp_tmpl functions.
Definition tmpl.h:347
A source or sink of value data.
Definition tmpl.h:562
static char buff[sizeof("18446744073709551615")+3]
Definition size_tests.c:41
fr_aka_sim_id_type_t type
Define entry and head types for tmpl request references.
Definition tmpl.h:286
tmpl_attr_list_presence_t list_presence
Whether the attribute reference can have a list, forbid it, or require it.
Definition tmpl.h:315
fr_dict_attr_t const * list_def
Default list to use with unqualified attribute reference.
Definition tmpl.h:309
uint8_t disallow_filters
disallow filters.
Definition tmpl.h:331
uint8_t allow_unresolved
Allow attributes that look valid but were not found in the dictionaries.
Definition tmpl.h:321
uint8_t bare_word_enum
for v3 compatibility.
Definition tmpl.h:335
uint8_t allow_foreign
Allow arguments not found in dict_def.
Definition tmpl.h:329
fr_dict_t const * dict_def
Default dictionary to use with unqualified attribute references.
Definition tmpl.h:287
FR_DLIST_HEAD(tmpl_request_list) _CONST *request_def
< Point in dictionary tree to resume parsing from.
uint8_t allow_wildcard
Allow the special case of .
Definition tmpl.h:326
uint8_t allow_unknown
Allow unknown attributes i.e.
Definition tmpl.h:318
uint8_t xlat
for %{User-Name}
Definition tmpl.h:333
tmpl_attr_prefix_t prefix
Whether the attribute reference requires a prefix.
Definition tmpl.h:312
An element in a list of nested attribute references.
Definition tmpl.h:445
unsigned int _CONST resolve_only
This reference and those before it.
Definition tmpl.h:468
unsigned int _CONST is_raw
Definition tmpl.h:471
fr_dict_attr_t const *_CONST da
Resolved dictionary attribute.
Definition tmpl.h:449
fr_dict_attr_t const *_CONST parent
The parent we used when trying to resolve the attribute originally.
Definition tmpl.h:463
FR_DLIST_ENTRY(tmpl_attr_list) _CONST entry
Entry in the doubly linked list of attribute references.
tmpl_attr_filter_t _CONST filter
Filter associated with the attribute reference.
Definition tmpl.h:475
tmpl_attr_type_t _CONST type
is a raw reference
Definition tmpl.h:473
Define manipulation functions for the attribute reference list.
Definition tmpl.h:486
FR_DLIST_ENTRY(tmpl_request_list) _CONST entry
Entry in the doubly linked list of request references.
tmpl_request_ref_t _CONST request
Definition tmpl.h:490
Stores an attribute, a value and various bits of other data.
Definition pair.h:68
#define fr_table_value_by_str(_table, _name, _def)
Convert a string to a value using a sorted or ordered table.
Definition table.h:653
#define fr_table_str_by_value(_table, _number, _def)
Convert an integer to a string.
Definition table.h:772
An element in an arbitrarily ordered array of name to num mappings.
Definition table.h:57
An element in a lexicographically sorted array of name to num mappings.
Definition table.h:49
Escaping rules for tmpls.
Definition tmpl_escape.h:80
enum fr_token fr_token_t
static fr_slen_t head
Definition xlat.h:422
static fr_slen_t parent
Definition pair.h:851
#define fr_type_is_structural(_x)
Definition types.h:371
#define fr_type_is_leaf(_x)
Definition types.h:372
static fr_slen_t data
Definition value.h:1265
static size_t char fr_sbuff_t size_t inlen
Definition value.h:997
uintptr_t fr_value_box_safe_for_t
Escaping that's been applied to a value box.
Definition value.h:155
int nonnull(2, 5))
static size_t char ** out
Definition value.h:997