Skip to content

coveooss/hareflow

Repository files navigation

Hareflow

Hareflow is a RabbitMQ stream client for C++.

It uses an API similar to the existing official Java client, with the ability to create, delete, consume from, and publish to streams.

License

Quick Start

git clone https://github.com/coveooss/hareflow
cmake [-DBUILD_TESTS=TRUE] -B build -S hareflow
cmake --build build
ctest --test-dir build
cmake --install build --prefix staging
cpack --config build/CPackConfig.cmake

Take note that Hareflow relies on the boost-asio library, which requires the /etc/services file to operate properly on Linux systems. In Debian-based distributions, this file is included in the netbase package, which is typically installed via the apt package manager.

vcpkg

If you want to use microsoft/vcpkg as the package manager, set the environment variable CMAKE_TOOLCHAIN_FILE to <VCPKG_ROOT>/scripts/buildsystems/vcpkg.cmake where <VCPKG_ROOT> is the path of the vcpkg repository on your machine.

Project State and Maturity

The project is still in development, however most APIs are expected to remain stable and API breaking changes will be kept to a minimum.

A low-level client is also exposed, though its direct usage is generally not needed and its API is subject to breaking changes.

No guarantees are made about ABI stability.

Getting Started

#include <chrono>

#include <hareflow/hareflow.h>

int main()
{
    // Note: these are the default values, they are only specified for illustration purposes.
    hareflow::EnvironmentPtr environment = hareflow::EnvironmentBuilder().host("localhost").username("guest").password("guest").build();

    environment->stream_creator().stream("my-stream").max_age(std::chrono::hours(6)).create();

    int nb_confirmed = 0;
    hareflow::ProducerPtr producer = environment->producer_builder().stream("my-stream").build();
    for (int i = 0; i < 5; ++i) {
        hareflow::MessagePtr message = hareflow::MessageBuilder().body("some data").build();
        producer->send(message, [&](const hareflow::ConfirmationStatus& status) {
            if (status.confirmed) {
                ++nb_confirmed;
            } else {
                // deal with error appropriately
            }
        });
    }
    // Note: waiting for confirmations omitted for simplicity
    producer = nullptr;

    int nb_consumed = 0;
    auto message_handler = [&](const hareflow::MessageContext& context, hareflow::MessagePtr message) {
        ++nb_consumed;
    };
    hareflow::ConsumerPtr consumer = environment->consumer_builder().stream("my-stream").offset(hareflow::OffsetSpecification::first()).message_handler(message_handler).build();
    // Note: waiting for messages omitted for simplicity
    consumer = nullptr;

    return 0;
}

Features

  • Creating, deleting, publishing to, and consuming from streams.
  • Automatic reconnection on network or broker failure.
  • Wrapping messages in AMQP 1.0 frame for better queue interoperability.
  • Manual or automatic cursor management for consumers, with automatic periodic persist.
  • Automatic message batching, with configurable maximum publish delay.

Installation

Hareflow is integrated to vcpkg and it is highly suggested to use it to build and install the library: https://vcpkg.io/en/package/hareflow

Hareflow supports GCC, Clang, and MSVC, and requires a compiler with support for C++17 features.