Class: Unrestful::AsyncJob

Inherits:
Object
  • Object
show all
Includes:
ActiveModel::Serializers::JSON
Defined in:
lib/unrestful/async_job.rb

Constant Summary collapse

ALLOCATED =
0
RUNNING =
1
FAILED =
2
SUCCESS =
3
KEY_TIMEOUT =
3600
KEY_LENGTH =
10
CHANNEL_TIMEOUT =
10

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(job_id: nil) ⇒ AsyncJob

Returns a new instance of AsyncJob.



27
28
29
30
31
32
33
# File 'lib/unrestful/async_job.rb', line 27

def initialize(job_id: nil)
  if job_id.nil?
    @job_id = SecureRandom.hex(KEY_LENGTH)
  else
    @job_id = job_id
  end
end

Instance Attribute Details

#job_idObject (readonly)

Returns the value of attribute job_id.



16
17
18
# File 'lib/unrestful/async_job.rb', line 16

def job_id
  @job_id
end

Instance Method Details

#attributesObject



18
19
20
21
22
23
24
25
# File 'lib/unrestful/async_job.rb', line 18

def attributes
  {
    job_id: job_id,
    state: state,
    last_message: last_message,
    ttl: ttl
  }
end

#closeObject



90
91
92
93
94
# File 'lib/unrestful/async_job.rb', line 90

def close
  redis.unsubscribe(job_channel) if redis.subscribed?
ensure
  @redis.quit
end

#deleteObject



59
60
61
62
# File 'lib/unrestful/async_job.rb', line 59

def delete
  redis.del(job_key)
  redis.del(job_message)
end

#last_messageObject



55
56
57
# File 'lib/unrestful/async_job.rb', line 55

def last_message
  redis.get(job_message)
end

#publish(message) ⇒ Object

Raises:



70
71
72
73
74
# File 'lib/unrestful/async_job.rb', line 70

def publish(message)
  raise AsyncError, "job #{job_key} doesn't exist" unless valid?

  redis.publish(job_channel, message)
end

#redisObject



86
87
88
# File 'lib/unrestful/async_job.rb', line 86

def redis
  @redis ||= Redis.new(url: Unrestful.configuration.redis_address)
end

#stateObject



51
52
53
# File 'lib/unrestful/async_job.rb', line 51

def state
  redis.get(job_key)
end

#subscribe(timeout: CHANNEL_TIMEOUT, &block) ⇒ Object

Raises:



64
65
66
67
68
# File 'lib/unrestful/async_job.rb', line 64

def subscribe(timeout: CHANNEL_TIMEOUT, &block)
  raise AsyncError, "job #{job_key} doesn't exist" unless valid?

  redis.subscribe_with_timeout(timeout, job_channel, &block)
end

#ttlObject



47
48
49
# File 'lib/unrestful/async_job.rb', line 47

def ttl
  redis.ttl(job_key)
end

#unsubscribeObject



80
81
82
83
84
# File 'lib/unrestful/async_job.rb', line 80

def unsubscribe
  redis.unsubscribe(job_channel)
rescue
  # ignore unsub errors
end

#update(state, message: '') ⇒ Object

Raises:

  • (ArgumentError)


35
36
37
38
39
40
41
42
43
44
45
# File 'lib/unrestful/async_job.rb', line 35

def update(state, message: '')
  raise ArgumentError, 'failed states must have a message' if message.blank? && state == FAILED

  redis.set(job_key, state)
  redis.set(job_message, message) unless message.blank?

  if state == ALLOCATED
    redis.expire(job_key, KEY_TIMEOUT)
    redis.expire(job_message, KEY_TIMEOUT)
  end
end

#valid?Boolean

Returns:

  • (Boolean)


76
77
78
# File 'lib/unrestful/async_job.rb', line 76

def valid?
  redis.exists(job_key)
end