amqp-subscribe-many 0.1.1 → 0.1.2

Sign up to get free protection for your applications and to get access to all the features.
data/LICENSE CHANGED
@@ -1,20 +1,373 @@
1
- Copyright (c) Brendan Hay
2
-
3
- Permission is hereby granted, free of charge, to any person obtaining
4
- a copy of this software and associated documentation files (the
5
- "Software"), to deal in the Software without restriction, including
6
- without limitation the rights to use, copy, modify, merge, publish,
7
- distribute, sublicense, and/or sell copies of the Software, and to
8
- permit persons to whom the Software is furnished to do so, subject to
9
- the following conditions:
10
-
11
- The above copyright notice and this permission notice shall be
12
- included in all copies or substantial portions of the Software.
13
-
14
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
- EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
- MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
- NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
- LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
- OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
- WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
1
+ Mozilla Public License Version 2.0
2
+ ==================================
3
+
4
+ 1. Definitions
5
+ --------------
6
+
7
+ 1.1. "Contributor"
8
+ means each individual or legal entity that creates, contributes to
9
+ the creation of, or owns Covered Software.
10
+
11
+ 1.2. "Contributor Version"
12
+ means the combination of the Contributions of others (if any) used
13
+ by a Contributor and that particular Contributor's Contribution.
14
+
15
+ 1.3. "Contribution"
16
+ means Covered Software of a particular Contributor.
17
+
18
+ 1.4. "Covered Software"
19
+ means Source Code Form to which the initial Contributor has attached
20
+ the notice in Exhibit A, the Executable Form of such Source Code
21
+ Form, and Modifications of such Source Code Form, in each case
22
+ including portions thereof.
23
+
24
+ 1.5. "Incompatible With Secondary Licenses"
25
+ means
26
+
27
+ (a) that the initial Contributor has attached the notice described
28
+ in Exhibit B to the Covered Software; or
29
+
30
+ (b) that the Covered Software was made available under the terms of
31
+ version 1.1 or earlier of the License, but not also under the
32
+ terms of a Secondary License.
33
+
34
+ 1.6. "Executable Form"
35
+ means any form of the work other than Source Code Form.
36
+
37
+ 1.7. "Larger Work"
38
+ means a work that combines Covered Software with other material, in
39
+ a separate file or files, that is not Covered Software.
40
+
41
+ 1.8. "License"
42
+ means this document.
43
+
44
+ 1.9. "Licensable"
45
+ means having the right to grant, to the maximum extent possible,
46
+ whether at the time of the initial grant or subsequently, any and
47
+ all of the rights conveyed by this License.
48
+
49
+ 1.10. "Modifications"
50
+ means any of the following:
51
+
52
+ (a) any file in Source Code Form that results from an addition to,
53
+ deletion from, or modification of the contents of Covered
54
+ Software; or
55
+
56
+ (b) any new file in Source Code Form that contains any Covered
57
+ Software.
58
+
59
+ 1.11. "Patent Claims" of a Contributor
60
+ means any patent claim(s), including without limitation, method,
61
+ process, and apparatus claims, in any patent Licensable by such
62
+ Contributor that would be infringed, but for the grant of the
63
+ License, by the making, using, selling, offering for sale, having
64
+ made, import, or transfer of either its Contributions or its
65
+ Contributor Version.
66
+
67
+ 1.12. "Secondary License"
68
+ means either the GNU General Public License, Version 2.0, the GNU
69
+ Lesser General Public License, Version 2.1, the GNU Affero General
70
+ Public License, Version 3.0, or any later versions of those
71
+ licenses.
72
+
73
+ 1.13. "Source Code Form"
74
+ means the form of the work preferred for making modifications.
75
+
76
+ 1.14. "You" (or "Your")
77
+ means an individual or a legal entity exercising rights under this
78
+ License. For legal entities, "You" includes any entity that
79
+ controls, is controlled by, or is under common control with You. For
80
+ purposes of this definition, "control" means (a) the power, direct
81
+ or indirect, to cause the direction or management of such entity,
82
+ whether by contract or otherwise, or (b) ownership of more than
83
+ fifty percent (50%) of the outstanding shares or beneficial
84
+ ownership of such entity.
85
+
86
+ 2. License Grants and Conditions
87
+ --------------------------------
88
+
89
+ 2.1. Grants
90
+
91
+ Each Contributor hereby grants You a world-wide, royalty-free,
92
+ non-exclusive license:
93
+
94
+ (a) under intellectual property rights (other than patent or trademark)
95
+ Licensable by such Contributor to use, reproduce, make available,
96
+ modify, display, perform, distribute, and otherwise exploit its
97
+ Contributions, either on an unmodified basis, with Modifications, or
98
+ as part of a Larger Work; and
99
+
100
+ (b) under Patent Claims of such Contributor to make, use, sell, offer
101
+ for sale, have made, import, and otherwise transfer either its
102
+ Contributions or its Contributor Version.
103
+
104
+ 2.2. Effective Date
105
+
106
+ The licenses granted in Section 2.1 with respect to any Contribution
107
+ become effective for each Contribution on the date the Contributor first
108
+ distributes such Contribution.
109
+
110
+ 2.3. Limitations on Grant Scope
111
+
112
+ The licenses granted in this Section 2 are the only rights granted under
113
+ this License. No additional rights or licenses will be implied from the
114
+ distribution or licensing of Covered Software under this License.
115
+ Notwithstanding Section 2.1(b) above, no patent license is granted by a
116
+ Contributor:
117
+
118
+ (a) for any code that a Contributor has removed from Covered Software;
119
+ or
120
+
121
+ (b) for infringements caused by: (i) Your and any other third party's
122
+ modifications of Covered Software, or (ii) the combination of its
123
+ Contributions with other software (except as part of its Contributor
124
+ Version); or
125
+
126
+ (c) under Patent Claims infringed by Covered Software in the absence of
127
+ its Contributions.
128
+
129
+ This License does not grant any rights in the trademarks, service marks,
130
+ or logos of any Contributor (except as may be necessary to comply with
131
+ the notice requirements in Section 3.4).
132
+
133
+ 2.4. Subsequent Licenses
134
+
135
+ No Contributor makes additional grants as a result of Your choice to
136
+ distribute the Covered Software under a subsequent version of this
137
+ License (see Section 10.2) or under the terms of a Secondary License (if
138
+ permitted under the terms of Section 3.3).
139
+
140
+ 2.5. Representation
141
+
142
+ Each Contributor represents that the Contributor believes its
143
+ Contributions are its original creation(s) or it has sufficient rights
144
+ to grant the rights to its Contributions conveyed by this License.
145
+
146
+ 2.6. Fair Use
147
+
148
+ This License is not intended to limit any rights You have under
149
+ applicable copyright doctrines of fair use, fair dealing, or other
150
+ equivalents.
151
+
152
+ 2.7. Conditions
153
+
154
+ Sections 3.1, 3.2, 3.3, and 3.4 are conditions of the licenses granted
155
+ in Section 2.1.
156
+
157
+ 3. Responsibilities
158
+ -------------------
159
+
160
+ 3.1. Distribution of Source Form
161
+
162
+ All distribution of Covered Software in Source Code Form, including any
163
+ Modifications that You create or to which You contribute, must be under
164
+ the terms of this License. You must inform recipients that the Source
165
+ Code Form of the Covered Software is governed by the terms of this
166
+ License, and how they can obtain a copy of this License. You may not
167
+ attempt to alter or restrict the recipients' rights in the Source Code
168
+ Form.
169
+
170
+ 3.2. Distribution of Executable Form
171
+
172
+ If You distribute Covered Software in Executable Form then:
173
+
174
+ (a) such Covered Software must also be made available in Source Code
175
+ Form, as described in Section 3.1, and You must inform recipients of
176
+ the Executable Form how they can obtain a copy of such Source Code
177
+ Form by reasonable means in a timely manner, at a charge no more
178
+ than the cost of distribution to the recipient; and
179
+
180
+ (b) You may distribute such Executable Form under the terms of this
181
+ License, or sublicense it under different terms, provided that the
182
+ license for the Executable Form does not attempt to limit or alter
183
+ the recipients' rights in the Source Code Form under this License.
184
+
185
+ 3.3. Distribution of a Larger Work
186
+
187
+ You may create and distribute a Larger Work under terms of Your choice,
188
+ provided that You also comply with the requirements of this License for
189
+ the Covered Software. If the Larger Work is a combination of Covered
190
+ Software with a work governed by one or more Secondary Licenses, and the
191
+ Covered Software is not Incompatible With Secondary Licenses, this
192
+ License permits You to additionally distribute such Covered Software
193
+ under the terms of such Secondary License(s), so that the recipient of
194
+ the Larger Work may, at their option, further distribute the Covered
195
+ Software under the terms of either this License or such Secondary
196
+ License(s).
197
+
198
+ 3.4. Notices
199
+
200
+ You may not remove or alter the substance of any license notices
201
+ (including copyright notices, patent notices, disclaimers of warranty,
202
+ or limitations of liability) contained within the Source Code Form of
203
+ the Covered Software, except that You may alter any license notices to
204
+ the extent required to remedy known factual inaccuracies.
205
+
206
+ 3.5. Application of Additional Terms
207
+
208
+ You may choose to offer, and to charge a fee for, warranty, support,
209
+ indemnity or liability obligations to one or more recipients of Covered
210
+ Software. However, You may do so only on Your own behalf, and not on
211
+ behalf of any Contributor. You must make it absolutely clear that any
212
+ such warranty, support, indemnity, or liability obligation is offered by
213
+ You alone, and You hereby agree to indemnify every Contributor for any
214
+ liability incurred by such Contributor as a result of warranty, support,
215
+ indemnity or liability terms You offer. You may include additional
216
+ disclaimers of warranty and limitations of liability specific to any
217
+ jurisdiction.
218
+
219
+ 4. Inability to Comply Due to Statute or Regulation
220
+ ---------------------------------------------------
221
+
222
+ If it is impossible for You to comply with any of the terms of this
223
+ License with respect to some or all of the Covered Software due to
224
+ statute, judicial order, or regulation then You must: (a) comply with
225
+ the terms of this License to the maximum extent possible; and (b)
226
+ describe the limitations and the code they affect. Such description must
227
+ be placed in a text file included with all distributions of the Covered
228
+ Software under this License. Except to the extent prohibited by statute
229
+ or regulation, such description must be sufficiently detailed for a
230
+ recipient of ordinary skill to be able to understand it.
231
+
232
+ 5. Termination
233
+ --------------
234
+
235
+ 5.1. The rights granted under this License will terminate automatically
236
+ if You fail to comply with any of its terms. However, if You become
237
+ compliant, then the rights granted under this License from a particular
238
+ Contributor are reinstated (a) provisionally, unless and until such
239
+ Contributor explicitly and finally terminates Your grants, and (b) on an
240
+ ongoing basis, if such Contributor fails to notify You of the
241
+ non-compliance by some reasonable means prior to 60 days after You have
242
+ come back into compliance. Moreover, Your grants from a particular
243
+ Contributor are reinstated on an ongoing basis if such Contributor
244
+ notifies You of the non-compliance by some reasonable means, this is the
245
+ first time You have received notice of non-compliance with this License
246
+ from such Contributor, and You become compliant prior to 30 days after
247
+ Your receipt of the notice.
248
+
249
+ 5.2. If You initiate litigation against any entity by asserting a patent
250
+ infringement claim (excluding declaratory judgment actions,
251
+ counter-claims, and cross-claims) alleging that a Contributor Version
252
+ directly or indirectly infringes any patent, then the rights granted to
253
+ You by any and all Contributors for the Covered Software under Section
254
+ 2.1 of this License shall terminate.
255
+
256
+ 5.3. In the event of termination under Sections 5.1 or 5.2 above, all
257
+ end user license agreements (excluding distributors and resellers) which
258
+ have been validly granted by You or Your distributors under this License
259
+ prior to termination shall survive termination.
260
+
261
+ ************************************************************************
262
+ * *
263
+ * 6. Disclaimer of Warranty *
264
+ * ------------------------- *
265
+ * *
266
+ * Covered Software is provided under this License on an "as is" *
267
+ * basis, without warranty of any kind, either expressed, implied, or *
268
+ * statutory, including, without limitation, warranties that the *
269
+ * Covered Software is free of defects, merchantable, fit for a *
270
+ * particular purpose or non-infringing. The entire risk as to the *
271
+ * quality and performance of the Covered Software is with You. *
272
+ * Should any Covered Software prove defective in any respect, You *
273
+ * (not any Contributor) assume the cost of any necessary servicing, *
274
+ * repair, or correction. This disclaimer of warranty constitutes an *
275
+ * essential part of this License. No use of any Covered Software is *
276
+ * authorized under this License except under this disclaimer. *
277
+ * *
278
+ ************************************************************************
279
+
280
+ ************************************************************************
281
+ * *
282
+ * 7. Limitation of Liability *
283
+ * -------------------------- *
284
+ * *
285
+ * Under no circumstances and under no legal theory, whether tort *
286
+ * (including negligence), contract, or otherwise, shall any *
287
+ * Contributor, or anyone who distributes Covered Software as *
288
+ * permitted above, be liable to You for any direct, indirect, *
289
+ * special, incidental, or consequential damages of any character *
290
+ * including, without limitation, damages for lost profits, loss of *
291
+ * goodwill, work stoppage, computer failure or malfunction, or any *
292
+ * and all other commercial damages or losses, even if such party *
293
+ * shall have been informed of the possibility of such damages. This *
294
+ * limitation of liability shall not apply to liability for death or *
295
+ * personal injury resulting from such party's negligence to the *
296
+ * extent applicable law prohibits such limitation. Some *
297
+ * jurisdictions do not allow the exclusion or limitation of *
298
+ * incidental or consequential damages, so this exclusion and *
299
+ * limitation may not apply to You. *
300
+ * *
301
+ ************************************************************************
302
+
303
+ 8. Litigation
304
+ -------------
305
+
306
+ Any litigation relating to this License may be brought only in the
307
+ courts of a jurisdiction where the defendant maintains its principal
308
+ place of business and such litigation shall be governed by laws of that
309
+ jurisdiction, without reference to its conflict-of-law provisions.
310
+ Nothing in this Section shall prevent a party's ability to bring
311
+ cross-claims or counter-claims.
312
+
313
+ 9. Miscellaneous
314
+ ----------------
315
+
316
+ This License represents the complete agreement concerning the subject
317
+ matter hereof. If any provision of this License is held to be
318
+ unenforceable, such provision shall be reformed only to the extent
319
+ necessary to make it enforceable. Any law or regulation which provides
320
+ that the language of a contract shall be construed against the drafter
321
+ shall not be used to construe this License against a Contributor.
322
+
323
+ 10. Versions of the License
324
+ ---------------------------
325
+
326
+ 10.1. New Versions
327
+
328
+ Mozilla Foundation is the license steward. Except as provided in Section
329
+ 10.3, no one other than the license steward has the right to modify or
330
+ publish new versions of this License. Each version will be given a
331
+ distinguishing version number.
332
+
333
+ 10.2. Effect of New Versions
334
+
335
+ You may distribute the Covered Software under the terms of the version
336
+ of the License under which You originally received the Covered Software,
337
+ or under the terms of any subsequent version published by the license
338
+ steward.
339
+
340
+ 10.3. Modified Versions
341
+
342
+ If you create software not governed by this License, and you want to
343
+ create a new license for such software, you may create and use a
344
+ modified version of this License if you rename the license and remove
345
+ any references to the name of the license steward (except to note that
346
+ such modified license differs from this License).
347
+
348
+ 10.4. Distributing Source Code Form that is Incompatible With Secondary
349
+ Licenses
350
+
351
+ If You choose to distribute Source Code Form that is Incompatible With
352
+ Secondary Licenses under the terms of this version of the License, the
353
+ notice described in Exhibit B of this License must be attached.
354
+
355
+ Exhibit A - Source Code Form License Notice
356
+ -------------------------------------------
357
+
358
+ This Source Code Form is subject to the terms of the Mozilla Public
359
+ License, v. 2.0. If a copy of the MPL was not distributed with this
360
+ file, You can obtain one at http://mozilla.org/MPL/2.0/.
361
+
362
+ If it is not possible or desirable to put the notice in a particular
363
+ file, then You may include the notice in a location (such as a LICENSE
364
+ file in a relevant directory) where a recipient would be likely to look
365
+ for such a notice.
366
+
367
+ You may add additional accurate notices of copyright ownership.
368
+
369
+ Exhibit B - "Incompatible With Secondary Licenses" Notice
370
+ ---------------------------------------------------------
371
+
372
+ This Source Code Form is "Incompatible With Secondary Licenses", as
373
+ defined by the Mozilla Public License, v. 2.0.
data/Rakefile CHANGED
@@ -49,9 +49,9 @@ Jeweler::RubygemsDotOrgTasks.new
49
49
 
50
50
  Jeweler::Tasks.new do |gem|
51
51
  gem.name = "amqp-subscribe-many"
52
- gem.version = "0.1.1"
52
+ gem.version = "0.1.2"
53
53
  gem.homepage = "http://github.com/brendanhay/amqp-subscribe-many"
54
- gem.license = "BSD"
54
+ gem.license = "MPL"
55
55
  gem.summary = "'Publish-one, subscribe-many' pattern implementation"
56
56
  gem.description = gem.summary
57
57
  gem.email = "brendan@soundcloud.com"
@@ -5,7 +5,7 @@
5
5
 
6
6
  Gem::Specification.new do |s|
7
7
  s.name = %q{amqp-subscribe-many}
8
- s.version = "0.1.1"
8
+ s.version = "0.1.2"
9
9
 
10
10
  s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
11
  s.authors = [%q{brendanhay}]
@@ -25,20 +25,22 @@ Gem::Specification.new do |s|
25
25
  "README.md",
26
26
  "Rakefile",
27
27
  "amqp-subscribe-many.gemspec",
28
+ "examples/consumer_processor.rb",
29
+ "examples/duplex_processor.rb",
30
+ "examples/producer_processor.rb",
31
+ "examples/run",
28
32
  "lib/messaging.rb",
29
33
  "lib/messaging/client.rb",
