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