PHPinnacle Ridge
This library is a pure asynchronous PHP implementation of the AMQP 0-9-1 protocol.
Code is mostly based on bunnyphp, but use amphp for async operations.
Install
Via Composer
$ composer require phpinnacle/ridgeBasic Usage
<?php
use Amp\Loop;
use PHPinnacle\Ridge\Channel;
use PHPinnacle\Ridge\Client;
use PHPinnacle\Ridge\Message;
require __DIR__ . '/vendor/autoload.php';
Loop::run(function () {
$client = Client::create('amqp://user:pass@localhost:5672');
yield $client->connect();
/** @var Channel $channel */
$channel = yield $client->channel();
yield $channel->queueDeclare('queue_name');
for ($i = 0; $i < 10; $i++) {
yield $channel->publish("test_$i", '', 'queue_name');
}
yield $channel->consume(function (Message $message, Channel $channel) {
echo $message->content() . \PHP_EOL;
yield $channel->ack($message);
}, 'queue_name');
});More examples can be found in examples directory.
Testing
$ composer testsChange log
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING and CONDUCT for details.
Security
If you discover any security related issues, please email dev@phpinnacle.com instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.

Formed in 2009, the Archive Team (not to be confused with the archive.org Archive-It Team) is a rogue archivist collective dedicated to saving copies of rapidly dying or deleted websites for the sake of history and digital heritage. The group is 100% composed of volunteers and interested parties, and has expanded into a large amount of related projects for saving online and digital history.
