mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
e46135be0a
- Turn sake into a symfony/console app - Avoid using HTTPRequest for CLI interaction - Implement abstract hybrid execution path
75 lines
2.6 KiB
YAML
75 lines
2.6 KiB
YAML
---
|
|
Name: logging
|
|
---
|
|
# Core error logging is built up of a chain containing:
|
|
# - A top level \ErrorHandler which registers the error service
|
|
# - A \Logger which acts as the error service
|
|
# - A \HandlerInterface which handles errors for the logger
|
|
# - One or more \FormatterInterface which format errors for the handler
|
|
#
|
|
# Logging for use outside of core error handling also uses the same implementations,
|
|
# but is available without the HandlerInterfaces attached
|
|
SilverStripe\Core\Injector\Injector:
|
|
SilverStripe\Logging\ErrorHandler:
|
|
class: SilverStripe\Logging\MonologErrorHandler
|
|
calls:
|
|
pushDefaultLogger: [ pushLogger, [ '%$Psr\Log\LoggerInterface' ] ]
|
|
pushErrorHandler: [ pushLogger, [ '%$Psr\Log\LoggerInterface.errorhandler' ] ]
|
|
|
|
# Default implementation for use as a standard logger. Up to developers to attach their own
|
|
# handlers
|
|
Psr\Log\LoggerInterface:
|
|
type: singleton
|
|
class: Monolog\Logger
|
|
constructor:
|
|
- "error-log"
|
|
# Core error handling
|
|
Psr\Log\LoggerInterface.errorhandler:
|
|
type: singleton
|
|
class: Monolog\Logger
|
|
constructor:
|
|
- "error-handler"
|
|
calls:
|
|
pushDisplayErrorHandler: [ pushHandler, [ '%$Monolog\Handler\HandlerInterface' ] ]
|
|
---
|
|
Name: loggingformatters
|
|
---
|
|
SilverStripe\Core\Injector\Injector:
|
|
# Display detailed information on an error
|
|
Monolog\Formatter\FormatterInterface.detailed:
|
|
class: SilverStripe\Logging\DetailedErrorFormatter
|
|
# Display friendly error messages and suppresses possible disclosure of dev configuration
|
|
Monolog\Formatter\FormatterInterface.friendly:
|
|
class: SilverStripe\Logging\DebugViewFriendlyErrorFormatter
|
|
properties:
|
|
Title: "There has been an error"
|
|
Body: "The website server has not been able to respond to your request"
|
|
---
|
|
Name: dev-logging
|
|
Only:
|
|
environment: dev
|
|
---
|
|
# Dev handler outputs detailed information including notices
|
|
SilverStripe\Core\Injector\Injector:
|
|
Monolog\Handler\HandlerInterface:
|
|
class: SilverStripe\Logging\ErrorOutputHandler
|
|
constructor:
|
|
- "notice"
|
|
properties:
|
|
DefaultFormatter: '%$Monolog\Formatter\FormatterInterface.detailed'
|
|
---
|
|
Name: live-logging
|
|
Except:
|
|
environment: dev
|
|
---
|
|
# Live handler outputs user-friendly error details, and ignores notices
|
|
# CLI errors still show full details
|
|
SilverStripe\Core\Injector\Injector:
|
|
Monolog\Handler\HandlerInterface:
|
|
class: SilverStripe\Logging\ErrorOutputHandler
|
|
constructor:
|
|
- "error"
|
|
properties:
|
|
DefaultFormatter: '%$Monolog\Formatter\FormatterInterface.friendly'
|
|
CLIFormatter: '%$Monolog\Formatter\FormatterInterface.detailed'
|