rest-rsmq v0.4.1
REST rsmq
A REST interface for rsmq the really simple message queue based on Redis.
This REST interface makes it easy to use rsmq with other application platforms like php, .net etc. Simply call the RESTful methods to send and receive messages.
Note: There is no security built in - so use this only in a trusted enviroment, just like memcached.
Installation
- Make sure Node 0.8.10+ is installed
- Clone this repository
- Run
npm installto install the dependencies - For the test make sure Redis runs locally and run
npm test - Optional: Modify the server port in server.js
- Start the server:
node server.js
Methods
changeMessageVisibility
PUT /message/qname/id
Change the visibility of the message with id id from queue qname.
Example:
PUT /message/myqueue/dhxekddac921a9422ec10e5439b55aa62e4dd49142?vt=5Response:
{"result": 1}createQueue
POST /queues/qname
Create a new queue qname
Parameters:
qname(String): The Queue name. Maximum 80 characters; alphanumeric characters, hyphens (-), and underscores (_) are allowed.vt(Number): optional (Default: 30) The length of time, in seconds, that a message received from a queue will be invisible to other receiving components when they ask to receive messages. Allowed values: 0-9999999delay(Number): optional (Default: 0) The time in seconds that the delivery of all new messages in the queue will be delayed. Allowed values: 0-9999999maxsize(Number): optional (Default: 65536) The maximum message size in bytes. Allowed values: 1024-65536
Example:
POST /queues/myqueue
Content-Type: application/json
{
"vt": 30,
"delay": 0,
"maxsize": 2048
}Response:
{"result": 1}deleteMessage
DELETE /messages/qname/id
Delete the message with id id from queue qname.
Example:
DELETE /messages/myqueue/dhxekddac921a9422ec10e5439b55aa62e4dd49142Response:
{"result": 1}deleteQueue
DELETE /queues/qname
Delete the queue qname and all messages in that queue.
Example:
DELETE /queues/myqueueResponse:
{"result": 1}getQueueAttributes
Get queue attributes, counter and stats
Parameters:
qname(String): The Queue name.
Example:
GET /queues/myqueueResponse:
{
"vt": 30,
"delay": 0,
"maxsize": 65536,
"totalrecv": 32,
"totalsent": 13,
"created": 1371645477,
"modified": 1371645477,
"msgs": 4,
"hiddenmsgs": 2
}listQueues
GET /queues
List all queues.
Example:
GET /queuesResponse:
{"queues": ["myqueue","someOtherQueue"]}receiveMessage
GET /messages/qname
Receive the next message from the queue.
Parameters:
vt(Number): optional (Default: 30) The length of time, in seconds, that a message received from a queue will be invisible to other receiving components when they ask to receive messages. Allowed values: 0-9999999
Example:
GET /messages/myqueue?vt=30Response:
{
"id": "dhxeguaqv8cb2c78e9b5c97121d60f4caf54925c03",
"message": "Hello World!",
"rc": 1,
"fr": 1370856862274,
"sent": 1370855815832
}sendMessage
POST /messages/qname
Sends a new message.
Example:
POST /messages/myqueue
Content-Type: application/json
{
"message": "Hello World!",
"delay": 0
}Response:
{
"id": "dhxekddac921a9422ec10e5439b55aa62e4dd49142"
}The MIT License (MIT)
Please see the LICENSE.md file.
