File indexing completed on 2024-12-22 05:36:50
0001 <?php 0002 /** 0003 * Zend Framework 0004 * 0005 * LICENSE 0006 * 0007 * This source file is subject to the new BSD license that is bundled 0008 * with this package in the file LICENSE.txt. 0009 * It is also available through the world-wide-web at this URL: 0010 * http://framework.zend.com/license/new-bsd 0011 * If you did not receive a copy of the license and are unable to 0012 * obtain it through the world-wide-web, please send an email 0013 * to license@zend.com so we can send you a copy immediately. 0014 * 0015 * @category Zend 0016 * @package Zend_Log 0017 * @subpackage Filter 0018 * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com) 0019 * @license http://framework.zend.com/license/new-bsd New BSD License 0020 * @version $Id$ 0021 */ 0022 0023 /** Zend_Log_Filter_Abstract */ 0024 // require_once 'Zend/Log/Filter/Abstract.php'; 0025 0026 /** 0027 * @category Zend 0028 * @package Zend_Log 0029 * @subpackage Filter 0030 * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com) 0031 * @license http://framework.zend.com/license/new-bsd New BSD License 0032 * @version $Id$ 0033 */ 0034 class Zend_Log_Filter_Message extends Zend_Log_Filter_Abstract 0035 { 0036 /** 0037 * @var string 0038 */ 0039 protected $_regexp; 0040 0041 /** 0042 * Filter out any log messages not matching $regexp. 0043 * 0044 * @param string $regexp Regular expression to test the log message 0045 * @return void 0046 * @throws Zend_Log_Exception 0047 */ 0048 public function __construct($regexp) 0049 { 0050 if (@preg_match($regexp, '') === false) { 0051 // require_once 'Zend/Log/Exception.php'; 0052 throw new Zend_Log_Exception("Invalid regular expression '$regexp'"); 0053 } 0054 $this->_regexp = $regexp; 0055 } 0056 0057 /** 0058 * Create a new instance of Zend_Log_Filter_Message 0059 * 0060 * @param array|Zend_Config $config 0061 * @return Zend_Log_Filter_Message 0062 */ 0063 static public function factory($config) 0064 { 0065 $config = self::_parseConfig($config); 0066 $config = array_merge(array( 0067 'regexp' => null 0068 ), $config); 0069 0070 return new self( 0071 $config['regexp'] 0072 ); 0073 } 0074 0075 /** 0076 * Returns TRUE to accept the message, FALSE to block it. 0077 * 0078 * @param array $event event data 0079 * @return boolean accepted? 0080 */ 0081 public function accept($event) 0082 { 0083 return preg_match($this->_regexp, $event['message']) > 0; 0084 } 0085 }