lib/c/c_Consumer.cc (152 lines of code) (raw):
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
#include <pulsar/c/consumer.h>
#include "c_structs.h"
const char *pulsar_consumer_get_topic(pulsar_consumer_t *consumer) {
return consumer->consumer.getTopic().c_str();
}
const char *pulsar_consumer_get_subscription_name(pulsar_consumer_t *consumer) {
return consumer->consumer.getSubscriptionName().c_str();
}
pulsar_result pulsar_consumer_unsubscribe(pulsar_consumer_t *consumer) {
return (pulsar_result)consumer->consumer.unsubscribe();
}
void pulsar_consumer_unsubscribe_async(pulsar_consumer_t *consumer, pulsar_result_callback callback,
void *ctx) {
consumer->consumer.unsubscribeAsync(
std::bind(handle_result_callback, std::placeholders::_1, callback, ctx));
}
pulsar_result pulsar_consumer_receive(pulsar_consumer_t *consumer, pulsar_message_t **msg) {
pulsar::Message message;
pulsar::Result res = consumer->consumer.receive(message);
if (res == pulsar::ResultOk) {
(*msg) = new pulsar_message_t;
(*msg)->message = message;
}
return (pulsar_result)res;
}
pulsar_result pulsar_consumer_receive_with_timeout(pulsar_consumer_t *consumer, pulsar_message_t **msg,
int timeoutMs) {
pulsar::Message message;
pulsar::Result res = consumer->consumer.receive(message, timeoutMs);
if (res == pulsar::ResultOk) {
(*msg) = new pulsar_message_t;
(*msg)->message = message;
}
return (pulsar_result)res;
}
pulsar_result pulsar_consumer_batch_receive(pulsar_consumer_t *consumer, pulsar_messages_t **msgs) {
pulsar::Messages messages;
pulsar::Result res = consumer->consumer.batchReceive(messages);
if (res == pulsar::ResultOk) {
(*msgs) = new pulsar_messages_t;
(*msgs)->messages.resize(messages.size());
for (size_t i = 0; i < messages.size(); i++) {
(*msgs)->messages[i].message = messages[i];
}
}
return (pulsar_result)res;
}
void pulsar_consumer_batch_receive_async(pulsar_consumer_t *consumer, pulsar_batch_receive_callback callback,
void *ctx) {
consumer->consumer.batchReceiveAsync([callback, ctx](pulsar::Result result, pulsar::Messages messages) {
if (callback) {
pulsar_messages_t *msgs = nullptr;
if (result == pulsar::ResultOk) {
msgs = new pulsar_messages_t;
msgs->messages.resize(messages.size());
for (size_t i = 0; i < messages.size(); i++) {
msgs->messages[i].message = messages[i];
}
}
callback((pulsar_result)result, msgs, ctx);
}
});
}
static void handle_receive_callback(pulsar::Result result, pulsar::Message message,
pulsar_receive_callback callback, void *ctx) {
if (callback) {
pulsar_message_t *msg = new pulsar_message_t;
msg->message = message;
callback((pulsar_result)result, msg, ctx);
}
}
void pulsar_consumer_receive_async(pulsar_consumer_t *consumer, pulsar_receive_callback callback, void *ctx) {
consumer->consumer.receiveAsync(
std::bind(handle_receive_callback, std::placeholders::_1, std::placeholders::_2, callback, ctx));
}
pulsar_result pulsar_consumer_acknowledge(pulsar_consumer_t *consumer, pulsar_message_t *message) {
return (pulsar_result)consumer->consumer.acknowledge(message->message);
}
pulsar_result pulsar_consumer_acknowledge_id(pulsar_consumer_t *consumer, pulsar_message_id_t *messageId) {
return (pulsar_result)consumer->consumer.acknowledge(messageId->messageId);
}
void pulsar_consumer_acknowledge_async(pulsar_consumer_t *consumer, pulsar_message_t *message,
pulsar_result_callback callback, void *ctx) {
consumer->consumer.acknowledgeAsync(
message->message, std::bind(handle_result_callback, std::placeholders::_1, callback, ctx));
}
void pulsar_consumer_acknowledge_async_id(pulsar_consumer_t *consumer, pulsar_message_id_t *messageId,
pulsar_result_callback callback, void *ctx) {
consumer->consumer.acknowledgeAsync(
messageId->messageId, std::bind(handle_result_callback, std::placeholders::_1, callback, ctx));
}
pulsar_result pulsar_consumer_acknowledge_cumulative(pulsar_consumer_t *consumer, pulsar_message_t *message) {
return (pulsar_result)consumer->consumer.acknowledgeCumulative(message->message);
}
pulsar_result pulsar_consumer_acknowledge_cumulative_id(pulsar_consumer_t *consumer,
pulsar_message_id_t *messageId) {
return (pulsar_result)consumer->consumer.acknowledge(messageId->messageId);
}
void pulsar_consumer_acknowledge_cumulative_async(pulsar_consumer_t *consumer, pulsar_message_t *message,
pulsar_result_callback callback, void *ctx) {
consumer->consumer.acknowledgeCumulativeAsync(
message->message, std::bind(handle_result_callback, std::placeholders::_1, callback, ctx));
}
void pulsar_consumer_acknowledge_cumulative_async_id(pulsar_consumer_t *consumer,
pulsar_message_id_t *messageId,
pulsar_result_callback callback, void *ctx) {
consumer->consumer.acknowledgeCumulativeAsync(
messageId->messageId, std::bind(handle_result_callback, std::placeholders::_1, callback, ctx));
}
void pulsar_consumer_negative_acknowledge(pulsar_consumer_t *consumer, pulsar_message_t *message) {
consumer->consumer.negativeAcknowledge(message->message);
}
void pulsar_consumer_negative_acknowledge_id(pulsar_consumer_t *consumer, pulsar_message_id_t *messageId) {
consumer->consumer.negativeAcknowledge(messageId->messageId);
}
pulsar_result pulsar_consumer_close(pulsar_consumer_t *consumer) {
return (pulsar_result)consumer->consumer.close();
}
void pulsar_consumer_close_async(pulsar_consumer_t *consumer, pulsar_result_callback callback, void *ctx) {
consumer->consumer.closeAsync(std::bind(handle_result_callback, std::placeholders::_1, callback, ctx));
}
void pulsar_consumer_free(pulsar_consumer_t *consumer) { delete consumer; }
pulsar_result pulsar_consumer_pause_message_listener(pulsar_consumer_t *consumer) {
return (pulsar_result)consumer->consumer.pauseMessageListener();
}
pulsar_result resume_message_listener(pulsar_consumer_t *consumer) {
return (pulsar_result)consumer->consumer.resumeMessageListener();
}
void pulsar_consumer_redeliver_unacknowledged_messages(pulsar_consumer_t *consumer) {
return consumer->consumer.redeliverUnacknowledgedMessages();
}
void pulsar_consumer_seek_async(pulsar_consumer_t *consumer, pulsar_message_id_t *messageId,
pulsar_result_callback callback, void *ctx) {
consumer->consumer.seekAsync(messageId->messageId,
std::bind(handle_result_callback, std::placeholders::_1, callback, ctx));
}
pulsar_result pulsar_consumer_seek(pulsar_consumer_t *consumer, pulsar_message_id_t *messageId) {
return (pulsar_result)consumer->consumer.seek(messageId->messageId);
}
void pulsar_consumer_seek_by_timestamp_async(pulsar_consumer_t *consumer, uint64_t timestamp,
pulsar_result_callback callback, void *ctx) {
consumer->consumer.seekAsync(timestamp,
std::bind(handle_result_callback, std::placeholders::_1, callback, ctx));
}
pulsar_result pulsar_consumer_seek_by_timestamp(pulsar_consumer_t *consumer, uint64_t timestamp) {
return (pulsar_result)consumer->consumer.seek(timestamp);
}
int pulsar_consumer_is_connected(pulsar_consumer_t *consumer) { return consumer->consumer.isConnected(); }
pulsar_result pulsar_consumer_get_last_message_id(pulsar_consumer_t *consumer,
pulsar_message_id_t *messageId) {
return (pulsar_result)consumer->consumer.getLastMessageId(messageId->messageId);
}