com.microsoft.azure.eventhubs.impl.PartitionSenderImpl Maven / Gradle / Ivy
/*
* 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.*;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.Executor;
import java.util.function.Consumer;
import java.util.function.Function;
final class PartitionSenderImpl extends ClientEntity implements PartitionSender {
private final String partitionId;
private final String eventHubName;
private final MessagingFactory factory;
private volatile MessageSender internalSender;
private PartitionSenderImpl(final MessagingFactory factory, final String eventHubName, final String partitionId, final Executor executor) {
super(null, null, executor);
this.partitionId = partitionId;
this.eventHubName = eventHubName;
this.factory = factory;
}
static CompletableFuture Create(final MessagingFactory factory,
final String eventHubName,
final String partitionId,
final Executor executor) throws EventHubException {
final PartitionSenderImpl sender = new PartitionSenderImpl(factory, eventHubName, partitionId, executor);
return sender.createInternalSender()
.thenApplyAsync(new Function() {
public PartitionSender apply(Void a) {
return sender;
}
}, executor);
}
private CompletableFuture createInternalSender() throws EventHubException {
return MessageSender.create(this.factory, StringUtil.getRandomString(),
String.format("%s/Partitions/%s", this.eventHubName, this.partitionId))
.thenAcceptAsync(new Consumer() {
public void accept(MessageSender a) {
PartitionSenderImpl.this.internalSender = a;
}
}, this.executor);
}
public String getPartitionId() {
return this.partitionId;
}
public EventDataBatch createBatch(BatchOptions options) {
if (!StringUtil.isNullOrEmpty(options.partitionKey)) {
throw new IllegalArgumentException("A partition key cannot be set when using PartitionSenderImpl. If you'd like to " +
"continue using PartitionSenderImpl with EventDataBatches, then please do not set a partition key in your BatchOptions.");
}
int maxSize = this.internalSender.getMaxMessageSize();
if (options.maxMessageSize == null) {
return new EventDataBatchImpl(maxSize, null);
}
if (options.maxMessageSize > maxSize) {
throw new IllegalArgumentException("The maxMessageSize set in BatchOptions is too large. You set a maxMessageSize of " +
options.maxMessageSize + ". The maximum allowed size is " + maxSize + ".");
}
return new EventDataBatchImpl(options.maxMessageSize, null);
}
public final CompletableFuture send(EventData data) {
return this.internalSender.send(((EventDataImpl) data).toAmqpMessage());
}
public final CompletableFuture send(Iterable eventDatas) {
if (eventDatas == null || IteratorUtil.sizeEquals(eventDatas, 0)) {
throw new IllegalArgumentException("EventData batch cannot be empty.");
}
return this.internalSender.send(EventDataUtil.toAmqpMessages(eventDatas));
}
public final CompletableFuture send(EventDataBatch eventDatas) {
if (eventDatas == null || Integer.compare(eventDatas.getSize(), 0) == 0) {
throw new IllegalArgumentException("EventDataBatch cannot be empty.");
}
if (!StringUtil.isNullOrEmpty(((EventDataBatchImpl) eventDatas).getPartitionKey())) {
throw new IllegalArgumentException("A partition key cannot be set when using PartitionSenderImpl. If you'd like to " +
"continue using PartitionSenderImpl with EventDataBatches, then please do not set a partition key in your BatchOptions");
}
return this.internalSender.send(EventDataUtil.toAmqpMessages(((EventDataBatchImpl) eventDatas).getInternalIterable()));
}
@Override
public CompletableFuture onClose() {
if (this.internalSender == null) {
return CompletableFuture.completedFuture(null);
} else {
return this.internalSender.close();
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy