esp-commons 0.3.1 → 0.3.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -6,10 +6,12 @@ class MessageMaker
6
6
 
7
7
  amqp_client.start
8
8
 
9
- exchange = amqp_client.exchange('esp', :type => :topic)
9
+ exchange = amqp_client.exchange(queue_name, :type => :topic)
10
10
 
11
11
  queue = amqp_client.queue(queue_name, :durable => true)
12
12
 
13
+ queue.bind(exchange, :key => '*')
14
+
13
15
  exchange.publish(message, :key => routing_key, :persistent => true)
14
16
 
15
17
  amqp_client.stop
@@ -2,44 +2,53 @@ require 'amqp'
2
2
 
3
3
  class Subscriber
4
4
  def start
5
- logger.debug "RAILS_ENV=#{Rails.env}"
6
- subscribers.each do |subscriber|
7
- AMQP.start(Settings['amqp.url']) do |connection|
5
+ logger.debug "Subscribers runned in #{Rails.env} environment"
6
+ AMQP.start(Settings['amqp.url']) do |connection|
7
+ Signal.trap("TERM") do
8
+ logger.info "All subscribers stopped"
9
+ connection.close do
10
+ EM.stop { exit }
11
+ end
12
+ end
13
+ subscribers.each do |subscriber|
8
14
  channel = AMQP::Channel.new(connection)
9
15
  channel.prefetch(1)
10
16
 
11
- exchange = channel.topic('esp')
12
- queue = channel.queue(queue_name(subscriber), :durable => true)
17
+ topic = routing_prefix(subscriber)
13
18
 
14
- queue.bind(exchange, :routing_key => '*')
19
+ exchange = channel.topic(topic)
20
+ queue = channel.queue(topic, :durable => true)
15
21
 
16
- Signal.trap("TERM") do
17
- connection.close do
18
- logger.info "#{subscriber.class} stopped"
19
- EM.stop { exit }
20
- end
21
- end
22
+ queue.bind(exchange, :routing_key => "*")
22
23
 
23
24
  queue.subscribe(:ack => true) do |header, message|
24
25
  method = header.routing_key
26
+ logger.debug "#{subscriber.class} receive #{method}: #{message}"
25
27
  if subscriber.respond_to?(method)
26
- logger.debug("#{subscriber.class} receive #{method}: #{message}")
27
- subscriber.send(method, message)
28
- header.ack
28
+ begin
29
+ defined?(ActiveRecord::Base) and ActiveRecord::Base.establish_connection
30
+ subscriber.send(method, message)
31
+ logger.debug "#{subscriber.class} successfully executed #{method}"
32
+ rescue => e
33
+ logger.warn "#{subscriber.class} error while executing #{method} - #{e.message}"
34
+ end
29
35
  else
30
- logger.warn "#{subscriber.class} not respond to #{method}"
36
+ logger.warn "#{subscriber.class} cann't execute #{method} due #{subscriber.class} not respond to #{method}"
31
37
  end
38
+ header.ack
32
39
  end
33
40
 
34
- logger.info "#{subscriber.class} started"
41
+ logger.info "#{subscriber.class} listen #{queue.name}"
35
42
  end
36
43
  end
37
44
  end
38
45
 
39
46
  def subscribers
40
- Dir.glob("#{Rails.root}/lib/subscribers/*").map do |subscriber_path|
47
+ Dir.glob("#{Rails.root}/lib/subscribers/*_subscriber.rb").map do |subscriber_path|
41
48
  require subscriber_path
42
- File.basename(subscriber_path, '.rb').classify.constantize.new
49
+ File.basename(subscriber_path, '.rb').classify.constantize.new.tap do |subscriber|
50
+ subscriber.logger = logger if subscriber.respond_to? :logger=
51
+ end
43
52
  end
44
53
  end
45
54
 
@@ -48,7 +57,7 @@ class Subscriber
48
57
  end
49
58
 
50
59
  private
51
- def queue_name(subscriber)
60
+ def routing_prefix(subscriber)
52
61
  from = subscriber.class.name.sub(/Subscriber$/, '').underscore
53
62
  to = Rails.application.class.name.sub('::Application', '').underscore
54
63
 
@@ -1,3 +1,3 @@
1
1
  module EspCommons
