2023-12-01 20:38:48 +08:00
|
|
|
// Copyright 2023 Memgraph Ltd.
|
2021-11-11 19:17:05 +08:00
|
|
|
//
|
|
|
|
// Use of this software is governed by the Business Source License
|
|
|
|
// included in the file licenses/BSL.txt; by using this file, you agree to be bound by the terms of the Business Source
|
|
|
|
// License, and you may not use this file except in compliance with the Business Source License.
|
|
|
|
//
|
|
|
|
// As of the Change Date specified in that file, in accordance with
|
|
|
|
// the Business Source License, use of this software will be governed
|
|
|
|
// by the Apache License, Version 2.0, included in the file
|
|
|
|
// licenses/APL.txt.
|
|
|
|
|
|
|
|
#pragma once
|
2023-12-01 20:38:48 +08:00
|
|
|
|
2021-11-11 19:17:05 +08:00
|
|
|
#include <atomic>
|
|
|
|
#include <optional>
|
|
|
|
#include <span>
|
|
|
|
#include <thread>
|
|
|
|
|
|
|
|
#include <pulsar/Client.h>
|
|
|
|
|
2022-02-22 20:33:45 +08:00
|
|
|
namespace memgraph::integrations::pulsar {
|
2021-11-11 19:17:05 +08:00
|
|
|
|
|
|
|
namespace pulsar_client = ::pulsar;
|
|
|
|
|
|
|
|
class Consumer;
|
|
|
|
|
|
|
|
class Message final {
|
|
|
|
public:
|
|
|
|
explicit Message(pulsar_client::Message &&message);
|
|
|
|
|
|
|
|
std::span<const char> Payload() const;
|
2021-11-15 23:23:49 +08:00
|
|
|
std::string_view TopicName() const;
|
2021-11-11 19:17:05 +08:00
|
|
|
|
|
|
|
private:
|
|
|
|
pulsar_client::Message message_;
|
|
|
|
|
|
|
|
friend Consumer;
|
|
|
|
};
|
|
|
|
|
|
|
|
using ConsumerFunction = std::function<void(const std::vector<Message> &)>;
|
|
|
|
|
|
|
|
struct ConsumerInfo {
|
2021-11-30 23:29:51 +08:00
|
|
|
int64_t batch_size;
|
|
|
|
std::chrono::milliseconds batch_interval;
|
2021-11-11 19:17:05 +08:00
|
|
|
std::vector<std::string> topics;
|
|
|
|
std::string consumer_name;
|
|
|
|
std::string service_url;
|
|
|
|
};
|
|
|
|
|
|
|
|
class Consumer final {
|
|
|
|
public:
|
|
|
|
Consumer(ConsumerInfo info, ConsumerFunction consumer_function);
|
|
|
|
~Consumer();
|
|
|
|
|
|
|
|
Consumer(const Consumer &) = delete;
|
|
|
|
Consumer(Consumer &&) noexcept = delete;
|
|
|
|
Consumer &operator=(const Consumer &) = delete;
|
|
|
|
Consumer &operator=(Consumer &&) = delete;
|
|
|
|
|
|
|
|
bool IsRunning() const;
|
|
|
|
void Start();
|
2022-06-20 20:09:45 +08:00
|
|
|
void StartWithLimit(uint64_t limit_batches, std::optional<std::chrono::milliseconds> timeout) const;
|
2021-11-11 19:17:05 +08:00
|
|
|
void Stop();
|
|
|
|
void StopIfRunning();
|
|
|
|
|
2022-06-20 20:09:45 +08:00
|
|
|
void Check(std::optional<std::chrono::milliseconds> timeout, std::optional<uint64_t> limit_batches,
|
2021-11-11 19:17:05 +08:00
|
|
|
const ConsumerFunction &check_consumer_function) const;
|
|
|
|
|
|
|
|
const ConsumerInfo &Info() const;
|
|
|
|
|
|
|
|
private:
|
|
|
|
void StartConsuming();
|
2022-06-20 20:09:45 +08:00
|
|
|
void StartConsumingWithLimit(uint64_t limit_batches, std::optional<std::chrono::milliseconds> timeout) const;
|
2021-11-11 19:17:05 +08:00
|
|
|
void StopConsuming();
|
|
|
|
|
|
|
|
ConsumerInfo info_;
|
|
|
|
mutable pulsar_client::Client client_;
|
2022-06-20 20:09:45 +08:00
|
|
|
mutable pulsar_client::Consumer consumer_;
|
2021-11-11 19:17:05 +08:00
|
|
|
ConsumerFunction consumer_function_;
|
|
|
|
|
|
|
|
mutable std::atomic<bool> is_running_{false};
|
2022-06-20 20:09:45 +08:00
|
|
|
mutable pulsar_client::MessageId last_message_id_{pulsar_client::MessageId::earliest()}; // Protected by is_running_
|
2021-11-11 19:17:05 +08:00
|
|
|
std::thread thread_;
|
|
|
|
};
|
2022-02-22 20:33:45 +08:00
|
|
|
} // namespace memgraph::integrations::pulsar
|