Go to file
Matt Broadstone f2ac01de34 add preliminary support for publisher acknowledgements
RabbitMQ supports publish confirms (Publisher Acknowledgements) on
a given channel. This enables the user to toggle this functionality
and ensure that published messages are in fact published.
2015-01-19 13:51:20 -05:00
src add preliminary support for publisher acknowledgements 2015-01-19 13:51:20 -05:00
tests add preliminary support for publisher acknowledgements 2015-01-19 13:51:20 -05:00
tutorials remove QAMQP namespace 2014-09-15 13:26:48 -04:00
.gitignore Don't install test cases 2014-09-30 08:06:30 -04:00
.travis.yml Add coveralls support to travis builds 2014-09-16 17:42:21 -04:00
Doxyfile [+] Start write documentation 2012-07-18 09:18:04 -07:00
LICENSE.html 2012-01-29 07:43:56 -08:00
README.md Add coveralls support to travis builds 2014-09-16 17:42:21 -04:00
qamqp.pri fix windows build 2014-09-11 15:37:46 -04:00
qamqp.pro begin to add rabbitmq tutorials 2014-06-18 10:31:28 -04:00

README.md

Build Status Coverage Status

QAMQP

Qt4/Qt5 implementation of AMQP 0.9.1.

Implement

Connection

work with socket connections

  • start - start connection negotiation
  • startok - select security mechanism and locale
  • tune - propose connection tuning parameters
  • tuneok - negotiate connection tuning parameters
  • open - open connection to virtual host
  • openok - signal that connection is ready
  • close - request a connection close
  • closeok - confirm a connection close

Channel

work with channels

  • open - open a channel for use
  • openok - signal that the channel is ready
  • close - request a channel close
  • closeok - confirm a channel close

Exchange

work with exchanges

  • declare - verify exchange exists, create if needed
  • declareok - confirm exchange declaration
  • delete - delete an exchange
  • deleteok - confirm deletion of an exchange

Queue

work with queues

  • declare - declare queue, create if needed
  • declareok - confirms a queue definition
  • bind - bind queue to an exchange
  • bindok - confirm bind successful
  • unbind - unbind a queue from an exchange
  • unbindok - confirm unbind successful
  • purge - purge a queue
  • purgeok - confirms a queue purge
  • delete - delete a queue
  • deleteok - confirm deletion of a queue

Basic

work with basic content

  • qos - specify quality of service
  • qosok - confirm the requested qos
  • consume - start a queue consumer
  • consumeok - confirm a new consumer
  • publish - publish a message
  • deliver - notify the client of a consumer message
  • get - direct access to a queue
  • getok - provide client with a message
  • getempty - indicate no messages available
  • ack - acknowledge one or more messages

Usage

Test::Test()	
{
	QUrl con(QString("amqp://guest:guest@localhost:5672/"));
	client_ = new QAMQP::Client(this);
	connect(client_, SIGNAL(connected()), this, SLOT(connected()));
	client_->open(con);
	exchange_ =  client_->createExchange("test.test2");
	queue_ = client_->createQueue("test.my_queue", exchange_->channelNumber());
		
	connect(queue_, SIGNAL(declared()), this, SLOT(declared()));
	connect(queue_, SIGNAL(messageReceived(QAMQP::Queue * )), this, SLOT(newMessage(QAMQP::Queue *)));	

}

void Test::connected()
{
	exchange_->declare("fanout");		
	queue_->declare();
	exchange_->bind(queue_);
}

void Test::declared()
{
	exchange_->publish("Hello world", exchange_->name());
	queue_->setQOS(0,10);
	queue_->setConsumerTag("qamqp-consumer");
	queue_->consume(QAMQP::Queue::coNoAck);
}

void Test::newMessage(QAMQP::Queue * q)
{
	while (q->hasMessage())
	{
		QAMQP::MessagePtr message = q->getMessage();
		qDebug("+ RECEIVE MESSAGE");
		qDebug("| Exchange-name: %s", qPrintable(message->exchangeName));
		qDebug("| Routing-key: %s", qPrintable(message->routeKey));
		qDebug("| Content-type: %s", qPrintable(message->property[QAMQP::Frame::Content::cpContentType].toString()));
		if(!q->noAck())
		{
			q->ack(message);
		}
	}
}

Credits

Thank you @mdhooge for tutorials inspired by https://github.com/jonnydee/nzmqt

githalytics.com alpha