com.microsoft.azure.eventhubs.BatchOptions 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;
import java.util.function.Consumer;
/**
* BatchOptions is used to create {@link EventDataBatch}es.
*
* If you're creating {@link EventDataBatch}es with {@link EventHubClient}, then you can set a partitionKey and maxMessageSize
* using the .with() method. Alternatively, if you'd like the default settings, simply construct BatchOptions with the void constructor.
* Default settings:
* - partitionKey is null
* - maxMessageSize is the maximum allowed size
*
* If you're creating {@link EventDataBatch}es with {@link PartitionSender}, then you can only set a maxMessageSize
* using the .with() method. Alternatively, if you'd like the default settings, simply construct BatchOptions with the void constructor.
* Default settings:
* - maxMessageSize is the maximum allowed size
* - Note: if you set a partition key, an {@link IllegalArgumentException} will be thrown.
*
* To construct either type of batch, create a {@link BatchOptions} object and pass it into the appropriate
* createBatch method. If using {@link PartitionSender}, then use ({@link PartitionSender#createBatch(BatchOptions)}.
* If using {@link EventHubClient}, then use {@link EventHubClient#createBatch(BatchOptions)}.
*
*
* {@code
* // Note: For all examples, 'client' is an instance of EventHubClient. The usage is the same for PartitionSender,
* however, you can NOT set a partition key when using PartitionSender
*
* // Create EventDataBatch with defaults
* EventDataBatch edb1 = client.createBatch();
*
* // Create EventDataBatch with custom partitionKey
* BatchOptions options = new BatchOptions().with( options -> options.partitionKey = "foo");
* EventDataBatch edb2 = client.createBatch(options);
*
* // Create EventDataBatch with custom partitionKey and maxMessageSize
* BatchOptions options = new BatchOptions().with ( options -> {
* options.partitionKey = "foo";
* options.maxMessageSize = 100 * 1024;
* };
* EventDataBatch edb3 = client.createBatch(options);
* }
*
*/
public final class BatchOptions {
public String partitionKey = null;
public Integer maxMessageSize = null;
public final BatchOptions with(Consumer builderFunction) {
builderFunction.accept(this);
return this;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy