
com.azure.resourcemanager.datafactory.models.AzureBlobFSLocation Maven / Gradle / Ivy
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
// Code generated by Microsoft (R) AutoRest Code Generator.
package com.azure.resourcemanager.datafactory.models;
import com.azure.core.annotation.Fluent;
import com.azure.json.JsonReader;
import com.azure.json.JsonToken;
import com.azure.json.JsonWriter;
import java.io.IOException;
import java.util.LinkedHashMap;
import java.util.Map;
/**
* The location of azure blobFS dataset.
*/
@Fluent
public final class AzureBlobFSLocation extends DatasetLocation {
/*
* Type of dataset storage location.
*/
private String type = "AzureBlobFSLocation";
/*
* Specify the fileSystem of azure blobFS. Type: string (or Expression with resultType string).
*/
private Object fileSystem;
/**
* Creates an instance of AzureBlobFSLocation class.
*/
public AzureBlobFSLocation() {
}
/**
* Get the type property: Type of dataset storage location.
*
* @return the type value.
*/
@Override
public String type() {
return this.type;
}
/**
* Get the fileSystem property: Specify the fileSystem of azure blobFS. Type: string (or Expression with resultType
* string).
*
* @return the fileSystem value.
*/
public Object fileSystem() {
return this.fileSystem;
}
/**
* Set the fileSystem property: Specify the fileSystem of azure blobFS. Type: string (or Expression with resultType
* string).
*
* @param fileSystem the fileSystem value to set.
* @return the AzureBlobFSLocation object itself.
*/
public AzureBlobFSLocation withFileSystem(Object fileSystem) {
this.fileSystem = fileSystem;
return this;
}
/**
* {@inheritDoc}
*/
@Override
public AzureBlobFSLocation withFolderPath(Object folderPath) {
super.withFolderPath(folderPath);
return this;
}
/**
* {@inheritDoc}
*/
@Override
public AzureBlobFSLocation withFileName(Object fileName) {
super.withFileName(fileName);
return this;
}
/**
* Validates the instance.
*
* @throws IllegalArgumentException thrown if the instance is not valid.
*/
@Override
public void validate() {
}
/**
* {@inheritDoc}
*/
@Override
public JsonWriter toJson(JsonWriter jsonWriter) throws IOException {
jsonWriter.writeStartObject();
jsonWriter.writeUntypedField("folderPath", folderPath());
jsonWriter.writeUntypedField("fileName", fileName());
jsonWriter.writeStringField("type", this.type);
jsonWriter.writeUntypedField("fileSystem", this.fileSystem);
if (additionalProperties() != null) {
for (Map.Entry additionalProperty : additionalProperties().entrySet()) {
jsonWriter.writeUntypedField(additionalProperty.getKey(), additionalProperty.getValue());
}
}
return jsonWriter.writeEndObject();
}
/**
* Reads an instance of AzureBlobFSLocation from the JsonReader.
*
* @param jsonReader The JsonReader being read.
* @return An instance of AzureBlobFSLocation if the JsonReader was pointing to an instance of it, or null if it was
* pointing to JSON null.
* @throws IOException If an error occurs while reading the AzureBlobFSLocation.
*/
public static AzureBlobFSLocation fromJson(JsonReader jsonReader) throws IOException {
return jsonReader.readObject(reader -> {
AzureBlobFSLocation deserializedAzureBlobFSLocation = new AzureBlobFSLocation();
Map additionalProperties = null;
while (reader.nextToken() != JsonToken.END_OBJECT) {
String fieldName = reader.getFieldName();
reader.nextToken();
if ("folderPath".equals(fieldName)) {
deserializedAzureBlobFSLocation.withFolderPath(reader.readUntyped());
} else if ("fileName".equals(fieldName)) {
deserializedAzureBlobFSLocation.withFileName(reader.readUntyped());
} else if ("type".equals(fieldName)) {
deserializedAzureBlobFSLocation.type = reader.getString();
} else if ("fileSystem".equals(fieldName)) {
deserializedAzureBlobFSLocation.fileSystem = reader.readUntyped();
} else {
if (additionalProperties == null) {
additionalProperties = new LinkedHashMap<>();
}
additionalProperties.put(fieldName, reader.readUntyped());
}
}
deserializedAzureBlobFSLocation.withAdditionalProperties(additionalProperties);
return deserializedAzureBlobFSLocation;
});
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy