You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
94 lines
2.9 KiB
94 lines
2.9 KiB
13 years ago
|
<?php
|
||
|
/**
|
||
|
* @link http://www.yiiframework.com/
|
||
12 years ago
|
* @copyright Copyright (c) 2008 Yii Software LLC
|
||
13 years ago
|
* @license http://www.yiiframework.com/license/
|
||
|
*/
|
||
|
|
||
13 years ago
|
namespace yii\logging;
|
||
13 years ago
|
|
||
12 years ago
|
use Yii;
|
||
12 years ago
|
use yii\db\Connection;
|
||
|
use yii\base\InvalidConfigException;
|
||
|
|
||
13 years ago
|
/**
|
||
13 years ago
|
* DbTarget stores log messages in a database table.
|
||
13 years ago
|
*
|
||
12 years ago
|
* By default, DbTarget stores the log messages in a DB table named 'tbl_log'. This table
|
||
|
* must be pre-created. The table name can be changed by setting [[logTable]].
|
||
13 years ago
|
*
|
||
|
* @author Qiang Xue <qiang.xue@gmail.com>
|
||
13 years ago
|
* @since 2.0
|
||
13 years ago
|
*/
|
||
13 years ago
|
class DbTarget extends Target
|
||
13 years ago
|
{
|
||
|
/**
|
||
12 years ago
|
* @var Connection|string the DB connection object or the application component ID of the DB connection.
|
||
|
* After the DbTarget object is created, if you want to change this property, you should only assign it
|
||
|
* with a DB connection object.
|
||
13 years ago
|
*/
|
||
12 years ago
|
public $db = 'db';
|
||
13 years ago
|
/**
|
||
12 years ago
|
* @var string name of the DB table to store cache content.
|
||
|
* The table should be pre-created as follows:
|
||
13 years ago
|
*
|
||
|
* ~~~
|
||
|
* CREATE TABLE tbl_log (
|
||
12 years ago
|
* id BIGINT NOT NULL AUTO_INCREMENT PRIMARY KEY,
|
||
12 years ago
|
* level INTEGER,
|
||
13 years ago
|
* category VARCHAR(255),
|
||
|
* log_time INTEGER,
|
||
|
* message TEXT,
|
||
|
* INDEX idx_log_level (level),
|
||
|
* INDEX idx_log_category (category)
|
||
|
* )
|
||
|
* ~~~
|
||
|
*
|
||
|
* Note that the 'id' column must be created as an auto-incremental column.
|
||
12 years ago
|
* The above SQL uses the MySQL syntax. If you are using other DBMS, you need
|
||
12 years ago
|
* to adjust it accordingly. For example, in PostgreSQL, it should be `id SERIAL PRIMARY KEY`.
|
||
13 years ago
|
*
|
||
|
* The indexes declared above are not required. They are mainly used to improve the performance
|
||
|
* of some queries about message levels and categories. Depending on your actual needs, you may
|
||
12 years ago
|
* want to create additional indexes (e.g. index on `log_time`).
|
||
13 years ago
|
*/
|
||
12 years ago
|
public $logTable = 'tbl_log';
|
||
13 years ago
|
|
||
|
/**
|
||
12 years ago
|
* Initializes the DbTarget component.
|
||
|
* This method will initialize the [[db]] property to make sure it refers to a valid DB connection.
|
||
|
* @throws InvalidConfigException if [[db]] is invalid.
|
||
13 years ago
|
*/
|
||
12 years ago
|
public function init()
|
||
13 years ago
|
{
|
||
12 years ago
|
parent::init();
|
||
|
if (is_string($this->db)) {
|
||
|
$this->db = Yii::$app->getComponent($this->db);
|
||
|
}
|
||
|
if (!$this->db instanceof Connection) {
|
||
|
throw new InvalidConfigException("DbTarget::db must be either a DB connection instance or the application component ID of a DB connection.");
|
||
13 years ago
|
}
|
||
12 years ago
|
}
|
||
|
|
||
|
/**
|
||
12 years ago
|
* Stores log messages to DB.
|
||
|
* @param array $messages the messages to be exported. See [[Logger::messages]] for the structure
|
||
|
* of each message.
|
||
13 years ago
|
*/
|
||
12 years ago
|
public function export($messages)
|
||
13 years ago
|
{
|
||
12 years ago
|
$tableName = $this->db->quoteTableName($this->logTable);
|
||
12 years ago
|
$sql = "INSERT INTO $tableName ([[level]], [[category]], [[log_time]], [[message]])
|
||
|
VALUES (:level, :category, :log_time, :message)";
|
||
12 years ago
|
$command = $this->db->createCommand($sql);
|
||
12 years ago
|
foreach ($messages as $message) {
|
||
13 years ago
|
$command->bindValues(array(
|
||
|
':level' => $message[1],
|
||
|
':category' => $message[2],
|
||
|
':log_time' => $message[3],
|
||
|
':message' => $message[0],
|
||
|
))->execute();
|
||
13 years ago
|
}
|
||
|
}
|
||
|
}
|