com.pulumi.azure.streamanalytics.outputs.ReferenceInputBlobSerialization Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of azure Show documentation
Show all versions of azure Show documentation
A Pulumi package for creating and managing Microsoft Azure cloud resources, based on the Terraform azurerm provider. We recommend using the [Azure Native provider](https://github.com/pulumi/pulumi-azure-native) to provision Azure infrastructure. Azure Native provides complete coverage of Azure resources and same-day access to new resources and resource updates.
// *** WARNING: this file was generated by pulumi-java-gen. ***
// *** Do not edit by hand unless you're certain you know what you are doing! ***
package com.pulumi.azure.streamanalytics.outputs;
import com.pulumi.core.annotations.CustomType;
import com.pulumi.exceptions.MissingRequiredPropertyException;
import java.lang.String;
import java.util.Objects;
import java.util.Optional;
import javax.annotation.Nullable;
@CustomType
public final class ReferenceInputBlobSerialization {
/**
* @return The encoding of the incoming data in the case of input and the encoding of outgoing data in the case of output. It currently can only be set to `UTF8`.
*
* > **NOTE:** This is required when `type` is set to `Csv` or `Json`.
*
*/
private @Nullable String encoding;
/**
* @return The delimiter that will be used to separate comma-separated value (CSV) records. Possible values are ` ` (space), `,` (comma), ` ` (tab), `|` (pipe) and `;`.
*
* > **NOTE:** This is required when `type` is set to `Csv`.
*
*/
private @Nullable String fieldDelimiter;
/**
* @return The serialization format used for the reference data. Possible values are `Avro`, `Csv` and `Json`.
*
*/
private String type;
private ReferenceInputBlobSerialization() {}
/**
* @return The encoding of the incoming data in the case of input and the encoding of outgoing data in the case of output. It currently can only be set to `UTF8`.
*
* > **NOTE:** This is required when `type` is set to `Csv` or `Json`.
*
*/
public Optional encoding() {
return Optional.ofNullable(this.encoding);
}
/**
* @return The delimiter that will be used to separate comma-separated value (CSV) records. Possible values are ` ` (space), `,` (comma), ` ` (tab), `|` (pipe) and `;`.
*
* > **NOTE:** This is required when `type` is set to `Csv`.
*
*/
public Optional fieldDelimiter() {
return Optional.ofNullable(this.fieldDelimiter);
}
/**
* @return The serialization format used for the reference data. Possible values are `Avro`, `Csv` and `Json`.
*
*/
public String type() {
return this.type;
}
public static Builder builder() {
return new Builder();
}
public static Builder builder(ReferenceInputBlobSerialization defaults) {
return new Builder(defaults);
}
@CustomType.Builder
public static final class Builder {
private @Nullable String encoding;
private @Nullable String fieldDelimiter;
private String type;
public Builder() {}
public Builder(ReferenceInputBlobSerialization defaults) {
Objects.requireNonNull(defaults);
this.encoding = defaults.encoding;
this.fieldDelimiter = defaults.fieldDelimiter;
this.type = defaults.type;
}
@CustomType.Setter
public Builder encoding(@Nullable String encoding) {
this.encoding = encoding;
return this;
}
@CustomType.Setter
public Builder fieldDelimiter(@Nullable String fieldDelimiter) {
this.fieldDelimiter = fieldDelimiter;
return this;
}
@CustomType.Setter
public Builder type(String type) {
if (type == null) {
throw new MissingRequiredPropertyException("ReferenceInputBlobSerialization", "type");
}
this.type = type;
return this;
}
public ReferenceInputBlobSerialization build() {
final var _resultValue = new ReferenceInputBlobSerialization();
_resultValue.encoding = encoding;
_resultValue.fieldDelimiter = fieldDelimiter;
_resultValue.type = type;
return _resultValue;
}
}
}