class DynamoDbLock extends Lock (View source)

Traits

Properties

protected string $name

The name of the lock.

from  Lock
protected int $seconds

The number of seconds the lock should be maintained.

from  Lock
protected string $owner

The scope identifier of this lock.

from  Lock
protected DynamoDbStore $dynamo

The DynamoDB client instance.

Methods

int
secondsUntil(DateTimeInterface|DateInterval|int $delay)

Get the number of seconds until the given DateTime.

int
availableAt(DateTimeInterface|DateInterval|int $delay = 0)

Get the "available at" UNIX timestamp.

parseDateInterval(DateTimeInterface|DateInterval|int $delay)

If the given value is an interval, convert it to a DateTime instance.

int
currentTime()

Get the current system time as a UNIX timestamp.

void
__construct(DynamoDbStore $dynamo, string $name, int $seconds, string|null $owner = null)

Create a new lock instance.

bool
acquire()

Attempt to acquire the lock.

bool
release()

Release the lock.

string
getCurrentOwner()

Returns the owner value written into the driver for this lock.

mixed
get(callable|null $callback = null)

Attempt to acquire the lock.

from  Lock
mixed
block(int $seconds, callable|null $callback = null)

Attempt to acquire the lock for the given number of seconds.

from  Lock
string
owner()

Returns the current owner of the lock.

from  Lock
bool
isOwnedByCurrentProcess()

Determines whether this lock is allowed to release the lock in the driver.

from  Lock
void
forceRelease()

Release this lock in disregard of ownership.

Details

protected int secondsUntil(DateTimeInterface|DateInterval|int $delay)

Get the number of seconds until the given DateTime.

Parameters

DateTimeInterface|DateInterval|int $delay

Return Value

int

protected int availableAt(DateTimeInterface|DateInterval|int $delay = 0)

Get the "available at" UNIX timestamp.

Parameters

DateTimeInterface|DateInterval|int $delay

Return Value

int

protected DateTimeInterface|int parseDateInterval(DateTimeInterface|DateInterval|int $delay)

If the given value is an interval, convert it to a DateTime instance.

Parameters

DateTimeInterface|DateInterval|int $delay

Return Value

DateTimeInterface|int

protected int currentTime()

Get the current system time as a UNIX timestamp.

Return Value

int

void __construct(DynamoDbStore $dynamo, string $name, int $seconds, string|null $owner = null)

Create a new lock instance.

Parameters

DynamoDbStore $dynamo
string $name
int $seconds
string|null $owner

Return Value

void

bool acquire()

Attempt to acquire the lock.

Return Value

bool

bool release()

Release the lock.

Return Value

bool

protected string getCurrentOwner()

Returns the owner value written into the driver for this lock.

Return Value

string

mixed get(callable|null $callback = null)

Attempt to acquire the lock.

Parameters

callable|null $callback

Return Value

mixed

mixed block(int $seconds, callable|null $callback = null)

Attempt to acquire the lock for the given number of seconds.

Parameters

int $seconds
callable|null $callback

Return Value

mixed

Exceptions

LockTimeoutException

string owner()

Returns the current owner of the lock.

Return Value

string

protected bool isOwnedByCurrentProcess()

Determines whether this lock is allowed to release the lock in the driver.

Return Value

bool

void forceRelease()

Release this lock in disregard of ownership.

Return Value

void