Class: Roundhouse::SortedEntry

Inherits:
Job
  • Object
show all
Defined in:
lib/roundhouse/api.rb

Instance Attribute Summary collapse

Attributes inherited from Job

#item

Instance Method Summary collapse

Methods inherited from Job

#[], #args, #created_at, #display_args, #display_class, #enqueued_at, #jid, #klass, #latency, #queue_id

Constructor Details

#initialize(parent, score, item) ⇒ SortedEntry

Returns a new instance of SortedEntry.



413
414
415
416
417
# File 'lib/roundhouse/api.rb', line 413

def initialize(parent, score, item)
  super(item)
  @score = score
  @parent = parent
end

Instance Attribute Details

#parentObject (readonly)

Returns the value of attribute parent.



411
412
413
# File 'lib/roundhouse/api.rb', line 411

def parent
  @parent
end

#scoreObject (readonly)

Returns the value of attribute score.



410
411
412
# File 'lib/roundhouse/api.rb', line 410

def score
  @score
end

Instance Method Details

#add_to_queueObject



436
437
438
439
440
441
# File 'lib/roundhouse/api.rb', line 436

def add_to_queue
  remove_job do |message|
    msg = Roundhouse.load_json(message)
    Roundhouse::Client.push(msg)
  end
end

#atObject



419
420
421
# File 'lib/roundhouse/api.rb', line 419

def at
  Time.at(score).utc
end

#deleteObject



423
424
425
426
427
428
429
# File 'lib/roundhouse/api.rb', line 423

def delete
  if @value
    @parent.delete_by_value(@parent.name, @value)
  else
    @parent.delete_by_jid(score, jid)
  end
end

#killObject

Place job in the dead set



454
455
456
457
458
459
460
461
462
463
464
465
466
467
# File 'lib/roundhouse/api.rb', line 454

def kill
  raise 'Kill not available on jobs which have not failed' unless item['failed_at']
  remove_job do |message|
    Roundhouse.logger.info { "Killing job #{message['jid']}" }
    now = Time.now.to_f
    Roundhouse.redis do |conn|
      conn.multi do
        conn.zadd('dead', now, message)
        conn.zremrangebyscore('dead', '-inf', now - DeadSet.timeout)
        conn.zremrangebyrank('dead', 0, - DeadSet.max_jobs)
      end
    end
  end
end

#reschedule(at) ⇒ Object



431
432
433
434
# File 'lib/roundhouse/api.rb', line 431

def reschedule(at)
  delete
  @parent.schedule(at, item)
end

#retryObject



443
444
445
446
447
448
449
450
# File 'lib/roundhouse/api.rb', line 443

def retry
  raise "Retry not available on jobs which have not failed" unless item["failed_at"]
  remove_job do |message|
    msg = Roundhouse.load_json(message)
    msg['retry_count'] -= 1
    Roundhouse::Client.push(msg)
  end
end