bytic /
logger
| 1 | <?php |
||
| 2 | |||
| 3 | namespace Nip\Logger\Manager; |
||
| 4 | |||
| 5 | use Nip\Logger\Logger; |
||
| 6 | use Throwable; |
||
| 7 | |||
| 8 | /** |
||
| 9 | * Trait HasDrivers |
||
| 10 | * @package Nip\Logger\Traits |
||
| 11 | */ |
||
| 12 | trait HasDrivers |
||
| 13 | { |
||
| 14 | |||
| 15 | /** |
||
| 16 | * Get a log driver instance. |
||
| 17 | * |
||
| 18 | * @param string|null $driver |
||
| 19 | * @return Logger|\Psr\Log\LoggerInterface |
||
| 20 | */ |
||
| 21 | 4 | public function driver($driver = null) |
|
| 22 | { |
||
| 23 | 4 | return $this->get($driver ?? $this->getDefaultDriver()); |
|
| 24 | } |
||
| 25 | |||
| 26 | /** |
||
| 27 | * Get the default log driver name. |
||
| 28 | * |
||
| 29 | * @return string |
||
| 30 | */ |
||
| 31 | 1 | public function getDefaultDriver() |
|
| 32 | { |
||
| 33 | 1 | return static::getPackageConfig("default", 'single'); |
|
| 34 | } |
||
| 35 | |||
| 36 | /** |
||
| 37 | * Attempt to get the log from the local cache. |
||
| 38 | * |
||
| 39 | * @param string $name |
||
| 40 | * @return \Psr\Log\LoggerInterface |
||
| 41 | */ |
||
| 42 | 4 | protected function get($name) |
|
| 43 | { |
||
| 44 | try { |
||
| 45 | 4 | return $this->channels[$name] ?? $this->initDriver($name); |
|
| 46 | } catch (Throwable $exception) { |
||
| 47 | return $this->createEmergencyLogger(); |
||
|
0 ignored issues
–
show
Bug
introduced
by
Loading history...
|
|||
| 48 | } |
||
| 49 | } |
||
| 50 | |||
| 51 | /** |
||
| 52 | * @param string $name |
||
| 53 | * @return mixed |
||
| 54 | */ |
||
| 55 | abstract protected function initDriver($name); |
||
| 56 | } |
||
| 57 |