Source
<?php
/*
** Copyright (C) 2001-2025 Zabbix SIA
**
** This program is free software: you can redistribute it and/or modify it under the terms of
** the GNU Affero General Public License as published by the Free Software Foundation, version 3.
**
** This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
** without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
** See the GNU Affero General Public License for more details.
**
** You should have received a copy of the GNU Affero General Public License along with this program.
** If not, see <https://www.gnu.org/licenses/>.
**/
/**
* A parser for function macros like "{{ITEM.VALUE}.func()}".
*/
class CMacroFunctionParser extends CParser {
/**
* Parser for generic macros.
*
* @var CMacroParser
*/
private $macro_parser;
/**
* Parser for trigger functions.
*
* @var C10FunctionParser
*/
private $function_parser;
/**
* @param array $options Parser options.
* @param array|bool $options['macros'] The list of macros, for example ['{ITEM.VALUE}', '{ITEM.LASTVALUE}']
* @param int $options['ref_type'] Reference options.
*/
public function __construct(array $options) {
$this->macro_parser = new CMacroParser($options);
$this->function_parser = new C10FunctionParser();
}
/**
* @param string $source
* @param int $pos
*
* @return int
*/
public function parse($source, $pos = 0) {
$this->length = 0;
$this->match = '';
$p = $pos;
if (!isset($source[$p]) || $source[$p] !== '{') {
return self::PARSE_FAIL;
}
$p++;
if ($this->macro_parser->parse($source, $p) == CParser::PARSE_FAIL) {