Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/net-amqp-rabbitmq/net-amqp-rabbitmq
Perl bindings to the librabbitmq-c AMQP library.
https://github.com/net-amqp-rabbitmq/net-amqp-rabbitmq
hacktoberfest perl perlxs rabbitmq rabbitmq-client rabbitmq-consumer
Last synced: 6 days ago
JSON representation
Perl bindings to the librabbitmq-c AMQP library.
- Host: GitHub
- URL: https://github.com/net-amqp-rabbitmq/net-amqp-rabbitmq
- Owner: net-amqp-rabbitmq
- License: other
- Created: 2013-12-16T13:34:25.000Z (about 11 years ago)
- Default Branch: main
- Last Pushed: 2024-11-10T13:37:25.000Z (about 2 months ago)
- Last Synced: 2024-12-27T04:06:05.799Z (13 days ago)
- Topics: hacktoberfest, perl, perlxs, rabbitmq, rabbitmq-client, rabbitmq-consumer
- Language: Perl
- Homepage:
- Size: 887 KB
- Stars: 23
- Watchers: 5
- Forks: 26
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- Changelog: Changes
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
Awesome Lists containing this project
README
![example workflow](https://github.com/net-amqp-rabbitmq/net-amqp-rabbitmq/actions/workflows/linux-builds.yml/badge.svg)
[![Coverage Status](https://coveralls.io/repos/net-amqp-rabbitmq/net-amqp-rabbitmq/badge.png)](https://coveralls.io/r/net-amqp-rabbitmq/net-amqp-rabbitmq)# NOTICE
This module has been in a pretty rough state of repair for a few years. I've been slowly cleaning it up and working on it as time allows.
With version `2.40011`, I feel like we may be in pretty good shape. OpenSSL v3 is supported now, and `rabbitmq-c` is updated to `v0.14.0`.> [!IMPORTANT]
> I could really use a hand with peer review on some of this cleanup. If you, or someone you know, is excited about security and is competent to review C code, [please see this GitHub Discussion](https://github.com/net-amqp-rabbitmq/net-amqp-rabbitmq/discussions/247#discussion-6849541). Thank you.# Install
` cpanm Net::AMQP::RabbitMQ`
or
`cpan Net::AMQP::RabbitMQ`
# Documentation
or once installed `perldoc Net::AMQP::RabbitMQ`
# Tests
There are several environment variables you can set that influence the tests.
# For developers/authors
Once you have cloned the repo, you will need to download the submodules.
```sh
git submodule init
git submodule update
```This module uses [Carton](https://metacpan.org/pod/Carton) for Perl dependencies. Please first install Carton, and then install Perl dependencies using:
```sh
carton install
```When running your own tests, for quick access to a testing RabbitMQ service, consider [CloudAMQP](https://cloudamqp.com).
There are a few convenience scripts to help you out:
- `local-tests-no-ssl` - Convenience script to run tests on a local network without SSL at all.
- `run-one-test` - This script helps you quickly run a single test while working on this project.
- `ci/run-ci-tests.sh` - This script is what we run in GitHub Actions, it'll help you run the full suite. This script will likely only run on GNU/Linux, and depending on your RabbitMQ server's capacity it could take in excess of two hours to run completely.# To build a release
```sh
make distclean
perl Makefile.PL
make manifest
make dist
```## Known challenges
- In order to run test `024_boolean_header_fields.t`, you need to have the web client for RabbitMQ enabled, and your test user must have access to it. This is because this test uses the web client to test specific use cases which require a literal Boolean type (which Perl lacks).
# Special note for macOS
You need `pkg-config` working, especially for openssl. There are so many different
ways to install dependencies, and so many different paths for them, it is becoming
very difficult to guess where they will be.As a result, we're shifting to using `pkg-config` for this. Please make sure
that if you're running into any problems of missing symbols or misplaced files,
that you check this _first_.# OpenSSL Compatibility
To date, OpenSSL v3 is supported.