workers = $conf['workers']; $this->maxqueue = $conf['maxqueue']; $this->timeout = $conf['timeout']; if ( isset( $conf['slots'] ) ) { $this->slots = $conf['slots']; } if ( $this->slots ) { $key = $this->hashKeyIntoSlots( $key, $this->slots ); } $this->key = $key; } /** * Create a Pool counter. This should only be called from the PoolWorks. * * @param string $type * @param string $key * * @return PoolCounter */ public static function factory( $type, $key ) { global $wgPoolCounterConf; if ( !isset( $wgPoolCounterConf[$type] ) ) { return new PoolCounter_Stub; } $conf = $wgPoolCounterConf[$type]; $class = $conf['class']; return new $class( $conf, $type, $key ); } /** * @return string */ public function getKey() { return $this->key; } /** * I want to do this task and I need to do it myself. * * @return Status Value is one of Locked/Error */ abstract public function acquireForMe(); /** * I want to do this task, but if anyone else does it * instead, it's also fine for me. I will read its cached data. * * @return Status Value is one of Locked/Done/Error */ abstract public function acquireForAnyone(); /** * I have successfully finished my task. * Lets another one grab the lock, and returns the workers * waiting on acquireForAnyone() * * @return Status Value is one of Released/NotLocked/Error */ abstract public function release(); /** * Given a key (any string) and the number of lots, returns a slot number (an integer from the [0..($slots-1)] range). * This is used for a global limit on the number of instances of a given type that can acquire a lock. * The hashing is deterministic so that PoolCounter::$workers is always an upper limit of how many instances with * the same key can acquire a lock. * * @param string $key PoolCounter instance key (any string) * @param int $slots The number of slots (max allowed value is 65536) * @return int */ protected function hashKeyIntoSlots( $key, $slots ) { return hexdec( substr( sha1( $key ), 0, 4 ) ) % $slots; } } // @codingStandardsIgnoreStart Squiz.Classes.ValidClassName.NotCamelCaps class PoolCounter_Stub extends PoolCounter { // @codingStandardsIgnoreEnd public function __construct() { /* No parameters needed */ } public function acquireForMe() { return Status::newGood( PoolCounter::LOCKED ); } public function acquireForAnyone() { return Status::newGood( PoolCounter::LOCKED ); } public function release() { return Status::newGood( PoolCounter::RELEASED ); } }