]> git.mxchange.org Git - friendica.git/blobdiff - src/Core/Lock/CacheLockDriver.php
Rename *CacheDriver to *Cache because they don't act as driver anymore
[friendica.git] / src / Core / Lock / CacheLockDriver.php
index 18d441ffea09d5a0910ec6ac3ada461db885ab7c..69db1c27f83c7e5fcc679fc661ce2f2d34196ad4 100644 (file)
@@ -3,21 +3,21 @@
 namespace Friendica\Core\Lock;
 
 use Friendica\Core\Cache;
-use Friendica\Core\Cache\IMemoryCacheDriver;
+use Friendica\Core\Cache\IMemoryCache;
 
-class CacheLockDriver extends AbstractLockDriver
+class CacheLockDriver extends AbstractLock
 {
        /**
-        * @var \Friendica\Core\Cache\ICacheDriver;
+        * @var \Friendica\Core\Cache\ICache;
         */
        private $cache;
 
        /**
         * CacheLockDriver constructor.
         *
-        * @param IMemoryCacheDriver $cache The CacheDriver for this type of lock
+        * @param IMemoryCache $cache The CacheDriver for this type of lock
         */
-       public function __construct(IMemoryCacheDriver $cache)
+       public function __construct(IMemoryCache $cache)
        {
                $this->cache = $cache;
        }
@@ -28,7 +28,7 @@ class CacheLockDriver extends AbstractLockDriver
        public function acquireLock($key, $timeout = 120, $ttl = Cache::FIVE_MINUTES)
        {
                $got_lock = false;
-               $start = time();
+               $start    = time();
 
                $cachekey = self::getLockKey($key);
 
@@ -61,12 +61,18 @@ class CacheLockDriver extends AbstractLockDriver
        /**
         * (@inheritdoc)
         */
-       public function releaseLock($key)
+       public function releaseLock($key, $override = false)
        {
                $cachekey = self::getLockKey($key);
 
-               $this->cache->compareDelete($cachekey, getmypid());
+               if ($override) {
+                       $return = $this->cache->delete($cachekey);
+               } else {
+                       $return = $this->cache->compareDelete($cachekey, getmypid());
+               }
                $this->markRelease($key);
+
+               return $return;
        }
 
        /**
@@ -75,15 +81,17 @@ class CacheLockDriver extends AbstractLockDriver
        public function isLocked($key)
        {
                $cachekey = self::getLockKey($key);
-               $lock = $this->cache->get($cachekey);
+               $lock     = $this->cache->get($cachekey);
                return isset($lock) && ($lock !== false);
        }
 
        /**
-        * @param string $key   The original key
-        * @return string               The cache key used for the cache
+        * @param string $key The original key
+        *
+        * @return string        The cache key used for the cache
         */
-       private static function getLockKey($key) {
+       private static function getLockKey($key)
+       {
                return "lock:" . $key;
        }
 }