wiki.techinc.nl/includes/deferred/MWCallableUpdate.php
James D. Forrester 67217d08df Namespace remaining files under includes/deferred
Bug: T166010
Change-Id: Ibd40734b96fd2900e3ce12239d09becfb4150059
2023-11-22 10:08:53 -05:00

74 lines
1.8 KiB
PHP

<?php
namespace MediaWiki\Deferred;
use Wikimedia\Rdbms\IDatabase;
/**
* DeferrableUpdate for closure/callable
*
* @internal Use DeferredUpdates::addCallableUpdate instead
*/
class MWCallableUpdate
implements DeferrableUpdate, DeferrableCallback, TransactionRoundAwareUpdate
{
/** @var callable|null Callback, or null if it was cancelled */
private $callback;
/** @var string Calling method name */
private $fname;
/** @var int One of the class TRX_ROUND_* constants */
private $trxRoundRequirement = self::TRX_ROUND_PRESENT;
/**
* @param callable $callback
* @param string $fname Calling method
* @param IDatabase|IDatabase[]|null $dbws Cancel the update if a DB transaction
* is rolled back [optional] (since 1.28)
*/
public function __construct( callable $callback, $fname = 'unknown', $dbws = [] ) {
$this->callback = $callback;
$this->fname = $fname;
$dbws = is_array( $dbws ) ? $dbws : [ $dbws ];
foreach ( $dbws as $dbw ) {
if ( $dbw && $dbw->trxLevel() ) {
$dbw->onTransactionResolution( [ $this, 'cancelOnRollback' ], $fname );
}
}
}
public function doUpdate() {
if ( $this->callback ) {
call_user_func( $this->callback );
}
}
/**
* @internal This method is public so that it works with onTransactionResolution()
* @param int $trigger
*/
public function cancelOnRollback( $trigger ) {
if ( $trigger === IDatabase::TRIGGER_ROLLBACK ) {
$this->callback = null;
}
}
public function getOrigin() {
return $this->fname;
}
/**
* @since 1.34
* @param int $mode One of the class TRX_ROUND_* constants
*/
public function setTransactionRoundRequirement( $mode ) {
$this->trxRoundRequirement = $mode;
}
public function getTransactionRoundRequirement() {
return $this->trxRoundRequirement;
}
}
/** @deprecated since 1.42 */
class_alias( MWCallableUpdate::class, 'MWCallableUpdate' );