Blame | Letzte Änderung | Log anzeigen | RSS feed
<?php/** $Id: MojaviLogAdapter.php 1262 2009-10-26 20:54:39Z francois $** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.** This software consists of voluntary contributions made by many individuals* and is licensed under the LGPL. For more information please see* <http://propel.phpdb.org>.*//*** Mojavi logging adapter for propel** @author Brandon Keepers <brandon@opensoul.org>* @version $Revision: 1262 $* @package propel.logger*/class MojaviLogAdapter implements BasicLogger {/*** Instance of mojavi logger*/private $logger = null;/*** constructor for setting up Mojavi log adapter** @param ErrorLog $logger instance of Mojavi error log obtained by* calling LogManager::getLogger();*/public function __construct($logger = null){$this->logger = $logger;}/*** A convenience function for logging an alert event.** @param mixed $message String or Exception object containing the message* to log.*/public function alert($message){$this->log($message, 'alert');}/*** A convenience function for logging a critical event.** @param mixed $message String or Exception object containing the message* to log.*/public function crit($message){$this->log($message, 'crit');}/*** A convenience function for logging an error event.** @param mixed $message String or Exception object containing the message* to log.*/public function err($message){$this->log($message, 'err');}/*** A convenience function for logging a warning event.** @param mixed $message String or Exception object containing the message* to log.*/public function warning($message){$this->log($message, 'warning');}/*** A convenience function for logging an critical event.** @param mixed $message String or Exception object containing the message* to log.*/public function notice($message){$this->log($message, 'notice');}/*** A convenience function for logging an critical event.** @param mixed $message String or Exception object containing the message* to log.*/public function info($message){$this->log($message, 'info');}/*** A convenience function for logging a debug event.** @param mixed $message String or Exception object containing the message* to log.*/public function debug($message){$this->log($message, 'debug');}/*** Primary method to handle logging.** @param mixed $message String or Exception object containing the message* to log.* @param int $severity The numeric severity. Defaults to null so that no* assumptions are made about the logging backend.*/public function log($message, $severity = null){if (is_null($this->logger))$this->logger = LogManager::getLogger('propel');switch($severity){case 'crit':$method = 'fatal';break;case 'err':$method = 'error';break;case 'alert':case 'warning':$method = 'warning';break;case 'notice':case 'info':$method = 'info';break;case 'debug':default:$method = 'debug';}// get a backtrace to pass class, function, file, & line to Mojavi logger$trace = debug_backtrace();// call the appropriate Mojavi logger method$this->logger->{$method} ($message,$trace[2]['class'],$trace[2]['function'],$trace[1]['file'],$trace[1]['line']);}}