38 parent::__construct( $params );
48 $unclaimed =& $this->getQueueData(
'unclaimed', [] );
50 foreach ( $jobs as
$job ) {
51 if (
$job->ignoreDuplicates() ) {
53 if ( !isset( $unclaimed[$sha1] ) ) {
54 $unclaimed[$sha1] =
$job;
68 return [
'random',
'timestamp',
'fifo' ];
95 $unclaimed = $this->getQueueData(
'unclaimed' );
97 return $unclaimed ? count( $unclaimed ) : 0;
106 $claimed = $this->getQueueData(
'claimed' );
108 return $claimed ? count( $claimed ) : 0;
121 $unclaimed =& $this->getQueueData(
'unclaimed' );
122 $claimed =& $this->getQueueData(
'claimed', [] );
124 if ( $this->order ===
'random' ) {
125 $key = array_rand( $unclaimed );
128 $key = key( $unclaimed );
131 $spec = $unclaimed[$key];
132 unset( $unclaimed[$key] );
138 $job->setMetadata(
'claimId', key( $claimed ) );
153 $claimed =& $this->getQueueData(
'claimed' );
154 unset( $claimed[
$job->getMetadata(
'claimId' )] );
161 if ( isset( self::$data[$this->type][$this->domain] ) ) {
162 unset( self::$data[$this->type][$this->domain] );
163 if ( !self::$data[$this->type] ) {
164 unset( self::$data[$this->type] );
175 $unclaimed = $this->getQueueData(
'unclaimed' );
177 return new ArrayIterator( [] );
182 function ( $value ) {
194 $claimed = $this->getQueueData(
'claimed' );
196 return new ArrayIterator( [] );
201 function ( $value ) {
221 private function &getQueueData( $field, $init =
null ) {
222 if ( !isset( self::$data[$this->type][$this->domain][$field] ) ) {
223 if ( $init !==
null ) {
Simple store for keeping values in an associative array for the current process.
Class to handle job queues stored in PHP memory for testing.
doDelete()
to override JobQueue::delete()
__construct(array $params)
doBatchPush(array $jobs, $flags)
jobFromSpecInternal(IJobSpecification $spec)
Class to handle enqueueing and running of background jobs.
factoryJob( $command, $params)
getAcquiredCount()
Get the number of acquired jobs (these are temporarily out of the queue).
string $domain
DB domain ID.
Convenience class for generating iterators from iterators.
Multi-datacenter aware caching interface.
Interface for serializable objects that describe a job queue task.
Job that has a run() method and metadata accessors for JobQueue::pop() and JobQueue::ack()
if(count( $args)< 1) $job