Overview

Namespaces

  • Net
    • Bazzline
      • Component
        • Lock

Classes

  • Net\Bazzline\Component\Lock\FileHandlerLock
  • Net\Bazzline\Component\Lock\FileNameLock
  • Net\Bazzline\Component\Lock\RuntimeLock

Interfaces

  • Net\Bazzline\Component\Lock\LockAwareInterface
  • Net\Bazzline\Component\Lock\LockDependentInterface
  • Net\Bazzline\Component\Lock\LockInterface
  • Overview
  • Namespace
  • Class
  1:   2:   3:   4:   5:   6:   7:   8:   9:  10:  11:  12:  13:  14:  15:  16:  17:  18:  19:  20:  21:  22:  23:  24:  25:  26:  27:  28:  29:  30:  31:  32:  33:  34:  35:  36:  37:  38:  39:  40:  41:  42:  43:  44:  45:  46:  47:  48:  49:  50:  51:  52:  53:  54:  55:  56:  57:  58:  59:  60:  61:  62:  63:  64:  65:  66:  67:  68:  69:  70:  71:  72:  73:  74:  75:  76:  77:  78:  79:  80:  81:  82:  83:  84:  85:  86:  87:  88:  89:  90:  91:  92:  93:  94:  95:  96:  97:  98:  99: 100: 101: 102: 103: 104: 105: 106: 107: 108: 109: 110: 111: 112: 113: 114: 115: 116: 117: 118: 119: 
<?php
/**
 * @author stev leibelt <artodeto@bazzline.net>
 * @since 2015-09-08
 */
namespace Net\Bazzline\Component\Lock;

use InvalidArgumentException;
use RuntimeException;
use SplFileObject;

/**
 * Class FileHandlerLock
 * @package Net\Bazzline\Component\Lock
 */
class FileHandlerLock implements LockInterface
{
    /** @var resource|SplFileObject */
    private $fileHandler;

    /** @var bool */
    private $isLocked = false;

    /** @var bool */
    private $isResource = false;

    /**
     * @return boolean
     */
    public function isLocked()
    {
        return $this->isLocked;
    }

    /**
     * @throws \RuntimeException
     */
    public function acquire()
    {
        if ($this->lockCouldBeAcquired()) {
            $this->isLocked = true;
        } else {
            throw new RuntimeException(
                'Can not acquire lock, lock already exists.'
            );
        }
    }

    /**
     * @throws \RuntimeException
     */
    public function release()
    {
        if ($this->lockCouldBeReleased()) {
            $this->isLocked = false;
        } else {
            throw new RuntimeException(
                'Can not release lock, no lock exists.'
            );
        }
    }

    /**
     * @return mixed|resource|SplFileObject|null
     */
    public function getResource()
    {
        return $this->fileHandler;
    }

    /**
     * @param resource|SplFileObject $resource
     * @throws InvalidArgumentException
     */
    public function setResource($resource)
    {
        if (is_resource($resource)) {
            $this->fileHandler  = $resource;
            $this->isResource   = true;
        } else if ($resource instanceof SplFileObject) {
            $this->fileHandler  = $resource;
            $this->isResource   = false;
        } else {
            throw new InvalidArgumentException(
                'provided resource must be of type "resource" or "SplFileObject"'
            );
        }

    }

    /**
     * @return bool
     */
    private function lockCouldBeAcquired()
    {
        if ($this->isResource) {
            $couldBeAcquired = flock($this->fileHandler, LOCK_EX | LOCK_NB);
        } else {
            $couldBeAcquired = $this->fileHandler->flock(LOCK_EX | LOCK_NB);
        }

        return $couldBeAcquired;
    }

    /**
     * @return bool
     */
    private function lockCouldBeReleased()
    {
        if ($this->isResource) {
            $couldBeAcquired = flock($this->fileHandler, LOCK_UN | LOCK_NB);
        } else {
            $couldBeAcquired = $this->fileHandler->flock(LOCK_UN | LOCK_NB);
        }

        return $couldBeAcquired;
    }
}
PHP Process Lock Component by bazzline.net API documentation generated by ApiGen