pictcode / lib / Cake / Log / LogEngineCollection.php @ 0b1b8047
履歴 | 表示 | アノテート | ダウンロード (2.364 KB)
| 1 | 635eef61 | spyder1211 | <?php
|
|---|---|---|---|
| 2 | /**
|
||
| 3 | * Registry of loaded log engines
|
||
| 4 | *
|
||
| 5 | * CakePHP(tm) : Rapid Development Framework (http://cakephp.org)
|
||
| 6 | * Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
|
||
| 7 | *
|
||
| 8 | * Licensed under The MIT License
|
||
| 9 | * For full copyright and license information, please see the LICENSE.txt
|
||
| 10 | * Redistributions of files must retain the above copyright notice.
|
||
| 11 | *
|
||
| 12 | * @copyright Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
|
||
| 13 | * @link http://cakephp.org CakePHP(tm) Project
|
||
| 14 | * @package Cake.Log
|
||
| 15 | * @since CakePHP(tm) v 2.2
|
||
| 16 | * @license http://www.opensource.org/licenses/mit-license.php MIT License
|
||
| 17 | */
|
||
| 18 | |||
| 19 | App::uses('ObjectCollection', 'Utility'); |
||
| 20 | |||
| 21 | /**
|
||
| 22 | * Registry of loaded log engines
|
||
| 23 | *
|
||
| 24 | * @package Cake.Log
|
||
| 25 | */
|
||
| 26 | class LogEngineCollection extends ObjectCollection { |
||
| 27 | |||
| 28 | /**
|
||
| 29 | * Loads/constructs a Log engine.
|
||
| 30 | *
|
||
| 31 | * @param string $name instance identifier
|
||
| 32 | * @param array $options Setting for the Log Engine
|
||
| 33 | * @return BaseLog BaseLog engine instance
|
||
| 34 | * @throws CakeLogException when logger class does not implement a write method
|
||
| 35 | */
|
||
| 36 | public function load($name, $options = array()) { |
||
| 37 | $enable = isset($options['enabled']) ? $options['enabled'] : true; |
||
| 38 | $loggerName = $options['engine']; |
||
| 39 | unset($options['engine']); |
||
| 40 | $className = $this->_getLogger($loggerName); |
||
| 41 | $logger = new $className($options); |
||
| 42 | if (!$logger instanceof CakeLogInterface) { |
||
| 43 | throw new CakeLogException( |
||
| 44 | __d('cake_dev', 'logger class %s does not implement a %s method.', $loggerName, 'write()') |
||
| 45 | ); |
||
| 46 | } |
||
| 47 | $this->_loaded[$name] = $logger; |
||
| 48 | if ($enable) { |
||
| 49 | $this->enable($name); |
||
| 50 | } |
||
| 51 | return $logger; |
||
| 52 | } |
||
| 53 | |||
| 54 | /**
|
||
| 55 | * Attempts to import a logger class from the various paths it could be on.
|
||
| 56 | * Checks that the logger class implements a write method as well.
|
||
| 57 | *
|
||
| 58 | * @param string $loggerName the plugin.className of the logger class you want to build.
|
||
| 59 | * @return mixed boolean false on any failures, string of classname to use if search was successful.
|
||
| 60 | * @throws CakeLogException
|
||
| 61 | */
|
||
| 62 | protected static function _getLogger($loggerName) { |
||
| 63 | list($plugin, $loggerName) = pluginSplit($loggerName, true); |
||
| 64 | if (substr($loggerName, -3) !== 'Log') { |
||
| 65 | $loggerName .= 'Log'; |
||
| 66 | } |
||
| 67 | App::uses($loggerName, $plugin . 'Log/Engine'); |
||
| 68 | if (!class_exists($loggerName)) { |
||
| 69 | throw new CakeLogException(__d('cake_dev', 'Could not load class %s', $loggerName)); |
||
| 70 | } |
||
| 71 | return $loggerName; |
||
| 72 | } |
||
| 73 | |||
| 74 | } |