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); }