AMQP-DSL is a fluent interface wrapper for node-amqp and help you write AMQP binding code in a clean and efficient way.
$ npm install amqp-dsl
amqp = require 'amqp-dsl'
amqp.login(
login: 'user'
password: 'password'
host: 'localhost'
).connect((err, amqp) ->
if err
throw err
return
console.log 'We are connected !'
)
AmqpDsl = require 'amqp-dsl'
AmqpDsl.login(
login: 'legen'
password: 'dary'
)
.on( 'close', () -> console.error "RabbitMQ connection closed" )
.on( 'error', (err) -> console.error "RabbitMQ error", err )
.on( 'ready', () -> console.log "Connected to RabbitMQ" )
.queue( 'testQueue', (queue) -> console.log "Connected to Queue", queue.name )
.bind( 'stream', '#' )
.subscribe( (message, header, deliveryInfo) -> )
.queue( 'queue2' )
.bind( 'search', '#.ok' )
.queue( 'queue3', passive:true )
.connect( (err, amqp) ->
if err
throw err
return
# Do other stuff with `amqp` like subscribing to a queue
queue3 = amqp.queues.queue3
queue3.subscribe( ack:true, ( message, header, deliveryInfo ) ->
console.log "Hey ! We got one new message !"
queue3.shift()
)
)
See examples/
and docs/
for more information.
login( options = {} )
on( event, listener )
.exchange( name, options )
.exchange( name, callback(exchange) )
.exchange( name, options, callback(exchange) )
.queue( name, options )
.queue( name, callback(queue) )
.queue( name, options, callback(queue) )
.subscribe( callback(message, header, deliveryInfo) )
.subscribe( options, callback(message, header, deliveryInfo) )
.bind( name, routingKey )
.connect( amqp, callback(err, amqp) )
.connect( callback(err, amqp) )
The amqp
argument is simply hashtable with the following properties:
- queues (hashtable of
AMQP::queues
) - exchanges (hashtable of
AMQP::Exchange
) - connection (
AMQP::Connection
)
$ cake doc
... and browse docs/
$ npm test