Class: RackRabbit::Subscriber

Inherits:
Object
  • Object
show all
Defined in:
lib/rack-rabbit/subscriber.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(rabbit, handler, lock, config) ⇒ Subscriber




17
18
19
20
21
22
23
# File 'lib/rack-rabbit/subscriber.rb', line 17

def initialize(rabbit, handler, lock, config)
  @rabbit  = rabbit
  @handler = handler
  @lock    = lock
  @config  = config
  @logger  = config.logger
end

Instance Attribute Details

#configObject (readonly)




9
10
11
# File 'lib/rack-rabbit/subscriber.rb', line 9

def config
  @config
end

#handlerObject (readonly)




9
10
11
# File 'lib/rack-rabbit/subscriber.rb', line 9

def handler
  @handler
end

#lockObject (readonly)




9
10
11
# File 'lib/rack-rabbit/subscriber.rb', line 9

def lock
  @lock
end

#loggerObject (readonly)




9
10
11
# File 'lib/rack-rabbit/subscriber.rb', line 9

def logger
  @logger
end

#rabbitObject (readonly)




9
10
11
# File 'lib/rack-rabbit/subscriber.rb', line 9

def rabbit
  @rabbit
end

Instance Method Details

#subscribeObject




27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
# File 'lib/rack-rabbit/subscriber.rb', line 27

def subscribe
  rabbit.startup
  rabbit.connect
  rabbit.subscribe(:queue         => config.queue,
                   :exchange      => config.exchange,
                   :exchange_type => config.exchange_type,
                   :routing_key   => config.routing_key,
                   :manual_ack    => config.ack) do |message|
    lock.synchronize do
      start = Time.now
      response = handle(message)
      finish = Time.now
      logger.info "\"#{message.method} #{message.path}\" [#{response.status}] - #{"%.4f" % (finish - start)}"
    end
  end
end

#unsubscribeObject



44
45
46
47
# File 'lib/rack-rabbit/subscriber.rb', line 44

def unsubscribe
  rabbit.disconnect
  rabbit.shutdown
end