amqp-client.js
AMQP 0-9-1 client both for Node.js and browsers (using WebSocket). API documentation.
This library is Promise-based and hence works very well with async/await. It's secure by default, for instance, publishes aren't fulfilled until either the data has been sent on the wire (so that back propagation is respected), or if the channel has Publish Confirms enabled, it isn't fulfilled until the server has acknowledged that the message has been enqueued.
The library was developed so to make it easy for developers who already are familiar with AMQP to write browser apps that communicates directly with an AMQP server over WebSocket.
The library is developed and supported by CloudAMQP, the largest hosted RabbitMQ provider in the world.
Install
npm install @cloudamqp/amqp-client --save
For web browsers a rolled up version is available in dist/.
Example usage
Using AMQP in Node.js:
import AMQPClient from '@cloudamqp/amqp-client'
async function run() {
try {
const amqp = new AMQPClient("amqp://localhost")
const conn = await amqp.connect()
const ch = await conn.channel()
const q = await ch.queue()
const consumer = await q.subscribe({noAck: true}, async (msg) => {
console.log(msg.bodyToString())
await consumer.cancel()
})
await q.publish("Hello World", {deliveryMode: 2})
await consumer.wait()
await conn.close()
} catch (e) {
console.error("ERROR", e)
e.connection.close()
setTimeout(run, 1000)
}
}
run()
Using AMQP over WebSockets in a browser:
<!DOCTYPE html>
<html>
<head>
<script type=module>
import AMQPClient from './js/amqp-websocket-client.mjs'
const textarea = document.getElementById("textarea")
const input = document.getElementById("message")
const tls = window.location.scheme === "https:"
const url = `${tls ? "wss" : "ws"}://${window.location.host}`
const amqp = new AMQPClient(url, "/", "guest", "guest")
async function start() {
try {
const conn = await amqp.connect()
const ch = await conn.channel()
attachPublish(ch)
const q = await ch.queue("")
await q.bind("amq.fanout")
const consumer = await q.subscribe({noAck: false}, (msg) => {
console.log(msg)
textarea.value += msg.bodyToString() + "\n"
msg.ack()
})
} catch (err) {
console.error("Error", err, "reconnecting in 1s")
disablePublish()
setTimeout(start, 1000)
}
}
function attachPublish(ch) {
document.forms[0].onsubmit = async (e) => {
e.preventDefault()
try {
await ch.basicPublish("amq.fanout", "", input.value, { contentType: "text/plain" })
} catch (err) {
console.error("Error", err, "reconnecting in 1s")
disablePublish()
setTimeout(start, 1000)
}
input.value = ""
}
}
function disablePublish() {
document.forms[0].onsubmit = (e) => { alert("Disconnected, waiting to be reconnected") }
}
start()
</script>
</head>
<body>
<form>
<textarea id="textarea" rows=10></textarea>
<br/>
<input id="message"/>
<button type="submit">Send</button>
</form>
</body>
</html>