pictcode / lib / Cake / Log / LogEngineCollection.php @ master
履歴 | 表示 | アノテート | ダウンロード (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 | } |