* @copyright Since 2007 PrestaShop SA and Contributors * @license https://opensource.org/licenses/AFL-3.0 Academic Free License version 3.0 */ namespace PrestaShop\Module\PrestashopCheckout\Logger; use Monolog\Handler\HandlerInterface; use Monolog\Logger; use Monolog\Processor\ProcessIdProcessor; use Monolog\Processor\PsrLogMessageProcessor; use PrestaShop\Module\PrestashopCheckout\Exception\PsCheckoutException; use Psr\Log\LoggerInterface; /** * Class responsible for create Logger instance. */ class LoggerFactory { const PS_CHECKOUT_LOGGER_MAX_FILES = 'PS_CHECKOUT_LOGGER_MAX_FILES'; const PS_CHECKOUT_LOGGER_LEVEL = 'PS_CHECKOUT_LOGGER_LEVEL'; const PS_CHECKOUT_LOGGER_HTTP = 'PS_CHECKOUT_LOGGER_HTTP'; const PS_CHECKOUT_LOGGER_HTTP_FORMAT = 'PS_CHECKOUT_LOGGER_HTTP_FORMAT'; /** * @var string */ private $name; /** * @var HandlerInterface */ private $loggerHandler; /** * @param string $name * @param HandlerInterface $loggerHandler * * @throws PsCheckoutException */ public function __construct($name, HandlerInterface $loggerHandler) { $this->assertNameIsValid($name); $this->name = $name; $this->loggerHandler = $loggerHandler; } /** * @return LoggerInterface */ public function build() { return new Logger( $this->name, [ $this->loggerHandler, ], [ new ProcessIdProcessor(), new PsrLogMessageProcessor(), ] ); } /** * @param string $name * * @throws PsCheckoutException */ private function assertNameIsValid($name) { if (empty($name)) { throw new PsCheckoutException('Logger name cannot be empty.', PsCheckoutException::UNKNOWN); } if (!is_string($name)) { throw new PsCheckoutException('Logger name should be a string.', PsCheckoutException::UNKNOWN); } if (!preg_match('/^[a-zA-Z0-9_.-]+$/', $name)) { throw new PsCheckoutException('Logger name is invalid.', PsCheckoutException::UNKNOWN); } } }