30
34
  "lib/messaging/configuration.rb",
31
35
  "lib/messaging/consumer.rb",
32
36
  "lib/messaging/producer.rb",
33
- "script/config.yml",
34
- "script/run.rb",
35
37
  "test/client_test.rb",
36
38
  "test/configuration_test.rb",
37
39
  "test/consumer_test.rb",
38
40
  "test/test_helper.rb"
39
41
  ]
40
42
  s.homepage = %q{http://github.com/brendanhay/amqp-subscribe-many}
41
- s.licenses = [%q{BSD}]
43
+ s.licenses = [%q{MPL}]
42
44
  s.require_paths = [%q{lib}]
43
45
  s.rubygems_version = %q{1.8.7}
44
46
  s.summary = %q{'Publish-one, subscribe-many' pattern implementation}
@@ -0,0 +1,12 @@
1
+ require "messaging"
2
+
3
+ # A consume only example
4
+ class ConsumerProcessor
5
+ include Messaging::Consumer
6
+
7
+ subscribe("exchange", "direct", "queue", "key")
8
+
9
+ def on_message(meta, payload)
10
+ log.info("ConsumeProcessor channel #{meta.channel.id} received payload #{payload.inspect}")
11
+ end
12
+ end
@@ -0,0 +1,13 @@
1
+ require "messaging"
2
+
3
+ # A consume and publish example
4
+ class DuplexProcessor
5
+ include Messaging::Producer
6
+ include Messaging::Consumer
7
+
8
+ subscribe("exchange", "direct", "queue", "key")
9
+
10
+ def on_message(meta, payload)
11
+ log.info("DuplexProcessor channel #{meta.channel.id} received payload #{payload.inspect}")
12
+ end
13
+ end
@@ -0,0 +1,6 @@
1
+ require "messaging"
2
+
3
+ # A publish only example
4
+ class ProducerProcessor
5
+ include Messaging::Producer
6
+ end
data/examples/run ADDED
@@ -0,0 +1,57 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require "rubygems"
4
+ require "bundler"
5
+
6
+ Bundler.setup(:default)
7
+
8
+ $:.unshift(File.dirname(__FILE__) + "/../lib")
9
+
10
+ require "messaging"
11
+
12
+ require_relative "consumer_processor"
13
+ require_relative "producer_processor"
14
+ require_relative "duplex_processor"
15
+
16
+ # Setup configuration
17
+ Messaging::Configuration.setup do |config|
18
+ config.publish_to = "amqp://localhost"
19
+ config.consume_from = [
20
+ "amqp://localhost",
21
+ "amqp://localhost",
22
+ "amqp://localhost"
23
+ ]
24
+ end
25
+
26
+ EM.run do
27
+ # Instantiate the processors
28
+ consumer = ConsumerProcessor.new
29
+ producer = ProducerProcessor.new
30
+ duplex = DuplexProcessor.new
31
+
32
+ # Start the consumers
33
+ consumer.consume
34
+ duplex.consume
35
+
36
+ # Create a handle to the publish timer, to cancel later
37
+ timer = EM.add_periodic_timer(0.5) do
38
+ producer.publish("exchange", "direct", "key", "a_producer_payload")
39
+ duplex.publish("exchange", "direct", "key", "a_duplex_payload")
40
+ end
41
+
42
+ # Handle Ctrl-C interrupt
43
+ trap("INT") do
44
+ puts "Stopping..."
45
+
46
+ # Cancel the publisher timer
47
+ EM.cancel_timer(timer)
48
+
49
+ # Disconnect the producer/consumer connections
50
+ consumer.disconnect
51
+ producer.disconnect
52
+ duplex.disconnect
53
+
54
+ # Shutdown the EM loop
55
+ EM.add_timer(1) { EM.stop }
56
+ end
57
+ end
@@ -48,35 +48,6 @@ module Messaging
48
48
  self
49
49
  end
50
50
 
51
- # Subscribe to a queue which will invoke the supplied block when
52
- # a message is received.
53
- # Additionally declaring a binding to the specified exchange/key pair.
54
- #
55
- # @param exchange [String]
56
- # @param type [String]
57
- # @param queue [String]
58
- # @param key [String]
59
- # @return [Messaging::Consumer]
60
- # @api public
61
- def subscribe(exchange, type, queue, key)
62
- consumer_channels.each do |channel|
63
- ex = declare_exchange(channel, exchange, type, config.exchange_options)
64
- q = declare_queue(channel, ex, queue, key, config.queue_options)
65
-
66
- q.subscribe(:ack => true) do |meta, payload|
67
- log.debug("Receieved message on channel #{meta.channel.id} from queue #{queue.inspect}")
68
-
69
- # If this raises an exception, the connection
70
- # will be closed, and the message requeued by the broker.
71
- on_message(meta, payload)
72
-
73
- meta.ack
74
- end
75
- end
76
-
77
- self
78
- end
79
-
80
51
  # @raise [NotImplementedError]
81
52
  # @api protected
82
53
  def on_message(meta, payload)
@@ -118,6 +89,35 @@ module Messaging
118
89
  def subscriptions
119
90
  self.class.subscriptions
120
91
  end
92
+
93
+ # Subscribe to a queue which will invoke the supplied block when
94
+ # a message is received.
95
+ # Additionally declaring a binding to the specified exchange/key pair.
96
+ #
97
+ # @param exchange [String]
98
+ # @param type [String]
99
+ # @param queue [String]
100
+ # @param key [String]
101
+ # @return [Messaging::Consumer]
102
+ # @api public
103
+ def subscribe(exchange, type, queue, key)
104
+ consumer_channels.each do |channel|
105
+ ex = declare_exchange(channel, exchange, type, config.exchange_options)
106
+ q = declare_queue(channel, ex, queue, key, config.queue_options)
107
+
108
+ q.subscribe(:ack => true) do |meta, payload|
109
+ log.debug("Receieved message on channel #{meta.channel.id} from queue #{queue.inspect}")
110
+
111
+ # If this raises an exception, the connection
112
+ # will be closed, and the message requeued by the broker.
113
+ on_message(meta, payload)
114
+
115
+ meta.ack
116
+ end
117
+ end
118
+
119
+ self
120
+ end
121
121
  end
122
122
 
123
123
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: amqp-subscribe-many
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.1
4
+ version: 0.1.2
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -13,7 +13,7 @@ date: 2012-07-10 00:00:00.000000000Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: amqp
16
- requirement: &70180070452160 !ruby/object:Gem::Requirement
16
+ requirement: &70257899258140 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ! '>='
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: 0.9.6
22
22
  type: :runtime
23
23
  prerelease: false
24
- version_requirements: *70180070452160
24
+ version_requirements: *70257899258140
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: bundler
27
- requirement: &70180070451500 !ruby/object:Gem::Requirement
27
+ requirement: &70257899255060 !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: :development
34
34
  prerelease: false
35
- version_requirements: *70180070451500
35
+ version_requirements: *70257899255060
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: minitest
38
- requirement: &70180070450860 !ruby/object:Gem::Requirement
38
+ requirement: &70257899253200 !ruby/object:Gem::Requirement
39
39
  none: false
40
40
  requirements:
41
41
  - - ! '>='
@@ -43,10 +43,10 @@ dependencies:
43
43
  version: '3.0'
44
44
  type: :development
45
45
  prerelease: false
46
- version_requirements: *70180070450860
46
+ version_requirements: *70257899253200
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: mocha
49
- requirement: &70180070450260 !ruby/object:Gem::Requirement
49
+ requirement: &70257899251440 !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: :development
56
56
  prerelease: false
57
- version_requirements: *70180070450260
57
+ version_requirements: *70257899251440
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: jeweler
60
- requirement: &70180070449620 !ruby/object:Gem::Requirement
60
+ requirement: &70257899250540 !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: :development
67
67
  prerelease: false
68
- version_requirements: *70180070449620
68
+ version_requirements: *70257899250540
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: redcarpet
71
- requirement: &70180070449020 !ruby/object:Gem::Requirement
71
+ requirement: &70257899249480 !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: :development
78
78
  prerelease: false
79
- version_requirements: *70180070449020
79
+ version_requirements: *70257899249480
80
80
  - !ruby/object:Gem::Dependency
81
81
  name: yard
82
- requirement: &70180070448440 !ruby/object:Gem::Requirement
82
+ requirement: &70257899248880 !ruby/object:Gem::Requirement
83
83
  none: false
84
84
  requirements:
85
85
  - - ! '>='
@@ -87,7 +87,7 @@ dependencies:
87
87
  version: '0'
88
88
  type: :development
89
89
  prerelease: false
90
- version_requirements: *70180070448440
90
+ version_requirements: *70257899248880
91
91
  description: ! '''Publish-one, subscribe-many'' pattern implementation'
92
92
  email: brendan@soundcloud.com
93
93
  executables: []
@@ -104,20 +104,22 @@ files:
104
104
  - README.md
105
105
  - Rakefile
106
106
  - amqp-subscribe-many.gemspec
107
+ - examples/consumer_processor.rb
108
+ - examples/duplex_processor.rb
109
+ - examples/producer_processor.rb
110
+ - examples/run
107
111
  - lib/messaging.rb
108
112
  - lib/messaging/client.rb
109
113
  - lib/messaging/configuration.rb
110
114
  - lib/messaging/consumer.rb
111
115
  - lib/messaging/producer.rb
112
- - script/config.yml
113
- - script/run.rb
114
116
  - test/client_test.rb
115
117
  - test/configuration_test.rb
116
118
  - test/consumer_test.rb
117
119
  - test/test_helper.rb
118
120
  homepage: http://github.com/brendanhay/amqp-subscribe-many
119
121
  licenses:
120
- - BSD
122
+ - MPL
121
123
  post_install_message:
122
124
  rdoc_options: []
123
125
  require_paths:
@@ -130,7 +132,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
130
132
  version: '0'
131
133
  segments:
132
134
  - 0
133
- hash: 235469886921977757
135
+ hash: -2295620827239768178
134
136
  required_rubygems_version: !ruby/object:Gem::Requirement
135
137
  none: false
136
138
  requirements:
data/script/config.yml DELETED
@@ -1,6 +0,0 @@
1
- ---
2
- :publish_to: amqp://localhost
3
- :consume_from:
4
- - amqp://localhost
5
- - amqp://localhost
6
- - amqp://localhost
data/script/run.rb DELETED
@@ -1,86 +0,0 @@
1
- #!/usr/bin/env ruby
2
-
3
- require "rubygems"
4
- require "bundler"
5
-
6
- Bundler.setup(:default)
7
-
8
- $:.unshift(File.dirname(__FILE__) + "/../lib")
9
-
10
- require "messaging"
11
-
12
- EXCHANGE = "exchange"
13
- TYPE = "direct"
14
- QUEUE = "queue"
15
- KEY = "key"
16
-
17
- # Load the config
18
- yml = YAML::load_file(File.dirname(__FILE__) + "/config.yml")
19
-
20
- # Setup configuration
21
- Messaging::Configuration.setup do |config|
22
- config.publish_to = yml[:publish_to]
23
- config.consume_from = yml[:consume_from]
24
- end
25
-
26
- # Consume example
27
- class ConsumerProcessor
28
- include Messaging::Consumer
29
-
30
- subscribe(EXCHANGE, TYPE, QUEUE, KEY)
31
-
32
- def on_message(meta, payload)
33
- log.info("ConsumeProcessor channel #{meta.channel.id} received payload #{payload.inspect}")
34
- end
35
- end
36
-
37
- # Publish example
38
- class ProducerProcessor
39
- include Messaging::Producer
40
- end
41
-
42
- # Consume + publish example
43
- class DuplexProcessor
44
- include Messaging::Producer
45
- include Messaging::Consumer
46
-
47
- subscribe(EXCHANGE, TYPE, QUEUE, KEY)
48
-
49
- def on_message(meta, payload)
50
- log.info("DuplexProcessor channel #{meta.channel.id} received payload #{payload.inspect}")
51
- end
52
- end
53
-
54
- EM.run do
55
-
56
- # Instantiate the processors
57
- consumer = ConsumerProcessor.new
58
- producer = ProducerProcessor.new
59
- duplex = DuplexProcessor.new
60
-
61
- # Start the consumers
62
- consumer.consume
63
- duplex.consume
64
-
65
- # Create a handle to the publish timer, to cancel later
66
- timer = EM.add_periodic_timer(0.5) do
67
- producer.publish(EXCHANGE, TYPE, KEY, "a_producer_payload")
68
- duplex.publish(EXCHANGE, TYPE, KEY, "a_duplex_payload")
69
- end
70
-
71
- # Handle Ctrl-C interrupt
72
- trap("INT") do
73
- puts "Stopping..."
74
-
75
- # Cancel the publisher timer
76
- EM.cancel_timer(timer)
77
-
78
- # Disconnect the producer/consumer connections
79
- consumer.disconnect
80
- producer.disconnect
81
- duplex.disconnect
82
-
83
- # Shutdown the EM loop
84
- EM.add_timer(1) { EM.stop }
85
- end
86
- end