com.microsoft.azure.eventhubs.impl.EventDataUtil Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of azure-eventhubs Show documentation
Show all versions of azure-eventhubs Show documentation
Client library for talking to Microsoft Azure Event Hubs.
/*
* Copyright (c) Microsoft. All rights reserved.
* Licensed under the MIT license. See LICENSE file in the project root for full license information.
*/
package com.microsoft.azure.eventhubs.impl;
import com.microsoft.azure.eventhubs.EventData;
import org.apache.qpid.proton.message.Message;
import java.util.*;
import java.util.function.Consumer;
/*
* Internal utility class for EventData
*/
final class EventDataUtil {
@SuppressWarnings("serial")
static final Set RESERVED_SYSTEM_PROPERTIES = Collections.unmodifiableSet(new HashSet() {{
add(AmqpConstants.OFFSET_ANNOTATION_NAME);
add(AmqpConstants.PARTITION_KEY_ANNOTATION_NAME);
add(AmqpConstants.SEQUENCE_NUMBER_ANNOTATION_NAME);
add(AmqpConstants.ENQUEUED_TIME_UTC_ANNOTATION_NAME);
add(AmqpConstants.PUBLISHER_ANNOTATION_NAME);
}});
private EventDataUtil() {
}
static LinkedList toEventDataCollection(final Collection messages, final PassByRef lastMessageRef) {
if (messages == null) {
return null;
}
LinkedList events = new LinkedList<>();
for (Message message : messages) {
events.add(new EventDataImpl(message));
if (lastMessageRef != null)
lastMessageRef.set(message);
}
return events;
}
static Iterable toAmqpMessages(final Iterable eventDatas, final String partitionKey) {
final LinkedList messages = new LinkedList<>();
eventDatas.forEach(new Consumer() {
@Override
public void accept(EventData eventData) {
EventDataImpl eventDataImpl = (EventDataImpl) eventData;
Message amqpMessage = partitionKey == null ? eventDataImpl.toAmqpMessage() : eventDataImpl.toAmqpMessage(partitionKey);
messages.add(amqpMessage);
}
});
return messages;
}
static Iterable toAmqpMessages(final Iterable eventDatas) {
return EventDataUtil.toAmqpMessages(eventDatas, null);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy