mirror of
				https://github.com/Icinga/icingaweb2.git
				synced 2025-10-25 17:34:03 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			286 lines
		
	
	
		
			8.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			286 lines
		
	
	
		
			8.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Zend Framework
 | |
|  *
 | |
|  * LICENSE
 | |
|  *
 | |
|  * This source file is subject to the new BSD license that is bundled
 | |
|  * with this package in the file LICENSE.txt.
 | |
|  * It is also available through the world-wide-web at this URL:
 | |
|  * http://framework.zend.com/license/new-bsd
 | |
|  * If you did not receive a copy of the license and are unable to
 | |
|  * obtain it through the world-wide-web, please send an email
 | |
|  * to license@zend.com so we can send you a copy immediately.
 | |
|  *
 | |
|  * @category   Zend
 | |
|  * @package    Zend_Cache
 | |
|  * @subpackage Zend_Cache_Backend
 | |
|  * @copyright  Copyright (c) 2005-2014 Zend Technologies USA Inc. (http://www.zend.com)
 | |
|  * @license    http://framework.zend.com/license/new-bsd     New BSD License
 | |
|  * @version    $Id$
 | |
|  */
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * @package    Zend_Cache
 | |
|  * @subpackage Zend_Cache_Backend
 | |
|  * @copyright  Copyright (c) 2005-2014 Zend Technologies USA Inc. (http://www.zend.com)
 | |
|  * @license    http://framework.zend.com/license/new-bsd     New BSD License
 | |
|  */
 | |
| class Zend_Cache_Backend
 | |
| {
 | |
|     /**
 | |
|      * Frontend or Core directives
 | |
|      *
 | |
|      * =====> (int) lifetime :
 | |
|      * - Cache lifetime (in seconds)
 | |
|      * - If null, the cache is valid forever
 | |
|      *
 | |
|      * =====> (int) logging :
 | |
|      * - if set to true, a logging is activated throw Zend_Log
 | |
|      *
 | |
|      * @var array directives
 | |
|      */
 | |
|     protected $_directives = array(
 | |
|         'lifetime' => 3600,
 | |
|         'logging'  => false,
 | |
|         'logger'   => null
 | |
|     );
 | |
| 
 | |
|     /**
 | |
|      * Available options
 | |
|      *
 | |
|      * @var array available options
 | |
|      */
 | |
|     protected $_options = array();
 | |
| 
 | |
|     /**
 | |
|      * Constructor
 | |
|      *
 | |
|      * @param  array $options Associative array of options
 | |
|      */
 | |
|     public function __construct(array $options = array())
 | |
|     {
 | |
|         while (list($name, $value) = each($options)) {
 | |
|             $this->setOption($name, $value);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set the frontend directives
 | |
|      *
 | |
|      * @param  array $directives Assoc of directives
 | |
|      * @throws Zend_Cache_Exception
 | |
|      * @return void
 | |
|      */
 | |
|     public function setDirectives($directives)
 | |
|     {
 | |
|         if (!is_array($directives)) Zend_Cache::throwException('Directives parameter must be an array');
 | |
|         while (list($name, $value) = each($directives)) {
 | |
|             if (!is_string($name)) {
 | |
|                 Zend_Cache::throwException("Incorrect option name : $name");
 | |
|             }
 | |
|             $name = strtolower($name);
 | |
|             if (array_key_exists($name, $this->_directives)) {
 | |
|                 $this->_directives[$name] = $value;
 | |
|             }
 | |
| 
 | |
|         }
 | |
| 
 | |
|         $this->_loggerSanity();
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set an option
 | |
|      *
 | |
|      * @param  string $name
 | |
|      * @param  mixed  $value
 | |
|      * @throws Zend_Cache_Exception
 | |
|      * @return void
 | |
|      */
 | |
|     public function setOption($name, $value)
 | |
|     {
 | |
|         if (!is_string($name)) {
 | |
|             Zend_Cache::throwException("Incorrect option name : $name");
 | |
|         }
 | |
|         $name = strtolower($name);
 | |
|         if (array_key_exists($name, $this->_options)) {
 | |
|             $this->_options[$name] = $value;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Returns an option
 | |
|      *
 | |
|      * @param string $name Optional, the options name to return
 | |
|      * @throws Zend_Cache_Exceptions
 | |
|      * @return mixed
 | |
|      */
 | |
|     public function getOption($name)
 | |
|     {
 | |
|         $name = strtolower($name);
 | |
| 
 | |
|         if (array_key_exists($name, $this->_options)) {
 | |
|             return $this->_options[$name];
 | |
|         }
 | |
| 
 | |
|         if (array_key_exists($name, $this->_directives)) {
 | |
|             return $this->_directives[$name];
 | |
|         }
 | |
| 
 | |
|         Zend_Cache::throwException("Incorrect option name : {$name}");
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the life time
 | |
|      *
 | |
|      * if $specificLifetime is not false, the given specific life time is used
 | |
|      * else, the global lifetime is used
 | |
|      *
 | |
|      * @param  int $specificLifetime
 | |
|      * @return int Cache life time
 | |
|      */
 | |
|     public function getLifetime($specificLifetime)
 | |
|     {
 | |
|         if ($specificLifetime === false) {
 | |
|             return $this->_directives['lifetime'];
 | |
|         }
 | |
|         return $specificLifetime;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return true if the automatic cleaning is available for the backend
 | |
|      *
 | |
|      * DEPRECATED : use getCapabilities() instead
 | |
|      *
 | |
|      * @deprecated
 | |
|      * @return boolean
 | |
|      */
 | |
|     public function isAutomaticCleaningAvailable()
 | |
|     {
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Determine system TMP directory and detect if we have read access
 | |
|      *
 | |
|      * inspired from Zend_File_Transfer_Adapter_Abstract
 | |
|      *
 | |
|      * @return string
 | |
|      * @throws Zend_Cache_Exception if unable to determine directory
 | |
|      */
 | |
|     public function getTmpDir()
 | |
|     {
 | |
|         $tmpdir = array();
 | |
|         foreach (array($_ENV, $_SERVER) as $tab) {
 | |
|             foreach (array('TMPDIR', 'TEMP', 'TMP', 'windir', 'SystemRoot') as $key) {
 | |
|                 if (isset($tab[$key]) && is_string($tab[$key])) {
 | |
|                     if (($key == 'windir') or ($key == 'SystemRoot')) {
 | |
|                         $dir = realpath($tab[$key] . '\\temp');
 | |
|                     } else {
 | |
|                         $dir = realpath($tab[$key]);
 | |
|                     }
 | |
|                     if ($this->_isGoodTmpDir($dir)) {
 | |
|                         return $dir;
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
|         $upload = ini_get('upload_tmp_dir');
 | |
|         if ($upload) {
 | |
|             $dir = realpath($upload);
 | |
|             if ($this->_isGoodTmpDir($dir)) {
 | |
|                 return $dir;
 | |
|             }
 | |
|         }
 | |
|         if (function_exists('sys_get_temp_dir')) {
 | |
|             $dir = sys_get_temp_dir();
 | |
|             if ($this->_isGoodTmpDir($dir)) {
 | |
|                 return $dir;
 | |
|             }
 | |
|         }
 | |
|         // Attemp to detect by creating a temporary file
 | |
|         $tempFile = tempnam(md5(uniqid(rand(), TRUE)), '');
 | |
|         if ($tempFile) {
 | |
|             $dir = realpath(dirname($tempFile));
 | |
|             unlink($tempFile);
 | |
|             if ($this->_isGoodTmpDir($dir)) {
 | |
|                 return $dir;
 | |
|             }
 | |
|         }
 | |
|         if ($this->_isGoodTmpDir('/tmp')) {
 | |
|             return '/tmp';
 | |
|         }
 | |
|         if ($this->_isGoodTmpDir('\\temp')) {
 | |
|             return '\\temp';
 | |
|         }
 | |
|         Zend_Cache::throwException('Could not determine temp directory, please specify a cache_dir manually');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Verify if the given temporary directory is readable and writable
 | |
|      *
 | |
|      * @param string $dir temporary directory
 | |
|      * @return boolean true if the directory is ok
 | |
|      */
 | |
|     protected function _isGoodTmpDir($dir)
 | |
|     {
 | |
|         if (is_readable($dir)) {
 | |
|             if (is_writable($dir)) {
 | |
|                 return true;
 | |
|             }
 | |
|         }
 | |
|         return false;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Make sure if we enable logging that the Zend_Log class
 | |
|      * is available.
 | |
|      * Create a default log object if none is set.
 | |
|      *
 | |
|      * @throws Zend_Cache_Exception
 | |
|      * @return void
 | |
|      */
 | |
|     protected function _loggerSanity()
 | |
|     {
 | |
|         if (!isset($this->_directives['logging']) || !$this->_directives['logging']) {
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         if (isset($this->_directives['logger'])) {
 | |
|             if ($this->_directives['logger'] instanceof Zend_Log) {
 | |
|                 return;
 | |
|             }
 | |
|             Zend_Cache::throwException('Logger object is not an instance of Zend_Log class.');
 | |
|         }
 | |
| 
 | |
|         // Create a default logger to the standard output stream
 | |
|         $logger = new Zend_Log(new Zend_Log_Writer_Stream('php://output'));
 | |
|         $logger->addFilter(new Zend_Log_Filter_Priority(Zend_Log::WARN, '<='));
 | |
|         $this->_directives['logger'] = $logger;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Log a message at the WARN (4) priority.
 | |
|      *
 | |
|      * @param  string $message
 | |
|      * @param  int    $priority
 | |
|      * @return void
 | |
|      */
 | |
|     protected function _log($message, $priority = 4)
 | |
|     {
 | |
|         if (!$this->_directives['logging']) {
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         if (!isset($this->_directives['logger'])) {
 | |
|             Zend_Cache::throwException('Logging is enabled but logger is not set.');
 | |
|         }
 | |
|         $logger = $this->_directives['logger'];
 | |
|         if (!$logger instanceof Zend_Log) {
 | |
|             Zend_Cache::throwException('Logger object is not an instance of Zend_Log class.');
 | |
|         }
 | |
|         $logger->log($message, $priority);
 | |
|     }
 | |
| }
 |