- Updated local libraries - PHP 7.1 support - New, proper caching method - Special cache folder
239 lines
6.0 KiB
PHP
239 lines
6.0 KiB
PHP
<?php
|
|
/**
|
|
*
|
|
* This file is part of phpFastCache.
|
|
*
|
|
* @license MIT License (MIT)
|
|
*
|
|
* For full copyright and license information, please see the docs/CREDITS.txt file.
|
|
*
|
|
* @author Khoa Bui (khoaofgod) <khoaofgod@gmail.com> http://www.phpfastcache.com
|
|
* @author Georges.L (Geolim4) <contact@geolim4.com>
|
|
*
|
|
*/
|
|
|
|
namespace phpFastCache\Drivers\Files;
|
|
|
|
use phpFastCache\Core\DriverAbstract;
|
|
use phpFastCache\Core\PathSeekerTrait;
|
|
use phpFastCache\Core\StandardPsr6StructureTrait;
|
|
use phpFastCache\Entities\driverStatistic;
|
|
use phpFastCache\Exceptions\phpFastCacheDriverCheckException;
|
|
use phpFastCache\Exceptions\phpFastCacheDriverException;
|
|
use phpFastCache\Util\Directory;
|
|
use Psr\Cache\CacheItemInterface;
|
|
|
|
/**
|
|
* Class Driver
|
|
* @package phpFastCache\Drivers
|
|
*/
|
|
class Driver extends DriverAbstract
|
|
{
|
|
use PathSeekerTrait;
|
|
|
|
/**
|
|
*
|
|
*/
|
|
const FILE_DIR = 'files';
|
|
|
|
/**
|
|
* Driver constructor.
|
|
* @param array $config
|
|
* @throws phpFastCacheDriverException
|
|
*/
|
|
public function __construct(array $config = [])
|
|
{
|
|
$this->setup($config);
|
|
|
|
if (!$this->driverCheck()) {
|
|
throw new phpFastCacheDriverCheckException(sprintf(self::DRIVER_CHECK_FAILURE, $this->getDriverName()));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @return bool
|
|
*/
|
|
public function driverCheck()
|
|
{
|
|
return is_writable($this->getFileDir()) || @mkdir($this->getFileDir(), $this->setChmodAuto(), true);
|
|
}
|
|
|
|
/**
|
|
* @param \Psr\Cache\CacheItemInterface $item
|
|
* @return mixed
|
|
* @throws \InvalidArgumentException
|
|
*/
|
|
protected function driverWrite(CacheItemInterface $item)
|
|
{
|
|
/**
|
|
* Check for Cross-Driver type confusion
|
|
*/
|
|
if ($item instanceof Item) {
|
|
$file_path = $this->getFilePath($item->getKey());
|
|
$data = $this->encode($this->driverPreWrap($item));
|
|
|
|
$toWrite = true;
|
|
|
|
/**
|
|
* Skip if Existing Caching in Options
|
|
*/
|
|
if (isset($this->config[ 'skipExisting' ]) && $this->config[ 'skipExisting' ] == true && file_exists($file_path)) {
|
|
$content = $this->readfile($file_path);
|
|
$old = $this->decode($content);
|
|
$toWrite = false;
|
|
if ($old->isExpired()) {
|
|
$toWrite = true;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Force write
|
|
*/
|
|
try {
|
|
if ($toWrite == true) {
|
|
$f = fopen($file_path, 'w+');
|
|
fwrite($f, $data);
|
|
fclose($f);
|
|
|
|
return true;
|
|
}
|
|
} catch (\Exception $e) {
|
|
return false;
|
|
}
|
|
} else {
|
|
throw new \InvalidArgumentException('Cross-Driver type confusion detected');
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param \Psr\Cache\CacheItemInterface $item
|
|
* @return mixed
|
|
*/
|
|
protected function driverRead(CacheItemInterface $item)
|
|
{
|
|
/**
|
|
* Check for Cross-Driver type confusion
|
|
*/
|
|
$file_path = $this->getFilePath($item->getKey());
|
|
if (!file_exists($file_path)) {
|
|
return null;
|
|
}
|
|
|
|
$content = $this->readfile($file_path);
|
|
|
|
return $this->decode($content);
|
|
|
|
}
|
|
|
|
/**
|
|
* @param \Psr\Cache\CacheItemInterface $item
|
|
* @return bool
|
|
* @throws \InvalidArgumentException
|
|
*/
|
|
protected function driverDelete(CacheItemInterface $item)
|
|
{
|
|
/**
|
|
* Check for Cross-Driver type confusion
|
|
*/
|
|
if ($item instanceof Item) {
|
|
$file_path = $this->getFilePath($item->getKey(), true);
|
|
if (file_exists($file_path) && @unlink($file_path)) {
|
|
return true;
|
|
} else {
|
|
return false;
|
|
}
|
|
} else {
|
|
throw new \InvalidArgumentException('Cross-Driver type confusion detected');
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @return bool
|
|
*/
|
|
protected function driverClear()
|
|
{
|
|
return (bool) Directory::rrmdir($this->getPath(true));
|
|
}
|
|
|
|
/**
|
|
* @return bool
|
|
*/
|
|
protected function driverConnect()
|
|
{
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* @param string $optionName
|
|
* @param mixed $optionValue
|
|
* @return bool
|
|
* @throws \InvalidArgumentException
|
|
*/
|
|
public static function isValidOption($optionName, $optionValue)
|
|
{
|
|
parent::isValidOption($optionName, $optionValue);
|
|
switch ($optionName) {
|
|
case 'path':
|
|
return is_string($optionValue);
|
|
break;
|
|
|
|
case 'default_chmod':
|
|
return is_numeric($optionValue);
|
|
break;
|
|
|
|
case 'securityKey':
|
|
return is_string($optionValue);
|
|
break;
|
|
case 'htaccess':
|
|
return is_bool($optionValue);
|
|
break;
|
|
default:
|
|
return false;
|
|
break;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @return array
|
|
*/
|
|
public static function getValidOptions()
|
|
{
|
|
return ['path', 'default_chmod', 'securityKey', 'htaccess'];
|
|
}
|
|
|
|
/**
|
|
* @return array
|
|
*/
|
|
public static function getRequiredOptions()
|
|
{
|
|
return ['path'];
|
|
}
|
|
|
|
/********************
|
|
*
|
|
* PSR-6 Extended Methods
|
|
*
|
|
*******************/
|
|
|
|
/**
|
|
* @return driverStatistic
|
|
* @throws \phpFastCache\Exceptions\phpFastCacheCoreException
|
|
* @throws \phpFastCache\Exceptions\phpFastCacheDriverException
|
|
*/
|
|
public function getStats()
|
|
{
|
|
$stat = new driverStatistic();
|
|
$path = $this->getFilePath(false);
|
|
|
|
if (!is_dir($path)) {
|
|
throw new phpFastCacheDriverException("Can't read PATH:" . $path, 94);
|
|
}
|
|
|
|
$stat->setData(implode(', ', array_keys($this->itemInstances)))
|
|
->setRawData([])
|
|
->setSize(Directory::dirSize($path))
|
|
->setInfo('Number of files used to build the cache: ' . Directory::getFileCount($path));
|
|
|
|
return $stat;
|
|
}
|
|
} |