mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-07 12:30:28 +01:00
172 lines
4.4 KiB
PHP
172 lines
4.4 KiB
PHP
|
<?php
|
||
|
|
||
|
|
||
|
namespace Xentral\Components\Backup\Logger;
|
||
|
|
||
|
|
||
|
use Xentral\Components\Backup\Exception\LogException;
|
||
|
|
||
|
final class BackupLog
|
||
|
{
|
||
|
/** @var string|null $path */
|
||
|
private $fullPath;
|
||
|
|
||
|
/** @var string|null $storagePath */
|
||
|
private $storagePath;
|
||
|
|
||
|
/** @var string|null $fileName */
|
||
|
private $fileName;
|
||
|
|
||
|
/** @var string $persistentFile */
|
||
|
private static $persistentFile = 'backup_logger.txt';
|
||
|
|
||
|
public function __construct($path = null, $fileName = null)
|
||
|
{
|
||
|
if (null !== $path && null !== $fileName) {
|
||
|
$this->fullPath = rtrim($path, DIRECTORY_SEPARATOR) . DIRECTORY_SEPARATOR . $fileName;
|
||
|
}
|
||
|
$this->storagePath = $path;
|
||
|
$this->fileName = $fileName;
|
||
|
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string $message
|
||
|
*
|
||
|
* @param string|null $path
|
||
|
* @param string|null $fileName
|
||
|
*
|
||
|
* @param bool $withDate
|
||
|
*
|
||
|
* @param bool $append
|
||
|
*
|
||
|
* @return false|int
|
||
|
*/
|
||
|
public function write($message, $path = null, $fileName = null, $withDate = true, $append = true)
|
||
|
{
|
||
|
$flag = FILE_APPEND | LOCK_EX;
|
||
|
|
||
|
$path = $this->getFullPath($path, $fileName);
|
||
|
|
||
|
if (null === $path || (!file_exists($path) && !@touch($path))) {
|
||
|
throw new LogException(sprintf('cannot access or create file %s', $path));
|
||
|
}
|
||
|
|
||
|
$message = $withDate === true ? time() . ': ' . $message : $message;
|
||
|
if ($append === false) {
|
||
|
$flag &= ~FILE_APPEND;
|
||
|
}
|
||
|
|
||
|
return file_put_contents($path, $message . "\n", $flag);
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* @param int $linePosition
|
||
|
*
|
||
|
* @param string|null $path
|
||
|
*
|
||
|
* @param string|null $fileName
|
||
|
*
|
||
|
* @return mixed|string
|
||
|
*/
|
||
|
public function tail($linePosition = 0, $path = null, $fileName = null)
|
||
|
{
|
||
|
$path = $this->getFullPath($path, $fileName);
|
||
|
|
||
|
if (null === $path || !file_exists($path)) {
|
||
|
throw new LogException(sprintf('File %s cannot be found!', $path));
|
||
|
}
|
||
|
$output = '';
|
||
|
if (($xData = file($path, FILE_SKIP_EMPTY_LINES)) && count($xData) > 0) {
|
||
|
$key = (int)$linePosition === 0 ? count($xData) - 1 : $linePosition;
|
||
|
if (!array_key_exists($key, $xData)) {
|
||
|
throw new LogException(sprintf('Offset %d is missing', (int)$linePosition));
|
||
|
}
|
||
|
$output = $xData[$key];
|
||
|
}
|
||
|
|
||
|
return $output;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string|null $path
|
||
|
*
|
||
|
* @param string|null $fileName
|
||
|
*
|
||
|
* @return bool|false|string
|
||
|
*/
|
||
|
public function getContent($path = null, $fileName = null)
|
||
|
{
|
||
|
$path = $this->getFullPath($path, $fileName);
|
||
|
|
||
|
if (null === $path || !file_exists($path)) {
|
||
|
throw new LogException(sprintf('File %s cannot be found!', $path));
|
||
|
}
|
||
|
|
||
|
return file_get_contents($path);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param null $path
|
||
|
*
|
||
|
* @param string|null $fileName
|
||
|
*
|
||
|
* @throws LogException
|
||
|
* @return bool
|
||
|
*/
|
||
|
public function delete($path = null, $fileName = null)
|
||
|
{
|
||
|
$path = $this->getFullPath($path, $fileName);
|
||
|
if (null !== $path && !file_exists($path)) {
|
||
|
return false;
|
||
|
//throw new LogException(sprintf('File %s cannot be deleted!', $path));
|
||
|
}
|
||
|
|
||
|
return unlink($path);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param null $path
|
||
|
* @param null $fileName
|
||
|
*
|
||
|
* @return string|null
|
||
|
*/
|
||
|
private function getFullPath($path = null, $fileName = null)
|
||
|
{
|
||
|
if ($path === null && $fileName === null) {
|
||
|
return $this->fullPath;
|
||
|
}
|
||
|
if ($path !== null && $fileName !== null) {
|
||
|
return rtrim($path, DIRECTORY_SEPARATOR) . DIRECTORY_SEPARATOR . $fileName;
|
||
|
}
|
||
|
|
||
|
if ($fileName !== null && $path === null && $this->storagePath !== null) {
|
||
|
return rtrim($this->storagePath, DIRECTORY_SEPARATOR) . DIRECTORY_SEPARATOR . $fileName;
|
||
|
}
|
||
|
|
||
|
if ($path !== null && $fileName === null && $this->fileName !== null) {
|
||
|
return rtrim($path, DIRECTORY_SEPARATOR) . DIRECTORY_SEPARATOR . $this->fileName;
|
||
|
}
|
||
|
|
||
|
return null;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param string $message
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
public function writePersistent($message)
|
||
|
{
|
||
|
$this->write($message, null, self::$persistentFile, true, false);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return string
|
||
|
*/
|
||
|
public function getPersistentFileName()
|
||
|
{
|
||
|
return self::$persistentFile;
|
||
|
}
|
||
|
}
|