| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 | <?php/** * Copyright © Magento, Inc. All rights reserved. * See COPYING.txt for license details. */namespace Magento\ImportExport\Model;use Magento\Framework\App\Filesystem\DirectoryList;/** * Operation abstract class * * @author      Magento Core Team <core@magentocommerce.com> */abstract class AbstractModel extends \Magento\Framework\DataObject{    /**     * Enable logging     *     * @var bool     */    protected $_debugMode = false;    /**     * Fields that should be replaced in debug with '***'     *     * @var string[]     */    protected $_debugReplacePrivateDataKeys = [];    /**     * Contains all log information     *     * @var string[]     */    protected $_logTrace = [];    /**     * @var \Psr\Log\LoggerInterface     */    protected $_logger;    /**     * @var \Magento\Framework\Filesystem\Directory\WriteInterface     */    protected $_varDirectory;    /**     * @param \Psr\Log\LoggerInterface $logger     * @param \Magento\Framework\Filesystem $filesystem     * @param array $data     */    public function __construct(        \Psr\Log\LoggerInterface $logger,        \Magento\Framework\Filesystem $filesystem,        array $data = []    ) {        $this->_logger = $logger;        $this->_varDirectory = $filesystem->getDirectoryWrite(DirectoryList::VAR_DIR);        parent::__construct($data);    }    /**     * Log debug data to file.     * Log file dir: var/log/import_export/%Y/%m/%d/%time%_%operation_type%_%entity_type%.log     *     * @param mixed $debugData     * @return $this     */    public function addLogComment($debugData)    {        if (is_array($debugData)) {            $this->_logTrace = array_merge($this->_logTrace, $debugData);        } else {            $this->_logTrace[] = $debugData;        }        if ($this->_debugMode) {            $this->_logger->debug(var_export($debugData, true));        }        return $this;    }    /**     * Return human readable debug trace.     *     * @return string     */    public function getFormatedLogTrace()    {        $trace = '';        $lineNumber = 1;        foreach ($this->_logTrace as &$info) {            $trace .= $lineNumber++ . ': ' . $info . "\n";        }        return $trace;    }}
 |