WP_CLI
6 years ago
abstracts
4 years ago
actions
4 years ago
data-stores
4 years ago
migration
4 years ago
schedules
6 years ago
schema
4 years ago
ActionScheduler_ActionClaim.php
6 years ago
ActionScheduler_ActionFactory.php
6 years ago
ActionScheduler_AdminView.php
6 years ago
ActionScheduler_AsyncRequest_QueueRunner.php
6 years ago
ActionScheduler_Compatibility.php
6 years ago
ActionScheduler_DataController.php
6 years ago
ActionScheduler_DateTime.php
6 years ago
ActionScheduler_Exception.php
6 years ago
ActionScheduler_FatalErrorMonitor.php
6 years ago
ActionScheduler_InvalidActionException.php
6 years ago
ActionScheduler_ListTable.php
6 years ago
ActionScheduler_LogEntry.php
6 years ago
ActionScheduler_NullLogEntry.php
6 years ago
ActionScheduler_OptionLock.php
6 years ago
ActionScheduler_QueueCleaner.php
4 years ago
ActionScheduler_QueueRunner.php
6 years ago
ActionScheduler_Versions.php
6 years ago
ActionScheduler_WPCommentCleaner.php
6 years ago
ActionScheduler_wcSystemStatus.php
4 years ago
ActionScheduler_OptionLock.php
50 lines
| 1 | <?php |
| 2 | |
| 3 | /** |
| 4 | * Provide a way to set simple transient locks to block behaviour |
| 5 | * for up-to a given duration. |
| 6 | * |
| 7 | * Class ActionScheduler_OptionLock |
| 8 | * @since 3.0.0 |
| 9 | */ |
| 10 | class ActionScheduler_OptionLock extends ActionScheduler_Lock { |
| 11 | |
| 12 | /** |
| 13 | * Set a lock using options for a given amount of time (60 seconds by default). |
| 14 | * |
| 15 | * Using an autoloaded option avoids running database queries or other resource intensive tasks |
| 16 | * on frequently triggered hooks, like 'init' or 'shutdown'. |
| 17 | * |
| 18 | * For example, ActionScheduler_QueueRunner->maybe_dispatch_async_request() uses a lock to avoid |
| 19 | * calling ActionScheduler_QueueRunner->has_maximum_concurrent_batches() every time the 'shutdown', |
| 20 | * hook is triggered, because that method calls ActionScheduler_QueueRunner->store->get_claim_count() |
| 21 | * to find the current number of claims in the database. |
| 22 | * |
| 23 | * @param string $lock_type A string to identify different lock types. |
| 24 | * @bool True if lock value has changed, false if not or if set failed. |
| 25 | */ |
| 26 | public function set( $lock_type ) { |
| 27 | return update_option( $this->get_key( $lock_type ), time() + $this->get_duration( $lock_type ) ); |
| 28 | } |
| 29 | |
| 30 | /** |
| 31 | * If a lock is set, return the timestamp it was set to expiry. |
| 32 | * |
| 33 | * @param string $lock_type A string to identify different lock types. |
| 34 | * @return bool|int False if no lock is set, otherwise the timestamp for when the lock is set to expire. |
| 35 | */ |
| 36 | public function get_expiration( $lock_type ) { |
| 37 | return get_option( $this->get_key( $lock_type ) ); |
| 38 | } |
| 39 | |
| 40 | /** |
| 41 | * Get the key to use for storing the lock in the transient |
| 42 | * |
| 43 | * @param string $lock_type A string to identify different lock types. |
| 44 | * @return string |
| 45 | */ |
| 46 | protected function get_key( $lock_type ) { |
| 47 | return sprintf( 'action_scheduler_lock_%s', $lock_type ); |
| 48 | } |
| 49 | } |
| 50 |