- Move constants to the "Cache" class (more transparent than inside the interface)
This commit is contained in:
		
					parent
					
						
							
								34e4968c06
							
						
					
				
			
			
				commit
				
					
						19777baa79
					
				
			
		
					 18 changed files with 59 additions and 69 deletions
				
			
		|  | @ -5,6 +5,7 @@ | ||||||
| namespace Friendica\Core; | namespace Friendica\Core; | ||||||
| 
 | 
 | ||||||
| use Friendica\BaseObject; | use Friendica\BaseObject; | ||||||
|  | use Friendica\Core\Cache\Cache as CacheClass; | ||||||
| use Friendica\Core\Cache\ICache; | use Friendica\Core\Cache\ICache; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  | @ -12,24 +13,24 @@ use Friendica\Core\Cache\ICache; | ||||||
|  */ |  */ | ||||||
| class Cache extends BaseObject | class Cache extends BaseObject | ||||||
| { | { | ||||||
| 	/** @deprecated Use ICache::MONTH */ | 	/** @deprecated Use CacheClass::MONTH */ | ||||||
| 	const MONTH        = ICache::MONTH; | 	const MONTH        = CacheClass::MONTH; | ||||||
| 	/** @deprecated Use ICache::WEEK */ | 	/** @deprecated Use CacheClass::WEEK */ | ||||||
| 	const WEEK         = ICache::WEEK; | 	const WEEK         = CacheClass::WEEK; | ||||||
| 	/** @deprecated Use ICache::DAY */ | 	/** @deprecated Use CacheClass::DAY */ | ||||||
| 	const DAY          = ICache::DAY; | 	const DAY          = CacheClass::DAY; | ||||||
| 	/** @deprecated Use ICache::HOUR */ | 	/** @deprecated Use CacheClass::HOUR */ | ||||||
| 	const HOUR         = ICache::HOUR; | 	const HOUR         = CacheClass::HOUR; | ||||||
| 	/** @deprecated Use ICache::HALF_HOUR */ | 	/** @deprecated Use CacheClass::HALF_HOUR */ | ||||||
| 	const HALF_HOUR    = ICache::HALF_HOUR; | 	const HALF_HOUR    = CacheClass::HALF_HOUR; | ||||||
| 	/** @deprecated Use ICache::QUARTER_HOUR */ | 	/** @deprecated Use CacheClass::QUARTER_HOUR */ | ||||||
| 	const QUARTER_HOUR = ICache::QUARTER_HOUR; | 	const QUARTER_HOUR = CacheClass::QUARTER_HOUR; | ||||||
| 	/** @deprecated Use ICache::FIVE_MINUTES */ | 	/** @deprecated Use CacheClass::FIVE_MINUTES */ | ||||||
| 	const FIVE_MINUTES = ICache::FIVE_MINUTES; | 	const FIVE_MINUTES = CacheClass::FIVE_MINUTES; | ||||||
| 	/** @deprecated Use ICache::MINUTE */ | 	/** @deprecated Use CacheClass::MINUTE */ | ||||||
| 	const MINUTE       = ICache::MINUTE; | 	const MINUTE       = CacheClass::MINUTE; | ||||||
| 	/** @deprecated Use ICache::INFINITE */ | 	/** @deprecated Use CacheClass::INFINITE */ | ||||||
| 	const INFINITE     = ICache::INFINITE; | 	const INFINITE     = CacheClass::INFINITE; | ||||||
| 
 | 
 | ||||||
| 	/** | 	/** | ||||||
| 	 * @brief Returns all the cache keys sorted alphabetically | 	 * @brief Returns all the cache keys sorted alphabetically | ||||||
|  | @ -69,7 +70,7 @@ class Cache extends BaseObject | ||||||
| 	 * @return bool | 	 * @return bool | ||||||
| 	 * @throws \Exception | 	 * @throws \Exception | ||||||
| 	 */ | 	 */ | ||||||
| 	public static function set($key, $value, $duration = ICache::MONTH) | 	public static function set($key, $value, $duration = CacheClass::MONTH) | ||||||
| 	{ | 	{ | ||||||
| 		return self::getClass(ICache::class)->set($key, $value, $duration); | 		return self::getClass(ICache::class)->set($key, $value, $duration); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | @ -3,14 +3,13 @@ | ||||||
| namespace Friendica\Core\Cache; | namespace Friendica\Core\Cache; | ||||||
| 
 | 
 | ||||||
| use Exception; | use Exception; | ||||||
| use Friendica\Core\Cache; |  | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * APCu Cache. |  * APCu Cache. | ||||||
|  * |  * | ||||||
|  * @author Philipp Holzer <admin@philipp.info> |  * @author Philipp Holzer <admin@philipp.info> | ||||||
|  */ |  */ | ||||||
| class APCuCache extends AbstractCache implements IMemoryCache | class APCuCache extends Cache implements IMemoryCache | ||||||
| { | { | ||||||
| 	use TraitCompareSet; | 	use TraitCompareSet; | ||||||
| 	use TraitCompareDelete; | 	use TraitCompareDelete; | ||||||
|  |  | ||||||
|  | @ -2,8 +2,6 @@ | ||||||
| 
 | 
 | ||||||
| namespace Friendica\Core\Cache; | namespace Friendica\Core\Cache; | ||||||
| 
 | 
 | ||||||
| use Friendica\Core\Cache; |  | ||||||
| 
 |  | ||||||
| /** | /** | ||||||
|  * Implementation of the IMemoryCache mainly for testing purpose |  * Implementation of the IMemoryCache mainly for testing purpose | ||||||
|  * |  * | ||||||
|  | @ -11,7 +9,7 @@ use Friendica\Core\Cache; | ||||||
|  * |  * | ||||||
|  * @package Friendica\Core\Cache |  * @package Friendica\Core\Cache | ||||||
|  */ |  */ | ||||||
| class ArrayCache extends AbstractCache implements IMemoryCache | class ArrayCache extends Cache implements IMemoryCache | ||||||
| { | { | ||||||
| 	use TraitCompareDelete; | 	use TraitCompareDelete; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -9,7 +9,7 @@ namespace Friendica\Core\Cache; | ||||||
|  * |  * | ||||||
|  * @package Friendica\Core\Cache |  * @package Friendica\Core\Cache | ||||||
|  */ |  */ | ||||||
| abstract class AbstractCache implements ICache | abstract class Cache implements ICache | ||||||
| { | { | ||||||
| 	const TYPE_APCU      = 'apcu'; | 	const TYPE_APCU      = 'apcu'; | ||||||
| 	const TYPE_ARRAY     = 'array'; | 	const TYPE_ARRAY     = 'array'; | ||||||
|  | @ -18,6 +18,16 @@ abstract class AbstractCache implements ICache | ||||||
| 	const TYPE_MEMCACHED = 'memcached'; | 	const TYPE_MEMCACHED = 'memcached'; | ||||||
| 	const TYPE_REDIS     = 'redis'; | 	const TYPE_REDIS     = 'redis'; | ||||||
| 
 | 
 | ||||||
|  | 	const MONTH        = 2592000; | ||||||
|  | 	const WEEK         = 604800; | ||||||
|  | 	const DAY          = 86400; | ||||||
|  | 	const HOUR         = 3600; | ||||||
|  | 	const HALF_HOUR    = 1800; | ||||||
|  | 	const QUARTER_HOUR = 900; | ||||||
|  | 	const FIVE_MINUTES = 300; | ||||||
|  | 	const MINUTE       = 60; | ||||||
|  | 	const INFINITE     = 0; | ||||||
|  | 
 | ||||||
| 	/** | 	/** | ||||||
| 	 * Force each Cache implementation to define the ToString method | 	 * Force each Cache implementation to define the ToString method | ||||||
| 	 * | 	 * | ||||||
|  | @ -2,7 +2,6 @@ | ||||||
| 
 | 
 | ||||||
| namespace Friendica\Core\Cache; | namespace Friendica\Core\Cache; | ||||||
| 
 | 
 | ||||||
| use Friendica\Core\Cache; |  | ||||||
| use Friendica\Database\Database; | use Friendica\Database\Database; | ||||||
| use Friendica\Util\DateTimeFormat; | use Friendica\Util\DateTimeFormat; | ||||||
| 
 | 
 | ||||||
|  | @ -11,7 +10,7 @@ use Friendica\Util\DateTimeFormat; | ||||||
|  * |  * | ||||||
|  * @author Hypolite Petovan <hypolite@mrpetovan.com> |  * @author Hypolite Petovan <hypolite@mrpetovan.com> | ||||||
|  */ |  */ | ||||||
| class DatabaseCache extends AbstractCache implements ICache | class DatabaseCache extends Cache implements ICache | ||||||
| { | { | ||||||
| 	/** | 	/** | ||||||
| 	 * @var Database | 	 * @var Database | ||||||
|  |  | ||||||
|  | @ -9,16 +9,6 @@ namespace Friendica\Core\Cache; | ||||||
|  */ |  */ | ||||||
| interface ICache | interface ICache | ||||||
| { | { | ||||||
| 	const MONTH        = 2592000; |  | ||||||
| 	const WEEK         = 604800; |  | ||||||
| 	const DAY          = 86400; |  | ||||||
| 	const HOUR         = 3600; |  | ||||||
| 	const HALF_HOUR    = 1800; |  | ||||||
| 	const QUARTER_HOUR = 900; |  | ||||||
| 	const FIVE_MINUTES = 300; |  | ||||||
| 	const MINUTE       = 60; |  | ||||||
| 	const INFINITE     = 0; |  | ||||||
| 
 |  | ||||||
| 	/** | 	/** | ||||||
| 	 * Lists all cache keys | 	 * Lists all cache keys | ||||||
| 	 * | 	 * | ||||||
|  | @ -46,7 +36,7 @@ interface ICache | ||||||
| 	 * | 	 * | ||||||
| 	 * @return bool | 	 * @return bool | ||||||
| 	 */ | 	 */ | ||||||
| 	public function set($key, $value, $ttl = self::FIVE_MINUTES); | 	public function set($key, $value, $ttl = Cache::FIVE_MINUTES); | ||||||
| 
 | 
 | ||||||
| 	/** | 	/** | ||||||
| 	 * Delete a key from the cache | 	 * Delete a key from the cache | ||||||
|  |  | ||||||
|  | @ -3,7 +3,6 @@ | ||||||
| namespace Friendica\Core\Cache; | namespace Friendica\Core\Cache; | ||||||
| 
 | 
 | ||||||
| use Exception; | use Exception; | ||||||
| use Friendica\Core\Cache; |  | ||||||
| use Friendica\Core\Config\Configuration; | use Friendica\Core\Config\Configuration; | ||||||
| use Memcache; | use Memcache; | ||||||
| 
 | 
 | ||||||
|  | @ -12,7 +11,7 @@ use Memcache; | ||||||
|  * |  * | ||||||
|  * @author Hypolite Petovan <hypolite@mrpetovan.com> |  * @author Hypolite Petovan <hypolite@mrpetovan.com> | ||||||
|  */ |  */ | ||||||
| class MemcacheCache extends AbstractCache implements IMemoryCache | class MemcacheCache extends Cache implements IMemoryCache | ||||||
| { | { | ||||||
| 	use TraitCompareSet; | 	use TraitCompareSet; | ||||||
| 	use TraitCompareDelete; | 	use TraitCompareDelete; | ||||||
|  |  | ||||||
|  | @ -3,7 +3,6 @@ | ||||||
| namespace Friendica\Core\Cache; | namespace Friendica\Core\Cache; | ||||||
| 
 | 
 | ||||||
| use Exception; | use Exception; | ||||||
| use Friendica\Core\Cache; |  | ||||||
| use Friendica\Core\Config\Configuration; | use Friendica\Core\Config\Configuration; | ||||||
| use Memcached; | use Memcached; | ||||||
| use Psr\Log\LoggerInterface; | use Psr\Log\LoggerInterface; | ||||||
|  | @ -13,7 +12,7 @@ use Psr\Log\LoggerInterface; | ||||||
|  * |  * | ||||||
|  * @author Hypolite Petovan <hypolite@mrpetovan.com> |  * @author Hypolite Petovan <hypolite@mrpetovan.com> | ||||||
|  */ |  */ | ||||||
| class MemcachedCache extends AbstractCache implements IMemoryCache | class MemcachedCache extends Cache implements IMemoryCache | ||||||
| { | { | ||||||
| 	use TraitCompareSet; | 	use TraitCompareSet; | ||||||
| 	use TraitCompareDelete; | 	use TraitCompareDelete; | ||||||
|  | @ -36,6 +35,7 @@ class MemcachedCache extends AbstractCache implements IMemoryCache | ||||||
| 	 * } | 	 * } | ||||||
| 	 * | 	 * | ||||||
| 	 * @param array $memcached_hosts | 	 * @param array $memcached_hosts | ||||||
|  | 	 * | ||||||
| 	 * @throws \Exception | 	 * @throws \Exception | ||||||
| 	 */ | 	 */ | ||||||
| 	public function __construct(string $hostname, Configuration $config, LoggerInterface $logger) | 	public function __construct(string $hostname, Configuration $config, LoggerInterface $logger) | ||||||
|  |  | ||||||
|  | @ -2,7 +2,6 @@ | ||||||
| 
 | 
 | ||||||
| namespace Friendica\Core\Cache; | namespace Friendica\Core\Cache; | ||||||
| 
 | 
 | ||||||
| use Friendica\Core\Cache; |  | ||||||
| use Friendica\Core\System; | use Friendica\Core\System; | ||||||
| use Friendica\Util\Profiler; | use Friendica\Util\Profiler; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -3,7 +3,6 @@ | ||||||
| namespace Friendica\Core\Cache; | namespace Friendica\Core\Cache; | ||||||
| 
 | 
 | ||||||
| use Exception; | use Exception; | ||||||
| use Friendica\Core\Cache; |  | ||||||
| use Friendica\Core\Config\Configuration; | use Friendica\Core\Config\Configuration; | ||||||
| use Redis; | use Redis; | ||||||
| 
 | 
 | ||||||
|  | @ -13,7 +12,7 @@ use Redis; | ||||||
|  * @author Hypolite Petovan <hypolite@mrpetovan.com> |  * @author Hypolite Petovan <hypolite@mrpetovan.com> | ||||||
|  * @author Roland Haeder <roland@mxchange.org> |  * @author Roland Haeder <roland@mxchange.org> | ||||||
|  */ |  */ | ||||||
| class RedisCache extends AbstractCache implements IMemoryCache | class RedisCache extends Cache implements IMemoryCache | ||||||
| { | { | ||||||
| 	/** | 	/** | ||||||
| 	 * @var Redis | 	 * @var Redis | ||||||
|  |  | ||||||
|  | @ -2,8 +2,6 @@ | ||||||
| 
 | 
 | ||||||
| namespace Friendica\Core\Cache; | namespace Friendica\Core\Cache; | ||||||
| 
 | 
 | ||||||
| use Friendica\Core\Cache; |  | ||||||
| 
 |  | ||||||
| /** | /** | ||||||
|  * Trait TraitCompareSetDelete |  * Trait TraitCompareSetDelete | ||||||
|  * |  * | ||||||
|  |  | ||||||
|  | @ -2,8 +2,6 @@ | ||||||
| 
 | 
 | ||||||
| namespace Friendica\Core\Cache; | namespace Friendica\Core\Cache; | ||||||
| 
 | 
 | ||||||
| use Friendica\Core\Cache; |  | ||||||
| 
 |  | ||||||
| /** | /** | ||||||
|  * Trait TraitCompareSetDelete |  * Trait TraitCompareSetDelete | ||||||
|  * |  * | ||||||
|  |  | ||||||
|  | @ -5,7 +5,7 @@ namespace Friendica\Core\Lock; | ||||||
| use Friendica\Core\Cache; | use Friendica\Core\Cache; | ||||||
| use Friendica\Core\Cache\IMemoryCache; | use Friendica\Core\Cache\IMemoryCache; | ||||||
| 
 | 
 | ||||||
| class CacheLock extends AbstractLock | class CacheLock extends Lock | ||||||
| { | { | ||||||
| 	/** | 	/** | ||||||
| 	 * @var \Friendica\Core\Cache\ICache; | 	 * @var \Friendica\Core\Cache\ICache; | ||||||
|  |  | ||||||
|  | @ -9,7 +9,7 @@ use Friendica\Util\DateTimeFormat; | ||||||
| /** | /** | ||||||
|  * Locking driver that stores the locks in the database |  * Locking driver that stores the locks in the database | ||||||
|  */ |  */ | ||||||
| class DatabaseLock extends AbstractLock | class DatabaseLock extends Lock | ||||||
| { | { | ||||||
| 	/** | 	/** | ||||||
| 	 * The current ID of the process | 	 * The current ID of the process | ||||||
|  |  | ||||||
|  | @ -9,7 +9,7 @@ namespace Friendica\Core\Lock; | ||||||
|  * |  * | ||||||
|  * Basic class for Locking with common functions (local acquired locks, releaseAll, ..) |  * Basic class for Locking with common functions (local acquired locks, releaseAll, ..) | ||||||
|  */ |  */ | ||||||
| abstract class AbstractLock implements ILock | abstract class Lock implements ILock | ||||||
| { | { | ||||||
| 	/** | 	/** | ||||||
| 	 * @var array The local acquired locks | 	 * @var array The local acquired locks | ||||||
|  | @ -4,7 +4,7 @@ namespace Friendica\Core\Lock; | ||||||
| 
 | 
 | ||||||
| use Friendica\Core\Cache; | use Friendica\Core\Cache; | ||||||
| 
 | 
 | ||||||
| class SemaphoreLock extends AbstractLock | class SemaphoreLock extends Lock | ||||||
| { | { | ||||||
| 	private static $semaphore = []; | 	private static $semaphore = []; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -22,7 +22,7 @@ class CacheFactory | ||||||
| 	/** | 	/** | ||||||
| 	 * @var string The default cache if nothing set | 	 * @var string The default cache if nothing set | ||||||
| 	 */ | 	 */ | ||||||
| 	const DEFAULT_TYPE = Cache\AbstractCache::TYPE_DATABASE; | 	const DEFAULT_TYPE = Cache\Cache::TYPE_DATABASE; | ||||||
| 
 | 
 | ||||||
| 	/** | 	/** | ||||||
| 	 * @var Configuration The configuration to read parameters out of the config | 	 * @var Configuration The configuration to read parameters out of the config | ||||||
|  | @ -73,16 +73,16 @@ class CacheFactory | ||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		switch ($type) { | 		switch ($type) { | ||||||
| 			case Cache\AbstractCache::TYPE_MEMCACHE: | 			case Cache\Cache::TYPE_MEMCACHE: | ||||||
| 				$cache = new Cache\MemcacheCache($this->hostname, $this->config); | 				$cache = new Cache\MemcacheCache($this->hostname, $this->config); | ||||||
| 				break; | 				break; | ||||||
| 			case Cache\AbstractCache::TYPE_MEMCACHED: | 			case Cache\Cache::TYPE_MEMCACHED: | ||||||
| 				$cache = new Cache\MemcachedCache($this->hostname, $this->config, $this->logger); | 				$cache = new Cache\MemcachedCache($this->hostname, $this->config, $this->logger); | ||||||
| 				break; | 				break; | ||||||
| 			case Cache\AbstractCache::TYPE_REDIS: | 			case Cache\Cache::TYPE_REDIS: | ||||||
| 				$cache = new Cache\RedisCache($this->hostname, $this->config); | 				$cache = new Cache\RedisCache($this->hostname, $this->config); | ||||||
| 				break; | 				break; | ||||||
| 			case Cache\AbstractCache::TYPE_APCU: | 			case Cache\Cache::TYPE_APCU: | ||||||
| 				$cache = new Cache\APCuCache($this->hostname); | 				$cache = new Cache\APCuCache($this->hostname); | ||||||
| 				break; | 				break; | ||||||
| 			default: | 			default: | ||||||
|  |  | ||||||
|  | @ -2,7 +2,7 @@ | ||||||
| 
 | 
 | ||||||
| namespace Friendica\Factory; | namespace Friendica\Factory; | ||||||
| 
 | 
 | ||||||
| use Friendica\Core\Cache\AbstractCache; | use Friendica\Core\Cache\Cache; | ||||||
| use Friendica\Core\Cache\IMemoryCache; | use Friendica\Core\Cache\IMemoryCache; | ||||||
| use Friendica\Core\Config\Configuration; | use Friendica\Core\Config\Configuration; | ||||||
| use Friendica\Core\Lock; | use Friendica\Core\Lock; | ||||||
|  | @ -63,10 +63,10 @@ class LockFactory | ||||||
| 
 | 
 | ||||||
| 		try { | 		try { | ||||||
| 			switch ($lock_type) { | 			switch ($lock_type) { | ||||||
| 				case AbstractCache::TYPE_MEMCACHE: | 				case Cache::TYPE_MEMCACHE: | ||||||
| 				case AbstractCache::TYPE_MEMCACHED: | 				case Cache::TYPE_MEMCACHED: | ||||||
| 				case AbstractCache::TYPE_REDIS: | 				case Cache::TYPE_REDIS: | ||||||
| 				case AbstractCache::TYPE_APCU: | 				case Cache::TYPE_APCU: | ||||||
| 					$cache = $this->cacheFactory->create($lock_type); | 					$cache = $this->cacheFactory->create($lock_type); | ||||||
| 					if ($cache instanceof IMemoryCache) { | 					if ($cache instanceof IMemoryCache) { | ||||||
| 						return new Lock\CacheLock($cache); | 						return new Lock\CacheLock($cache); | ||||||
|  | @ -115,7 +115,7 @@ class LockFactory | ||||||
| 
 | 
 | ||||||
| 		// 2. Try to use Cache Locking (don't use the DB-Cache Locking because it works different!)
 | 		// 2. Try to use Cache Locking (don't use the DB-Cache Locking because it works different!)
 | ||||||
| 		$cache_type = $this->config->get('system', 'cache_driver', 'database'); | 		$cache_type = $this->config->get('system', 'cache_driver', 'database'); | ||||||
| 		if ($cache_type != AbstractCache::TYPE_DATABASE) { | 		if ($cache_type != Cache::TYPE_DATABASE) { | ||||||
| 			try { | 			try { | ||||||
| 				$cache = $this->cacheFactory->create($cache_type); | 				$cache = $this->cacheFactory->create($cache_type); | ||||||
| 				if ($cache instanceof IMemoryCache) { | 				if ($cache instanceof IMemoryCache) { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue