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( 
     | 
| 
      
 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 " 
     | 
| 
       6 
     | 
    
         
            -
                 
     | 
| 
       7 
     | 
    
         
            -
                   
     | 
| 
      
 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 
     | 
    
         
            -
                     
     | 
| 
       12 
     | 
    
         
            -
                    queue = channel.queue(queue_name(subscriber), :durable => true)
         
     | 
| 
      
 17 
     | 
    
         
            +
                    topic = routing_prefix(subscriber)
         
     | 
| 
       13 
18 
     | 
    
         | 
| 
       14 
     | 
    
         
            -
                     
     | 
| 
      
 19 
     | 
    
         
            +
                    exchange = channel.topic(topic)
         
     | 
| 
      
 20 
     | 
    
         
            +
                    queue = channel.queue(topic, :durable => true)
         
     | 
| 
       15 
21 
     | 
    
         | 
| 
       16 
     | 
    
         
            -
                     
     | 
| 
       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 
     | 
    
         
            -
                         
     | 
| 
       27 
     | 
    
         
            -
             
     | 
| 
       28 
     | 
    
         
            -
             
     | 
| 
      
 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}  
     | 
| 
      
 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  
     | 
| 
      
 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 
     | 
    
         | 
    
        data/lib/esp-commons/version.rb
    CHANGED
    
    
    
        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. 
     | 
| 
      
 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- 
     | 
| 
      
 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: & 
     | 
| 
      
 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: * 
     | 
| 
      
 24 
     | 
    
         
            +
              version_requirements: *9792180
         
     | 
| 
       25 
25 
     | 
    
         
             
            - !ruby/object:Gem::Dependency
         
     | 
| 
       26 
26 
     | 
    
         
             
              name: amqp
         
     | 
| 
       27 
     | 
    
         
            -
              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: * 
     | 
| 
      
 35 
     | 
    
         
            +
              version_requirements: *9819120
         
     | 
| 
       36 
36 
     | 
    
         
             
            - !ruby/object:Gem::Dependency
         
     | 
| 
       37 
37 
     | 
    
         
             
              name: bunny
         
     | 
| 
       38 
     | 
    
         
            -
              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: * 
     | 
| 
      
 46 
     | 
    
         
            +
              version_requirements: *9818540
         
     | 
| 
       47 
47 
     | 
    
         
             
            - !ruby/object:Gem::Dependency
         
     | 
| 
       48 
48 
     | 
    
         
             
              name: curb
         
     | 
| 
       49 
     | 
    
         
            -
              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: * 
     | 
| 
      
 57 
     | 
    
         
            +
              version_requirements: *9817840
         
     | 
| 
       58 
58 
     | 
    
         
             
            - !ruby/object:Gem::Dependency
         
     | 
| 
       59 
59 
     | 
    
         
             
              name: daemons
         
     | 
| 
       60 
     | 
    
         
            -
              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: * 
     | 
| 
      
 68 
     | 
    
         
            +
              version_requirements: *9816640
         
     | 
| 
       69 
69 
     | 
    
         
             
            - !ruby/object:Gem::Dependency
         
     | 
| 
       70 
70 
     | 
    
         
             
              name: openteam-commons
         
     | 
| 
       71 
     | 
    
         
            -
              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: * 
     | 
| 
      
 79 
     | 
    
         
            +
              version_requirements: *9816040
         
     | 
| 
       80 
80 
     | 
    
         
             
            - !ruby/object:Gem::Dependency
         
     | 
| 
       81 
81 
     | 
    
         
             
              name: rails
         
     | 
| 
       82 
     | 
    
         
            -
              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: * 
     | 
| 
      
 90 
     | 
    
         
            +
              version_requirements: *9815560
         
     | 
| 
       91 
91 
     | 
    
         
             
            - !ruby/object:Gem::Dependency
         
     | 
| 
       92 
92 
     | 
    
         
             
              name: sqlite3
         
     | 
| 
       93 
     | 
    
         
            -
              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: * 
     | 
| 
      
 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: - 
     | 
| 
      
 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: - 
     | 
| 
      
 146 
     | 
    
         
            +
                  hash: -177488127929603302
         
     | 
| 
       147 
147 
     | 
    
         
             
            requirements: []
         
     | 
| 
       148 
148 
     | 
    
         
             
            rubyforge_project: 
         
     | 
| 
       149 
149 
     | 
    
         
             
            rubygems_version: 1.8.15
         
     |