139 lines
3.3 KiB
PHP
139 lines
3.3 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace GeneratePress\WPContentImporter2;
|
||
|
|
||
|
/**
|
||
|
* Describes a logger instance
|
||
|
*
|
||
|
* Based on PSR-3: http://www.php-fig.org/psr/psr-3/
|
||
|
*
|
||
|
* The message MUST be a string or object implementing __toString().
|
||
|
*
|
||
|
* The message MAY contain placeholders in the form: {foo} where foo
|
||
|
* will be replaced by the context data in key "foo".
|
||
|
*
|
||
|
* The context array can contain arbitrary data, the only assumption that
|
||
|
* can be made by implementors is that if an Exception instance is given
|
||
|
* to produce a stack trace, it MUST be in a key named "exception".
|
||
|
*
|
||
|
* See https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-3-logger-interface.md
|
||
|
* for the full interface specification.
|
||
|
*/
|
||
|
class WPImporterLogger {
|
||
|
/**
|
||
|
* System is unusable.
|
||
|
*
|
||
|
* @param string $message
|
||
|
* @param array $context
|
||
|
* @return null
|
||
|
*/
|
||
|
public function emergency( $message, array $context = array() ) {
|
||
|
return $this->log( 'emergency', $message, $context );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Action must be taken immediately.
|
||
|
*
|
||
|
* Example: Entire website down, database unavailable, etc. This should
|
||
|
* trigger the SMS alerts and wake you up.
|
||
|
*
|
||
|
* @param string $message
|
||
|
* @param array $context
|
||
|
* @return null
|
||
|
*/
|
||
|
public function alert( $message, array $context = array() ) {
|
||
|
return $this->log( 'alert', $message, $context );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Critical conditions.
|
||
|
*
|
||
|
* Example: Application component unavailable, unexpected exception.
|
||
|
*
|
||
|
* @param string $message
|
||
|
* @param array $context
|
||
|
* @return null
|
||
|
*/
|
||
|
public function critical( $message, array $context = array() ) {
|
||
|
return $this->log( 'critical', $message, $context );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Runtime errors that do not require immediate action but should typically
|
||
|
* be logged and monitored.
|
||
|
*
|
||
|
* @param string $message
|
||
|
* @param array $context
|
||
|
* @return null
|
||
|
*/
|
||
|
public function error( $message, array $context = array()) {
|
||
|
return $this->log( 'error', $message, $context );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Exceptional occurrences that are not errors.
|
||
|
*
|
||
|
* Example: Use of deprecated APIs, poor use of an API, undesirable things
|
||
|
* that are not necessarily wrong.
|
||
|
*
|
||
|
* @param string $message
|
||
|
* @param array $context
|
||
|
* @return null
|
||
|
*/
|
||
|
public function warning( $message, array $context = array() ) {
|
||
|
return $this->log( 'warning', $message, $context );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Normal but significant events.
|
||
|
*
|
||
|
* @param string $message
|
||
|
* @param array $context
|
||
|
* @return null
|
||
|
*/
|
||
|
public function notice( $message, array $context = array() ) {
|
||
|
return $this->log( 'notice', $message, $context );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Interesting events.
|
||
|
*
|
||
|
* Example: User logs in, SQL logs.
|
||
|
*
|
||
|
* @param string $message
|
||
|
* @param array $context
|
||
|
* @return null
|
||
|
*/
|
||
|
public function info( $message, array $context = array() ) {
|
||
|
return $this->log( 'info', $message, $context );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Detailed debug information.
|
||
|
*
|
||
|
* @param string $message
|
||
|
* @param array $context
|
||
|
* @return null
|
||
|
*/
|
||
|
public function debug( $message, array $context = array() ) {
|
||
|
return $this->log( 'debug', $message, $context );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Logs with an arbitrary level.
|
||
|
*
|
||
|
* @param mixed $level
|
||
|
* @param string $message
|
||
|
* @param array $context
|
||
|
* @return null
|
||
|
*/
|
||
|
public function log( $level, $message, array $context = array() ) {
|
||
|
$this->messages[] = array(
|
||
|
'timestamp' => time(),
|
||
|
'level' => $level,
|
||
|
'message' => $message,
|
||
|
'context' => $context,
|
||
|
);
|
||
|
}
|
||
|
}
|