| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 | <?php/** * Refer to LICENSE.txt distributed with the Temando Shipping module for notice of license */namespace Temando\Shipping\Webservice;use Magento\Framework\Logger\Monolog;use Temando\Shipping\Rest\Exception\RestClientErrorException;use Temando\Shipping\Webservice\Config\WsConfigInterface;use Temando\Shipping\Webservice\Exception\HttpResponseException;/** * Webservice communication logger * * @package  Temando\Shipping\Webservice * @author   Christoph Aßmann <christoph.assmann@netresearch.de> * @license  http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0) * @link     http://www.temando.com/ */class Logger extends Monolog{    /**     * @var WsConfigInterface     */    private $config;    /**     * Logger constructor.     * @param string $name     * @param WsConfigInterface $config     * @param \Monolog\Handler\HandlerInterface[] $handlers     * @param callable[] $processors     */    public function __construct(        $name,        WsConfigInterface $config,        array $handlers = [],        array $processors = []    ) {        $this->config = $config;        parent::__construct($name, $handlers, $processors);    }    /**     * @param string $message     * @param mixed[] $context     * @return string     */    private function addMessageContext($message, array $context = [])    {        if (isset($context['exception']) && ($context['exception'] instanceof RestClientErrorException)) {            /** @var RestClientErrorException $exception */            $exception = $context['exception'];            $previous = $exception->getPrevious();            if ($previous instanceof HttpResponseException) {                $message = sprintf("%s\n%s", $previous->getResponseHeaders(), $message);            }        }        return $message;    }    /**     * Log message if logging is enabled via module config.     * Disregard module config in error cases.     *     * @param mixed $level     * @param string $message     * @param array $context     * @return bool     */    public function log($level, $message, array $context = [])    {        $monologLevel = parent::toMonologLevel($level);        if ($this->config->isLoggingEnabled() || $monologLevel >= Monolog::ERROR) {            $message = $this->addMessageContext($message, $context);            return parent::log($level, $message, $context);        }        return false;    }}
 |