2
- VERSION = "0.3.1"
2
+ VERSION = "0.3.2"
3
3
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: esp-commons
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.3.1
4
+ version: 0.3.2
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -9,11 +9,11 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2012-04-26 00:00:00.000000000 Z
12
+ date: 2012-04-27 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: active_attr
16
- requirement: &16840440 !ruby/object:Gem::Requirement
16
+ requirement: &9792180 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ! '>='
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: '0'
22
22
  type: :runtime
23
23
  prerelease: false
24
- version_requirements: *16840440
24
+ version_requirements: *9792180
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: amqp
27
- requirement: &16867680 !ruby/object:Gem::Requirement
27
+ requirement: &9819120 !ruby/object:Gem::Requirement
28
28
  none: false
29
29
  requirements:
30
30
  - - ! '>='
@@ -32,10 +32,10 @@ dependencies:
32
32
  version: '0'
33
33
  type: :runtime
34
34
  prerelease: false
35
- version_requirements: *16867680
35
+ version_requirements: *9819120
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: bunny
38
- requirement: &16867100 !ruby/object:Gem::Requirement
38
+ requirement: &9818540 !ruby/object:Gem::Requirement
39
39
  none: false
40
40
  requirements:
41
41
  - - ! '>='
@@ -43,10 +43,10 @@ dependencies:
43
43
  version: '0'
44
44
  type: :runtime
45
45
  prerelease: false
46
- version_requirements: *16867100
46
+ version_requirements: *9818540
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: curb
49
- requirement: &16866360 !ruby/object:Gem::Requirement
49
+ requirement: &9817840 !ruby/object:Gem::Requirement
50
50
  none: false
51
51
  requirements:
52
52
  - - ! '>='
@@ -54,10 +54,10 @@ dependencies:
54
54
  version: '0'
55
55
  type: :runtime
56
56
  prerelease: false
57
- version_requirements: *16866360
57
+ version_requirements: *9817840
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: daemons
60
- requirement: &16865340 !ruby/object:Gem::Requirement
60
+ requirement: &9816640 !ruby/object:Gem::Requirement
61
61
  none: false
62
62
  requirements:
63
63
  - - ! '>='
@@ -65,10 +65,10 @@ dependencies:
65
65
  version: '0'
66
66
  type: :runtime
67
67
  prerelease: false
68
- version_requirements: *16865340
68
+ version_requirements: *9816640
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: openteam-commons
71
- requirement: &16864620 !ruby/object:Gem::Requirement
71
+ requirement: &9816040 !ruby/object:Gem::Requirement
72
72
  none: false
73
73
  requirements:
74
74
  - - ! '>='
@@ -76,10 +76,10 @@ dependencies:
76
76
  version: '0'
77
77
  type: :runtime
78
78
  prerelease: false
79
- version_requirements: *16864620
79
+ version_requirements: *9816040
80
80
  - !ruby/object:Gem::Dependency
81
81
  name: rails
82
- requirement: &16864140 !ruby/object:Gem::Requirement
82
+ requirement: &9815560 !ruby/object:Gem::Requirement
83
83
  none: false
84
84
  requirements:
85
85
  - - ! '>='
@@ -87,10 +87,10 @@ dependencies:
87
87
  version: '0'
88
88
  type: :runtime
89
89
  prerelease: false
90
- version_requirements: *16864140
90
+ version_requirements: *9815560
91
91
  - !ruby/object:Gem::Dependency
92
92
  name: sqlite3
93
- requirement: &16862880 !ruby/object:Gem::Requirement
93
+ requirement: &9814360 !ruby/object:Gem::Requirement
94
94
  none: false
95
95
  requirements:
96
96
  - - ! '>='
@@ -98,7 +98,7 @@ dependencies:
98
98
  version: '0'
99
99
  type: :development
100
100
  prerelease: false
101
- version_requirements: *16862880
101
+ version_requirements: *9814360
102
102
  description: Description of EspCommons.
103
103
  email:
104
104
  - mail@openteam.ru
@@ -134,7 +134,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
134
134
  version: '0'
135
135
  segments:
136
136
  - 0
137
- hash: -3357116084122121062
137
+ hash: -177488127929603302
138
138
  required_rubygems_version: !ruby/object:Gem::Requirement
139
139
  none: false
140
140
  requirements:
@@ -143,7 +143,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
143
143
  version: '0'
144
144
  segments:
145
145
  - 0
146
- hash: -3357116084122121062
146
+ hash: -177488127929603302
147
147
  requirements: []
148
148
  rubyforge_project:
149
149
  rubygems_version: 1.8.15