. */ /** * @package Doctrine * @subpackage Log * @author Konsta Vesterinen * @author Jonathan H. Wage * @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @link www.phpdoctrine.org * @since 1.0 * @version $Revision: 3155 $ */ class Doctrine_Log_Writer_Db extends Doctrine_Log_Writer_Abstract { /** * Doctrine_Table instance * * @var string */ private $_table; /** * Relates database columns names to log data field keys. * * @var null|array */ private $_columnMap; /** * Class constructor * * @param Doctrine_Db_Adapter $db Database adapter instance * @param string $table Log table in database * @param array $columnMap */ public function __construct($table, $columnMap = null) { if (!$table instanceof Doctrine_Table) { $table = Doctrine::getTable($table); } $this->_table = $table; $this->_columnMap = $columnMap; } /** * Formatting is not possible on this writer */ public function setFormatter($formatter) { throw new Doctrine_Log_Exception(get_class() . ' does not support formatting'); } /** * Remove reference to database adapter * * @return void */ public function shutdown() { $this->_table = null; } /** * Write a message to the log. * * @param array $event event data * @return void */ protected function _write($event) { if ($this->_table === null) { throw new Doctrine_Log_Exception('Database adapter instance has been removed by shutdown'); } if ($this->_columnMap === null) { $dataToInsert = $event; } else { $dataToInsert = array(); foreach ($this->_columnMap as $columnName => $fieldKey) { $dataToInsert[$columnName] = $event[$fieldKey]; } } $record = $this->_table->create($dataToInsert); $record->save(); } }