2023-03-11 12:04:29 +03:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Zend Framework (http://framework.zend.com/)
|
|
|
|
*
|
|
|
|
* @link http://github.com/zendframework/zf2 for the canonical source repository
|
2023-04-01 09:03:34 +03:00
|
|
|
* @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
|
2023-03-11 12:04:29 +03:00
|
|
|
* @license http://framework.zend.com/license/new-bsd New BSD License
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Zend\Server;
|
|
|
|
|
|
|
|
use Zend\Stdlib\ErrorHandler;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \Zend\Server\Cache: cache server definitions
|
|
|
|
*/
|
|
|
|
class Cache
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @var array Methods to skip when caching server
|
|
|
|
*/
|
|
|
|
protected static $skipMethods = array();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Cache a file containing the dispatch list.
|
|
|
|
*
|
|
|
|
* Serializes the server definition stores the information
|
|
|
|
* in $filename.
|
|
|
|
*
|
|
|
|
* Returns false on any error (typically, inability to write to file), true
|
|
|
|
* on success.
|
|
|
|
*
|
|
|
|
* @param string $filename
|
|
|
|
* @param \Zend\Server\Server $server
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function save($filename, Server $server)
|
|
|
|
{
|
2023-04-01 09:03:34 +03:00
|
|
|
if (!is_string($filename) || (!file_exists($filename) && !is_writable(dirname($filename)))) {
|
2023-03-11 12:04:29 +03:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
$methods = $server->getFunctions();
|
|
|
|
|
|
|
|
if ($methods instanceof Definition) {
|
|
|
|
$definition = new Definition();
|
|
|
|
foreach ($methods as $method) {
|
|
|
|
if (in_array($method->getName(), static::$skipMethods)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$definition->addMethod($method);
|
|
|
|
}
|
|
|
|
$methods = $definition;
|
|
|
|
}
|
|
|
|
|
|
|
|
ErrorHandler::start();
|
|
|
|
$test = file_put_contents($filename, serialize($methods));
|
|
|
|
ErrorHandler::stop();
|
|
|
|
if (0 === $test) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Load server definition from a file
|
|
|
|
*
|
|
|
|
* Unserializes a stored server definition from $filename. Returns false if
|
|
|
|
* it fails in any way, true on success.
|
|
|
|
*
|
|
|
|
* Useful to prevent needing to build the server definition on each
|
|
|
|
* request. Sample usage:
|
|
|
|
*
|
|
|
|
* <code>
|
|
|
|
* if (!Zend\Server\Cache::get($filename, $server)) {
|
|
|
|
* require_once 'Some/Service/ServiceClass.php';
|
|
|
|
* require_once 'Another/Service/ServiceClass.php';
|
|
|
|
*
|
|
|
|
* // Attach Some\Service\ServiceClass with namespace 'some'
|
|
|
|
* $server->attach('Some\Service\ServiceClass', 'some');
|
|
|
|
*
|
|
|
|
* // Attach Another\Service\ServiceClass with namespace 'another'
|
|
|
|
* $server->attach('Another\Service\ServiceClass', 'another');
|
|
|
|
*
|
|
|
|
* Zend\Server\Cache::save($filename, $server);
|
|
|
|
* }
|
|
|
|
*
|
|
|
|
* $response = $server->handle();
|
|
|
|
* echo $response;
|
|
|
|
* </code>
|
|
|
|
*
|
|
|
|
* @param string $filename
|
|
|
|
* @param \Zend\Server\Server $server
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function get($filename, Server $server)
|
|
|
|
{
|
2023-04-01 09:03:34 +03:00
|
|
|
if (!is_string($filename) || !file_exists($filename) || !is_readable($filename)) {
|
2023-03-11 12:04:29 +03:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
ErrorHandler::start();
|
|
|
|
$dispatch = file_get_contents($filename);
|
|
|
|
ErrorHandler::stop();
|
|
|
|
if (false === $dispatch) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
ErrorHandler::start(E_NOTICE);
|
|
|
|
$dispatchArray = unserialize($dispatch);
|
|
|
|
ErrorHandler::stop();
|
|
|
|
if (false === $dispatchArray) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
$server->loadFunctions($dispatchArray);
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove a cache file
|
|
|
|
*
|
|
|
|
* @param string $filename
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public static function delete($filename)
|
|
|
|
{
|
|
|
|
if (is_string($filename) && file_exists($filename)) {
|
|
|
|
unlink($filename);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|