123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450 |
- {* Licensed to the Apache Software Foundation (ASF) under one or more
- * contributor license agreements. See the NOTICE file distributed with
- * this work for additional information regarding copyright ownership.
- * The ASF licenses this file to You under the Apache License, Version 2.0
- * (the "License"); you may not use this file except in compliance with
- * the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- *}
- (**
- * @file ap_expr.h
- * @brief Expression parser
- *
- * @defgroup AP_EXPR Expression parser
- * @ingroup APACHE_CORE
- * @{
- *)
- //#ifndef AP_EXPR_H
- //#define AP_EXPR_H
- //#include "httpd.h"
- //#include "http_config.h"
- //#include "ap_regex.h"
- //** A node in the expression parse tree */
- //typedef struct ap_expr_node ap_expr_t;
- type
- ap_expr_node_op_e = (
- op_NOP,
- op_True, op_False,
- op_Not, op_Or, op_And,
- op_Comp,
- op_EQ, op_NE, op_LT, op_LE, op_GT, op_GE, op_IN,
- op_REG, op_NRE,
- op_STR_EQ, op_STR_NE, op_STR_LT, op_STR_LE, op_STR_GT, op_STR_GE,
- op_Concat,
- op_Digit, op_String, op_Regex, op_RegexBackref,
- op_Var,
- op_ListElement,
- {*
- * call external functions/operators.
- * The info node contains the function pointer and some function specific
- * info.
- * For Binary operators, the Call node links to the Info node and the
- * Args node, which in turn links to the left and right operand.
- * For all other variants, the Call node links to the Info node and the
- * argument.
- *}
- op_UnaryOpCall, op_UnaryOpInfo,
- op_BinaryOpCall, op_BinaryOpInfo, op_BinaryOpArgs,
- op_StringFuncCall, op_StringFuncInfo,
- op_ListFuncCall, op_ListFuncInfo
- );
- ap_expr_node = record {fpc -> from httpd-X-X-X/server/util_expr_private.h}
- node_op: ap_expr_node_op_e;
- node_arg1: Pointer;
- node_arg2: Pointer;
- end;
- ap_expr_t = ap_expr_node;
- Pap_expr_t = ^ap_expr_t;
- //** Struct describing a parsed expression */
- Pap_expr_info_t = ^ap_expr_info_t;
- ap_expr_info_t = record
- //** The root of the actual expression parse tree */
- root_node: Pap_expr_t;
- {** The filename where the expression has been defined (for logging).
- * May be NULL
- *}
- filename: PChar;
- //** The line number where the expression has been defined (for logging). */
- line_number: cuint;
- //** Flags relevant for the expression, see AP_EXPR_FLAG_* */
- flags: cuint;
- //** The module that is used for loglevel configuration */
- module_index: Integer;
- end; {ap_expr_info_t}
- {** Use ssl_expr compatibility mode (changes the meaning of the comparison
- * operators)
- *}
- const
- AP_EXPR_FLAG_SSL_EXPR_COMPAT = 1;
- //** Don't add siginificant request headers to the Vary response header */
- AP_EXPR_FLAG_DONT_VARY = 2;
- {** Don't allow functions/vars that bypass the current request's access
- * restrictions or would otherwise leak confidential information.
- * Used by e.g. mod_include.
- *}
- AP_EXPR_FLAG_RESTRICTED = 4;
- //** Expression evaluates to a string, not to a bool */
- AP_EXPR_FLAG_STRING_RESULT = 8;
- {**
- * Evaluate a parse tree, simple interface
- * @param r The current request
- * @param expr The expression to be evaluated
- * @param err Where an error message should be stored
- * @return > 0 if expression evaluates to true, == 0 if false, < 0 on error
- * @note err will be set to NULL on success, or to an error message on error
- * @note request headers used during evaluation will be added to the Vary:
- * response header, unless ::AP_EXPR_FLAG_DONT_VARY is set.
- *}
- //AP_DECLARE(int) ap_expr_exec(request_rec *r, const ap_expr_info_t *expr,
- // const char **err);
- function ap_expr_exec(r: Prequest_rec; const expr: Pap_expr_info_t; err: PPChar): Integer;
- {$IFDEF WINDOWS} stdcall; {$ELSE} cdecl; {$ENDIF}
- external LibHTTPD name LibNamePrefix + 'ap_expr_exec' + LibSuff12;
- {**
- * Evaluate a parse tree, with access to regexp backreference
- * @param r The current request
- * @param expr The expression to be evaluated
- * @param nmatch size of the regex match vector pmatch
- * @param pmatch information about regex matches
- * @param source the string that pmatch applies to
- * @param err Where an error message should be stored
- * @return > 0 if expression evaluates to true, == 0 if false, < 0 on error
- * @note err will be set to NULL on success, or to an error message on error
- * @note nmatch/pmatch/source can be used both to make previous matches
- * available to ap_expr_exec_re and to use ap_expr_exec_re's matches
- * later on.
- * @note request headers used during evaluation will be added to the Vary:
- * response header, unless ::AP_EXPR_FLAG_DONT_VARY is set.
- *}
- //AP_DECLARE(int) ap_expr_exec_re(request_rec *r, const ap_expr_info_t *expr,
- // apr_size_t nmatch, ap_regmatch_t *pmatch,
- // const char **source, const char **err);
- function ap_expr_exec_re(r: Prequest_rec; const expr: Pap_expr_info_t;
- nmatch: apr_size_t; pmatch: Pap_regmatch_t;
- const source: PPChar; const err: PPChar): Integer;
- {$IFDEF WINDOWS} stdcall; {$ELSE} cdecl; {$ENDIF}
- external LibHTTPD name LibNamePrefix + 'ap_expr_exec_re' + LibSuff24;
- //** Context used during evaluation of a parse tree, created by ap_expr_exec */
- type
- Pap_expr_eval_ctx_t = ^ap_expr_eval_ctx_t;
- ap_expr_eval_ctx_t = record
- //** the current request */
- r : Prequest_rec;
- //** the current connection */
- c : Pconn_rec;
- //** the current connection */
- s : Pserver_rec;
- //** the pool to use */
- p : Papr_pool_t;
- //** where to store the error string */
- err : PPchar;
- //** ap_expr_info_t for the expression */
- info : Pap_expr_info_t;
- //** regex match information for back references */
- re_pmatch : Pap_regmatch_t;
- //** size of the vector pointed to by re_pmatch */
- re_nmatch : apr_size_t;
- //** the string corresponding to the re_pmatch */
- re_source : PPchar;
- {** A string where the comma separated names of headers are stored
- * to be later added to the Vary: header. If NULL, the caller is not
- * interested in this information.
- *}
- vary_this : PPchar;
- //** where to store the result string */
- result_string : PPchar;
- //** Arbitrary context data provided by the caller for custom functions */
- data : pointer;
- //** The current recursion level */
- reclvl : Integer;
- end; {ap_expr_eval_ctx_t}
- {**
- * Evaluate a parse tree, full featured version
- * @param ctx The evaluation context with all data filled in
- * @return > 0 if expression evaluates to true, == 0 if false, < 0 on error
- * @note *ctx->err will be set to NULL on success, or to an error message on
- * error
- * @note request headers used during evaluation will be added to the Vary:
- * response header if ctx->vary_this is set.
- *}
- //AP_DECLARE(int) ap_expr_exec_ctx(ap_expr_eval_ctx_t *ctx);
- function ap_expr_exec_ctx(ctx: Pap_expr_eval_ctx_t): Integer;
- {$IFDEF WINDOWS} stdcall; {$ELSE} cdecl; {$ENDIF}
- external LibHTTPD name LibNamePrefix + 'ap_expr_exec_ctx' + LibSuff4;
- {**
- * Evaluate a parse tree of a string valued expression
- * @param r The current request
- * @param expr The expression to be evaluated
- * @param err Where an error message should be stored
- * @return The result string, NULL on error
- * @note err will be set to NULL on success, or to an error message on error
- * @note request headers used during evaluation will be added to the Vary:
- * response header, unless ::AP_EXPR_FLAG_DONT_VARY is set.
- *}
- //AP_DECLARE(const char *) ap_expr_str_exec(request_rec *r,
- // const ap_expr_info_t *expr,
- // const char **err);
- function ap_expr_str_exec(r: Prequest_rec;
- const expr: Pap_expr_info_t;
- const err: PPChar): PChar;
- {$IFDEF WINDOWS} stdcall; {$ELSE} cdecl; {$ENDIF}
- external LibHTTPD name LibNamePrefix + 'ap_expr_str_exec' + LibSuff12;
- {**
- * Evaluate a parse tree of a string valued expression
- * @param r The current request
- * @param expr The expression to be evaluated
- * @param nmatch size of the regex match vector pmatch
- * @param pmatch information about regex matches
- * @param source the string that pmatch applies to
- * @param err Where an error message should be stored
- * @return The result string, NULL on error
- * @note err will be set to NULL on success, or to an error message on error
- * @note nmatch/pmatch/source can be used both to make previous matches
- * available to ap_expr_exec_re and to use ap_expr_exec_re's matches
- * later on.
- * @note request headers used during evaluation will be added to the Vary:
- * response header, unless ::AP_EXPR_FLAG_DONT_VARY is set.
- *}
- //AP_DECLARE(const char *) ap_expr_str_exec_re(request_rec *r,
- // const ap_expr_info_t *expr,
- // apr_size_t nmatch,
- // ap_regmatch_t *pmatch,
- // const char **source,
- // const char **err);
- function ap_expr_str_exec_re(r: Prequest_rec;
- const expr: Pap_expr_info_t;
- nmatch: apr_size_t;
- pmatch: Pap_regmatch_t;
- const source: PPChar;
- const err: PPChar): PChar;
- {$IFDEF WINDOWS} stdcall; {$ELSE} cdecl; {$ENDIF}
- external LibHTTPD name LibNamePrefix + 'ap_expr_str_exec_re' + LibSuff24;
- {**
- * The parser can be extended with variable lookup, functions, and
- * and operators.
- *
- * During parsing, the parser calls the lookup function to resolve a
- * name into a function pointer and an opaque context for the function.
- * If the argument to a function or operator is constant, the lookup function
- * may also parse that argument and store the parsed data in the context.
- *
- * The default lookup function is the hook ::ap_expr_lookup_default which just
- * calls ap_run_expr_lookup. Modules can use it to make functions and
- * variables generally available.
- *
- * An ap_expr consumer can also provide its own custom lookup function to
- * modify the set of variables and functions that are available. The custom
- * lookup function can in turn call 'ap_run_expr_lookup'.
- *}
- {** Unary operator, takes one string argument and returns a bool value.
- * The name must have the form '-z' (one letter only).
- * @param ctx The evaluation context
- * @param data An opaque context provided by the lookup hook function
- * @param arg The (right) operand
- * @return 0 or 1
- *}
- //typedef int ap_expr_op_unary_t(ap_expr_eval_ctx_t *ctx, const void *data,
- // const char *arg);
- type
- ap_expr_op_unary_t = function(ctx: Pap_expr_eval_ctx_t; const data: Pointer;
- const arg: PChar): Integer; cdecl;
- {** Binary operator, takes two string arguments and returns a bool value.
- * The name must have the form '-cmp' (at least two letters).
- * @param ctx The evaluation context
- * @param data An opaque context provided by the lookup hook function
- * @param arg1 The left operand
- * @param arg2 The right operand
- * @return 0 or 1
- *}
- //typedef int ap_expr_op_binary_t(ap_expr_eval_ctx_t *ctx, const void *data,
- // const char *arg1, const char *arg2);
- ap_expr_op_binary_t = function(ctx: Pap_expr_eval_ctx_t; const data: Pointer;
- const arg1: PChar; const arg2: PChar): Integer; cdecl;
- {** String valued function, takes a string argument and returns a string
- * @param ctx The evaluation context
- * @param data An opaque context provided by the lookup hook function
- * @param arg The argument
- * @return The functions result string, may be NULL for 'empty string'
- *}
- //typedef const char *(ap_expr_string_func_t)(ap_expr_eval_ctx_t *ctx,
- // const void *data,
- // const char *arg);
- ap_expr_string_func_t = function(ctx: Pap_expr_eval_ctx_t;
- const data: Pointer;
- const arg: PChar): PChar; cdecl;
- {** List valued function, takes a string argument and returns a list of strings
- * Can currently only be called following the builtin '-in' operator.
- * @param ctx The evaluation context
- * @param data An opaque context provided by the lookup hook function
- * @param arg The argument
- * @return The functions result list of strings, may be NULL for 'empty array'
- *}
- //typedef apr_array_header_t *(ap_expr_list_func_t)(ap_expr_eval_ctx_t *ctx,
- // const void *data,
- // const char *arg);
- ap_expr_list_func_t = function(ctx: Pap_expr_eval_ctx_t;
- const data: Pointer;
- const arg: PChar): Papr_array_header_t;
- {** Variable lookup function, takes no argument and returns a string
- * @param ctx The evaluation context
- * @param data An opaque context provided by the lookup hook function
- * @return The expanded variable
- *}
- //typedef const char *(ap_expr_var_func_t)(ap_expr_eval_ctx_t *ctx,
- // const void *data);
- ap_expr_var_func_t = function(ctx: Pap_expr_eval_ctx_t;
- const data: Pointer): PChar; cdecl;
- const
- AP_EXPR_FUNC_VAR = 0;
- AP_EXPR_FUNC_STRING = 1;
- AP_EXPR_FUNC_LIST = 2;
- AP_EXPR_FUNC_OP_UNARY = 3;
- AP_EXPR_FUNC_OP_BINARY = 4;
- //** parameter struct passed to the lookup hook functions */
- type
- Pap_expr_lookup_parms = ^ap_expr_lookup_parms;
- ap_expr_lookup_parms = record
- //** type of the looked up object */
- type_: Integer;
- //#define AP_EXPR_FUNC_VAR 0 {fpc -> consts are moved up}
- //#define AP_EXPR_FUNC_STRING 1
- //#define AP_EXPR_FUNC_LIST 2
- //#define AP_EXPR_FUNC_OP_UNARY 3
- //#define AP_EXPR_FUNC_OP_BINARY 4
- //** name of the looked up object */
- name: PChar;
- flags: Integer;
- pool: Papr_pool_t;
- ptemp: Papr_pool_t;
- //** where to store the function pointer */
- func: PPointer;
- //** where to store the function's context */
- data: PPointer;
- //** where to store the error message (if any) */
- err: PPChar;
- {** arg for pre-parsing (only if a simple string).
- * For binary ops, this is the right argument. *}
- arg: PChar;
- end; {ap_expr_lookup_parms}
- {** Function for looking up the provider function for a variable, operator
- * or function in an expression.
- * @param parms The parameter struct, also determins where the result is
- * stored.
- * @return OK on success,
- * !OK on failure,
- * DECLINED if the requested name is not handled by this function
- *}
- //typedef int (ap_expr_lookup_fn_t)(ap_expr_lookup_parms *parms);
- type
- ap_expr_lookup_fn_t = function(parms: ap_expr_lookup_parms): Integer; cdecl;
- {** Default lookup function which just calls ap_run_expr_lookup().
- * ap_run_expr_lookup cannot be used directly because it has the wrong
- * calling convention under Windows.
- *}
- //AP_DECLARE_NONSTD(int) ap_expr_lookup_default(ap_expr_lookup_parms *parms);
- function ap_expr_lookup_default(parms: Pap_expr_lookup_parms): Integer; cdecl;
- external LibHTTPD name LibNamePrefix + 'ap_expr_lookup_default';
- //AP_DECLARE_HOOK(int, expr_lookup, (ap_expr_lookup_parms *parms))
- {macro ignored for now}
- {**
- * Parse an expression into a parse tree
- * @param pool Pool
- * @param ptemp temp pool
- * @param info The ap_expr_info_t struct (with values filled in)
- * @param expr The expression string to parse
- * @param lookup_fn The lookup function to use, NULL for default
- * @return NULL on success, error message on error.
- * A pointer to the resulting parse tree will be stored in
- * info->root_node.
- *}
- //AP_DECLARE(const char *) ap_expr_parse(apr_pool_t *pool, apr_pool_t *ptemp,
- // ap_expr_info_t *info, const char *expr,
- // ap_expr_lookup_fn_t *lookup_fn);
- function ap_expr_parse(pool, ptemp: Papr_pool_t;
- info: Pap_expr_info_t;
- const expr: PChar;
- lookup_fn: ap_expr_lookup_fn_t): PChar;
- {$IFDEF WINDOWS} stdcall; {$ELSE} cdecl; {$ENDIF}
- external LibHTTPD name LibNamePrefix + 'ap_expr_parse' + LibSuff20;
- {**
- * High level interface to ap_expr_parse that also creates ap_expr_info_t and
- * uses info from cmd_parms to fill in most of it.
- * @param cmd The cmd_parms struct
- * @param expr The expression string to parse
- * @param flags The flags to use, see AP_EXPR_FLAG_*
- * @param err Set to NULL on success, error message on error
- * @param lookup_fn The lookup function used to lookup vars, functions, and
- * operators
- * @param module_index The module_index to set for the expression
- * @return The parsed expression
- * @note Usually ap_expr_parse_cmd() should be used
- *}
- //AP_DECLARE(ap_expr_info_t *) ap_expr_parse_cmd_mi(const cmd_parms *cmd,
- // const char *expr,
- // unsigned int flags,
- // const char **err,
- // ap_expr_lookup_fn_t *lookup_fn,
- // int module_index);
- function ap_expr_parse_cmd_mi(cmd: Pcmd_parms;
- const expr: PChar;
- flags: cuint;
- const err: PPChar;
- lookup_fn: ap_expr_lookup_fn_t;
- module_index: Integer): PChar;
- {$IFDEF WINDOWS} stdcall; {$ELSE} cdecl; {$ENDIF}
- external LibHTTPD name LibNamePrefix + 'ap_expr_parse_cmd_mi' + LibSuff24;
- {**
- * Convenience wrapper for ap_expr_parse_cmd_mi() that sets
- * module_index = APLOG_MODULE_INDEX
- *}
- //#define ap_expr_parse_cmd(cmd, expr, flags, err, lookup_fn) \
- // ap_expr_parse_cmd_mi(cmd, expr, flags, err, lookup_fn, APLOG_MODULE_INDEX)
- {**
- * Internal initialisation of ap_expr (for httpd internal use)
- *}
- //void ap_expr_init(apr_pool_t *pool);
- //#endif /* AP_EXPR_H */
- //** @} */
|