2020-04-16 15:26:03 +03:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* MIT License
|
|
|
|
*
|
|
|
|
* Copyright (c) 2020 DIGITAL RETAIL TECHNOLOGIES SL
|
|
|
|
*
|
|
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
|
|
* in the Software without restriction, including without limitation the rights
|
|
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
|
|
* furnished to do so, subject to the following conditions:
|
|
|
|
*
|
|
|
|
* The above copyright notice and this permission notice shall be included in
|
|
|
|
* all copies or substantial portions of the Software.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
|
|
* SOFTWARE.
|
|
|
|
*
|
|
|
|
* DISCLAIMER
|
|
|
|
*
|
|
|
|
* Do not edit or add to this file if you wish to upgrade PrestaShop to newer
|
|
|
|
* versions in the future. If you wish to customize PrestaShop for your
|
|
|
|
* needs please refer to http://www.prestashop.com for more information.
|
|
|
|
*
|
|
|
|
* @author DIGITAL RETAIL TECHNOLOGIES SL <mail@simlachat.com>
|
|
|
|
* @copyright 2020 DIGITAL RETAIL TECHNOLOGIES SL
|
|
|
|
* @license https://opensource.org/licenses/MIT The MIT License
|
|
|
|
*
|
|
|
|
* Don't forget to prefix your containers with your own identifier
|
|
|
|
* to avoid any conflicts with others containers.
|
|
|
|
*/
|
|
|
|
if (!defined('_PS_VERSION_')) {
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Class RetailcrmLogger
|
|
|
|
* @author DIGITAL RETAIL TECHNOLOGIES SL <mail@simlachat.com>
|
|
|
|
* @license GPL
|
|
|
|
* @link https://retailcrm.ru
|
|
|
|
*/
|
|
|
|
class RetailcrmLogger
|
|
|
|
{
|
2020-04-23 15:49:29 +03:00
|
|
|
static $cloneToStdout;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set to true if you want all output to be cloned into STDOUT
|
|
|
|
*
|
|
|
|
* @param bool $cloneToStdout
|
|
|
|
*/
|
|
|
|
public static function setCloneToStdout($cloneToStdout)
|
|
|
|
{
|
|
|
|
self::$cloneToStdout = $cloneToStdout;
|
|
|
|
}
|
|
|
|
|
2020-04-16 15:26:03 +03:00
|
|
|
/**
|
|
|
|
* Write entry to log
|
|
|
|
*
|
|
|
|
* @param string $caller
|
|
|
|
* @param string $message
|
|
|
|
*/
|
|
|
|
public static function writeCaller($caller, $message)
|
|
|
|
{
|
2020-04-23 15:49:29 +03:00
|
|
|
$result = sprintf(
|
|
|
|
'[%s] @ [%s] %s' . PHP_EOL,
|
|
|
|
date(DATE_RFC3339),
|
|
|
|
$caller,
|
|
|
|
$message
|
|
|
|
);
|
|
|
|
|
2020-04-16 15:26:03 +03:00
|
|
|
error_log(
|
2020-04-23 15:49:29 +03:00
|
|
|
$result,
|
2020-04-16 15:26:03 +03:00
|
|
|
3,
|
2020-04-23 15:49:29 +03:00
|
|
|
static::getLogFile()
|
2020-04-16 15:26:03 +03:00
|
|
|
);
|
2020-04-23 15:49:29 +03:00
|
|
|
|
|
|
|
if (self::$cloneToStdout) {
|
|
|
|
self::output($result, '');
|
|
|
|
}
|
2020-04-16 15:26:03 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Write entry to log without caller name
|
|
|
|
*
|
|
|
|
* @param string $message
|
|
|
|
*/
|
|
|
|
public static function writeNoCaller($message)
|
|
|
|
{
|
2020-04-23 15:49:29 +03:00
|
|
|
$result = sprintf(
|
|
|
|
'[%s] %s' . PHP_EOL,
|
|
|
|
date(DATE_RFC3339),
|
|
|
|
$message
|
|
|
|
);
|
|
|
|
|
2020-04-16 15:26:03 +03:00
|
|
|
error_log(
|
2020-04-23 15:49:29 +03:00
|
|
|
$result,
|
2020-04-16 15:26:03 +03:00
|
|
|
3,
|
2020-04-23 15:49:29 +03:00
|
|
|
static::getLogFile()
|
2020-04-16 15:26:03 +03:00
|
|
|
);
|
2020-04-23 15:49:29 +03:00
|
|
|
|
|
|
|
if (self::$cloneToStdout) {
|
|
|
|
self::output($result, '');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Output message to stdout
|
|
|
|
*
|
|
|
|
* @param string $message
|
|
|
|
* @param string $end
|
|
|
|
*/
|
|
|
|
public static function output($message = '', $end = PHP_EOL)
|
|
|
|
{
|
|
|
|
if (php_sapi_name() == 'cli') {
|
|
|
|
echo $message . $end;
|
|
|
|
}
|
2020-04-16 15:26:03 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Write debug log record
|
|
|
|
*
|
|
|
|
* @param string $caller
|
|
|
|
* @param mixed $message
|
|
|
|
*/
|
|
|
|
public static function writeDebug($caller, $message)
|
|
|
|
{
|
|
|
|
if (RetailcrmTools::isDebug()) {
|
|
|
|
static::writeNoCaller(sprintf(
|
|
|
|
'(DEBUG) <%s> %s',
|
|
|
|
$caller,
|
|
|
|
print_r($message, true)
|
|
|
|
));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-08 16:09:45 +03:00
|
|
|
/**
|
|
|
|
* Debug log record with multiple entries
|
|
|
|
*
|
|
|
|
* @param string $caller
|
|
|
|
* @param array|string $messages
|
|
|
|
*/
|
|
|
|
public static function writeDebugArray($caller, $messages)
|
|
|
|
{
|
|
|
|
if (RetailcrmTools::isDebug()) {
|
|
|
|
if (!empty($caller) && !empty($messages)) {
|
|
|
|
$result = is_array($messages) ? substr(
|
|
|
|
array_reduce(
|
|
|
|
$messages,
|
|
|
|
function ($carry, $item) {
|
|
|
|
$carry .= ' ' . print_r($item, true);
|
|
|
|
return $carry;
|
|
|
|
}
|
|
|
|
),
|
|
|
|
1
|
|
|
|
) : $messages;
|
|
|
|
|
|
|
|
self::writeDebug($caller, $result);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-04-16 15:26:03 +03:00
|
|
|
/**
|
2020-04-23 15:49:29 +03:00
|
|
|
* Returns log file path
|
2020-04-16 15:26:03 +03:00
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2020-04-23 15:49:29 +03:00
|
|
|
public static function getLogFile()
|
2020-04-16 15:26:03 +03:00
|
|
|
{
|
|
|
|
if (!defined('_PS_ROOT_DIR_')) {
|
|
|
|
return '';
|
|
|
|
}
|
|
|
|
|
2021-05-28 14:32:43 +03:00
|
|
|
return self::getLogDir() . '/retailcrm_' . self::getLogFilePrefix() . '_' . date('Y_m_d') . '.log';
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function getLogDir()
|
|
|
|
{
|
|
|
|
return _PS_ROOT_DIR_ . '/var/logs';
|
2020-04-23 15:49:29 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns log file prefix based on current environment
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
private static function getLogFilePrefix()
|
|
|
|
{
|
|
|
|
if (php_sapi_name() == 'cli') {
|
|
|
|
if (isset($_SERVER['TERM'])) {
|
|
|
|
return 'cli';
|
|
|
|
} else {
|
|
|
|
return 'cron';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return 'web';
|
2020-04-16 15:26:03 +03:00
|
|
|
}
|
2021-05-28 14:32:43 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes module log files from var/logs which is older than 30 days
|
|
|
|
*/
|
|
|
|
public static function clearObsoleteLogs()
|
|
|
|
{
|
|
|
|
$logDir = self::getLogDir();
|
|
|
|
$handle = opendir($logDir);
|
|
|
|
while (($file = readdir($handle)) !== false) {
|
|
|
|
if (false !== self::checkFileName($file)) {
|
|
|
|
$path = "$logDir/$file";
|
|
|
|
if (filemtime($path) < strtotime('-30 days')) {
|
|
|
|
unlink($path);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function getLogFilesInfo()
|
|
|
|
{
|
|
|
|
$fileNames = [];
|
|
|
|
$logDir = self::getLogDir();
|
|
|
|
|
|
|
|
$handle = opendir($logDir);
|
|
|
|
while (false !== $file = readdir($handle)) {
|
|
|
|
if (false !== self::checkFileName($file)) {
|
|
|
|
$path = "$logDir/$file";
|
|
|
|
$fileNames[] = [
|
|
|
|
'name' => $file,
|
|
|
|
'path' => $path,
|
|
|
|
'size' => number_format(filesize($path), 0, '.', ' ') . ' bytes',
|
|
|
|
'modified' => date('Y-m-d H:i:s', filemtime($path)),
|
|
|
|
];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
closedir($handle);
|
|
|
|
|
|
|
|
return $fileNames;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function checkFileName($file)
|
|
|
|
{
|
|
|
|
$logDir = self::getLogDir();
|
|
|
|
if (preg_match('/^retailcrm[a-zA-Z0-9-_]+.log$/', $file)) {
|
|
|
|
$path = "$logDir/$file";
|
|
|
|
if (is_file($path)) {
|
|
|
|
return $path;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
2020-04-16 15:26:03 +03:00
|
|
|
}
|