com.zuora.model.CreateBatchQueryJobResponse Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of zuora-sdk-java Show documentation
Show all versions of zuora-sdk-java Show documentation
The SDK of JAVA language for Zuora pricing system
/*
* Zuora API Reference
* REST API reference for the Zuora Billing, Payments, and Central Platform! Check out the [REST API Overview](https://www.zuora.com/developer/api-references/api/overview/).
*
* The version of the OpenAPI document: 2024-05-20
* Contact: [email protected]
*
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
* https://openapi-generator.tech
* Do not edit the class manually.
*/
package com.zuora.model;
import java.util.Objects;
import com.google.gson.TypeAdapter;
import com.google.gson.annotations.JsonAdapter;
import com.google.gson.annotations.SerializedName;
import com.google.gson.stream.JsonReader;
import com.google.gson.stream.JsonWriter;
import com.zuora.model.BatchQueryEncrypted;
import com.zuora.model.BatchQueryFormat;
import com.zuora.model.BatchQueryStatus;
import com.zuora.model.CreateBatchQueryResponse;
import java.io.IOException;
import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
import com.google.gson.JsonArray;
import com.google.gson.JsonDeserializationContext;
import com.google.gson.JsonDeserializer;
import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
import com.google.gson.JsonParseException;
import com.google.gson.TypeAdapterFactory;
import com.google.gson.reflect.TypeToken;
import com.google.gson.TypeAdapter;
import com.google.gson.stream.JsonReader;
import com.google.gson.stream.JsonWriter;
import java.io.IOException;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set;
import com.zuora.JSON;
/**
* CreateBatchQueryJobResponse
*/
@javax.annotation.Generated(value = "org.openapitools.codegen.languages.JavaClientCodegen", comments = "Generator version: 7.6.0")
public class CreateBatchQueryJobResponse {
public static final String SERIALIZED_NAME_BATCHES = "batches";
@SerializedName(SERIALIZED_NAME_BATCHES)
private List batches;
public static final String SERIALIZED_NAME_ERROR_CODE = "errorCode";
@SerializedName(SERIALIZED_NAME_ERROR_CODE)
private String errorCode;
public static final String SERIALIZED_NAME_MESSAGE = "message";
@SerializedName(SERIALIZED_NAME_MESSAGE)
private String message;
public static final String SERIALIZED_NAME_ENCRYPTED = "encrypted";
@SerializedName(SERIALIZED_NAME_ENCRYPTED)
private BatchQueryEncrypted encrypted;
public static final String SERIALIZED_NAME_FORMAT = "format";
@SerializedName(SERIALIZED_NAME_FORMAT)
private BatchQueryFormat format;
public static final String SERIALIZED_NAME_ID = "id";
@SerializedName(SERIALIZED_NAME_ID)
private String id;
public static final String SERIALIZED_NAME_NAME = "name";
@SerializedName(SERIALIZED_NAME_NAME)
private String name;
public static final String SERIALIZED_NAME_NOTIFY_URL = "notifyUrl";
@SerializedName(SERIALIZED_NAME_NOTIFY_URL)
private String notifyUrl;
public static final String SERIALIZED_NAME_OFFSET = "offset";
@SerializedName(SERIALIZED_NAME_OFFSET)
private BigDecimal offset;
public static final String SERIALIZED_NAME_PARTNER = "partner";
@SerializedName(SERIALIZED_NAME_PARTNER)
private String partner;
public static final String SERIALIZED_NAME_PROJECT = "project";
@SerializedName(SERIALIZED_NAME_PROJECT)
private String project;
public static final String SERIALIZED_NAME_STATUS = "status";
@SerializedName(SERIALIZED_NAME_STATUS)
private BatchQueryStatus status;
public static final String SERIALIZED_NAME_LOCALIZED_STATUS = "localizedStatus";
@SerializedName(SERIALIZED_NAME_LOCALIZED_STATUS)
private BatchQueryStatus localizedStatus;
public static final String SERIALIZED_NAME_USE_LAST_COMPLETED_JOB_QUERIES = "useLastCompletedJobQueries";
@SerializedName(SERIALIZED_NAME_USE_LAST_COMPLETED_JOB_QUERIES)
private Boolean useLastCompletedJobQueries;
public static final String SERIALIZED_NAME_VERSION = "version";
@SerializedName(SERIALIZED_NAME_VERSION)
private Float version;
public CreateBatchQueryJobResponse() {
}
public CreateBatchQueryJobResponse batches(List batches) {
this.batches = batches;
return this;
}
public CreateBatchQueryJobResponse addBatchesItem(CreateBatchQueryResponse batchesItem) {
if (this.batches == null) {
this.batches = new ArrayList<>();
}
this.batches.add(batchesItem);
return this;
}
/**
* A JSON array object that contains a list of batch objects.
* @return batches
*/
@javax.annotation.Nullable
public List getBatches() {
return batches;
}
public void setBatches(List batches) {
this.batches = batches;
}
public CreateBatchQueryJobResponse errorCode(String errorCode) {
this.errorCode = errorCode;
return this;
}
/**
* The error code used to identify the failure reason.
* @return errorCode
*/
@javax.annotation.Nullable
public String getErrorCode() {
return errorCode;
}
public void setErrorCode(String errorCode) {
this.errorCode = errorCode;
}
public CreateBatchQueryJobResponse message(String message) {
this.message = message;
return this;
}
/**
* The error message used to describe the failure reason detail.
* @return message
*/
@javax.annotation.Nullable
public String getMessage() {
return message;
}
public void setMessage(String message) {
this.message = message;
}
public CreateBatchQueryJobResponse encrypted(BatchQueryEncrypted encrypted) {
this.encrypted = encrypted;
return this;
}
/**
* Get encrypted
* @return encrypted
*/
@javax.annotation.Nullable
public BatchQueryEncrypted getEncrypted() {
return encrypted;
}
public void setEncrypted(BatchQueryEncrypted encrypted) {
this.encrypted = encrypted;
}
public CreateBatchQueryJobResponse format(BatchQueryFormat format) {
this.format = format;
return this;
}
/**
* Get format
* @return format
*/
@javax.annotation.Nullable
public BatchQueryFormat getFormat() {
return format;
}
public void setFormat(BatchQueryFormat format) {
this.format = format;
}
public CreateBatchQueryJobResponse id(String id) {
this.id = id;
return this;
}
/**
* The job ID created for the AQuA API request. The job ID can be used for querying for the query status. The ID exists only if the JSON request can be parsed and validated successfully. Otherwise, the job ID is null.
* @return id
*/
@javax.annotation.Nullable
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public CreateBatchQueryJobResponse name(String name) {
this.name = name;
return this;
}
/**
* The name of the job. 32 character limit.
* @return name
*/
@javax.annotation.Nullable
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public CreateBatchQueryJobResponse notifyUrl(String notifyUrl) {
this.notifyUrl = notifyUrl;
return this;
}
/**
* If URL is provided, the AQuA job will call this `notifyUrl` once the job has completed. The value of `notifyUrl` needs to have `${JOBID}` and `${STATUS}` placeholders. These placeholders will be replaced by the actual job ID and status when returned in the response. Status will be `Completed` after the AQuA job is done. If you submit an AQuA query with `notifyUrl` specified, the value of `notifyUrl` will be ignored if your organization has already <a href=\"https://knowledgecenter.zuora.com/Zuora_Central_Platform/API/AB_Aggregate_Query_API/Callout_Notification_for_Completed_AQuA_Jobs\" target=\"_blank\">configured a callout notification through the Zuora user interface</a>.
* @return notifyUrl
*/
@javax.annotation.Nullable
public String getNotifyUrl() {
return notifyUrl;
}
public void setNotifyUrl(String notifyUrl) {
this.notifyUrl = notifyUrl;
}
public CreateBatchQueryJobResponse offset(BigDecimal offset) {
this.offset = offset;
return this;
}
/**
* This field specifies the time offset for AQuA queries in stateful mode. It is an integer in the range 0 to 3,600 seconds. For example, if you set this field to 600 seconds and you post a query in stateful mode at 2:00 AM, it will query against data created or updated between the completion time of the previous query and 1:50 AM. The value of this field will override the value you configured in **Settings** > **Administration** > **AQuA API Stateful Mode Time Offset**.
* @return offset
*/
@javax.annotation.Nullable
public BigDecimal getOffset() {
return offset;
}
public void setOffset(BigDecimal offset) {
this.offset = offset;
}
public CreateBatchQueryJobResponse partner(String partner) {
this.partner = partner;
return this;
}
/**
* The partner field indicates the unique ID of a data integration partner. The dropdown list of this field displays partner IDs for the past thirty days. It must be used together with \"project\" field to uniquely identify a data integration target. For example, if a continuous AQuA session is to retrieve data incrementally for a Salesforce.com Org 00170000011K3Ub, you can use partner as \"Salesforce\", and \"project\" as \"00170000011K3Ub.\" This field is required only if you are using AQuA in stateful mode. Otherwise, if you are using AQuA in stateless mode, partner field can be null. **Note**: Zuora highly recommends you use the stateless mode instead of the stateful mode to extract bulk data. See <a href=\"https://knowledgecenter.zuora.com/Zuora_Central_Platform/API/AB_Aggregate_Query_API/Bulk_data__extraction_from_Zuora_using_AQuA\" target=\"_blank\">Bulk data extraction from Zuora using AQuA</a> for best practices. **Note**: Submit a request at <a href=\"http://support.zuora.com\" target=\"_blank\">Zuora Global Support</a> to obtain a partner ID.
* @return partner
*/
@javax.annotation.Nullable
public String getPartner() {
return partner;
}
public void setPartner(String partner) {
this.partner = partner;
}
public CreateBatchQueryJobResponse project(String project) {
this.project = project;
return this;
}
/**
* The project field contains the unique ID of a data integration project for a particular partner. The dropdown list of this field displays project IDs for the past thirty days. This field must be used together with partner field to uniquely identify a data integration target. This field is required only if you are using AQuA in stateful mode. Otherwise, if you are using AQuA in stateless mode, partner field can be null.
* @return project
*/
@javax.annotation.Nullable
public String getProject() {
return project;
}
public void setProject(String project) {
this.project = project;
}
public CreateBatchQueryJobResponse status(BatchQueryStatus status) {
this.status = status;
return this;
}
/**
* Get status
* @return status
*/
@javax.annotation.Nullable
public BatchQueryStatus getStatus() {
return status;
}
public void setStatus(BatchQueryStatus status) {
this.status = status;
}
public CreateBatchQueryJobResponse localizedStatus(BatchQueryStatus localizedStatus) {
this.localizedStatus = localizedStatus;
return this;
}
/**
* Get localizedStatus
* @return localizedStatus
*/
@javax.annotation.Nullable
public BatchQueryStatus getLocalizedStatus() {
return localizedStatus;
}
public void setLocalizedStatus(BatchQueryStatus localizedStatus) {
this.localizedStatus = localizedStatus;
}
public CreateBatchQueryJobResponse useLastCompletedJobQueries(Boolean useLastCompletedJobQueries) {
this.useLastCompletedJobQueries = useLastCompletedJobQueries;
return this;
}
/**
* If this flag is set to `true`, then all the previous queries are merged with existing queries. If the flag is set to `false`, then the previous queries are ignored, and only the new query is executed.
* @return useLastCompletedJobQueries
*/
@javax.annotation.Nullable
public Boolean getUseLastCompletedJobQueries() {
return useLastCompletedJobQueries;
}
public void setUseLastCompletedJobQueries(Boolean useLastCompletedJobQueries) {
this.useLastCompletedJobQueries = useLastCompletedJobQueries;
}
public CreateBatchQueryJobResponse version(Float version) {
this.version = version;
return this;
}
/**
* The API version you want to use. The supported versions are as follows: - `1.1`. It supports both modes - `1.0`. Default. It supports stateless modes only. See <a href=\"https://knowledgecenter.zuora.com/Zuora_Central_Platform/API/AB_Aggregate_Query_API/BA_Stateless_and_Stateful_Modes\" target=\"_blank\">Stateless and stateful modes</a> for more information.
* @return version
*/
@javax.annotation.Nullable
public Float getVersion() {
return version;
}
public void setVersion(Float version) {
this.version = version;
}
/**
* A container for additional, undeclared properties.
* This is a holder for any undeclared properties as specified with
* the 'additionalProperties' keyword in the OAS document.
*/
private Map additionalProperties;
/**
* Set the additional (undeclared) property with the specified name and value.
* If the property does not already exist, create it otherwise replace it.
*
* @param key name of the property
* @param value value of the property
* @return the CreateBatchQueryJobResponse instance itself
*/
public CreateBatchQueryJobResponse putAdditionalProperty(String key, Object value) {
if (this.additionalProperties == null) {
this.additionalProperties = new HashMap();
}
this.additionalProperties.put(key, value);
return this;
}
/**
* Return the additional (undeclared) property.
*
* @return a map of objects
*/
public Map getAdditionalProperties() {
return additionalProperties;
}
/**
* Return the additional (undeclared) property with the specified name.
*
* @param key name of the property
* @return an object
*/
public Object getAdditionalProperty(String key) {
if (this.additionalProperties == null) {
return null;
}
return this.additionalProperties.get(key);
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
CreateBatchQueryJobResponse createBatchQueryJobResponse = (CreateBatchQueryJobResponse) o;
return Objects.equals(this.batches, createBatchQueryJobResponse.batches) &&
Objects.equals(this.errorCode, createBatchQueryJobResponse.errorCode) &&
Objects.equals(this.message, createBatchQueryJobResponse.message) &&
Objects.equals(this.encrypted, createBatchQueryJobResponse.encrypted) &&
Objects.equals(this.format, createBatchQueryJobResponse.format) &&
Objects.equals(this.id, createBatchQueryJobResponse.id) &&
Objects.equals(this.name, createBatchQueryJobResponse.name) &&
Objects.equals(this.notifyUrl, createBatchQueryJobResponse.notifyUrl) &&
Objects.equals(this.offset, createBatchQueryJobResponse.offset) &&
Objects.equals(this.partner, createBatchQueryJobResponse.partner) &&
Objects.equals(this.project, createBatchQueryJobResponse.project) &&
Objects.equals(this.status, createBatchQueryJobResponse.status) &&
Objects.equals(this.localizedStatus, createBatchQueryJobResponse.localizedStatus) &&
Objects.equals(this.useLastCompletedJobQueries, createBatchQueryJobResponse.useLastCompletedJobQueries) &&
Objects.equals(this.version, createBatchQueryJobResponse.version)&&
Objects.equals(this.additionalProperties, createBatchQueryJobResponse.additionalProperties);
}
@Override
public int hashCode() {
return Objects.hash(batches, errorCode, message, encrypted, format, id, name, notifyUrl, offset, partner, project, status, localizedStatus, useLastCompletedJobQueries, version, additionalProperties);
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("class CreateBatchQueryJobResponse {\n");
sb.append(" batches: ").append(toIndentedString(batches)).append("\n");
sb.append(" errorCode: ").append(toIndentedString(errorCode)).append("\n");
sb.append(" message: ").append(toIndentedString(message)).append("\n");
sb.append(" encrypted: ").append(toIndentedString(encrypted)).append("\n");
sb.append(" format: ").append(toIndentedString(format)).append("\n");
sb.append(" id: ").append(toIndentedString(id)).append("\n");
sb.append(" name: ").append(toIndentedString(name)).append("\n");
sb.append(" notifyUrl: ").append(toIndentedString(notifyUrl)).append("\n");
sb.append(" offset: ").append(toIndentedString(offset)).append("\n");
sb.append(" partner: ").append(toIndentedString(partner)).append("\n");
sb.append(" project: ").append(toIndentedString(project)).append("\n");
sb.append(" status: ").append(toIndentedString(status)).append("\n");
sb.append(" localizedStatus: ").append(toIndentedString(localizedStatus)).append("\n");
sb.append(" useLastCompletedJobQueries: ").append(toIndentedString(useLastCompletedJobQueries)).append("\n");
sb.append(" version: ").append(toIndentedString(version)).append("\n");
sb.append(" additionalProperties: ").append(toIndentedString(additionalProperties)).append("\n");
sb.append("}");
return sb.toString();
}
/**
* Convert the given object to string with each line indented by 4 spaces
* (except the first line).
*/
private String toIndentedString(Object o) {
if (o == null) {
return "null";
}
return o.toString().replace("\n", "\n ");
}
public static HashSet openapiFields;
public static HashSet openapiRequiredFields;
static {
// a set of all properties/fields (JSON key names)
openapiFields = new HashSet();
openapiFields.add("batches");
openapiFields.add("errorCode");
openapiFields.add("message");
openapiFields.add("encrypted");
openapiFields.add("format");
openapiFields.add("id");
openapiFields.add("name");
openapiFields.add("notifyUrl");
openapiFields.add("offset");
openapiFields.add("partner");
openapiFields.add("project");
openapiFields.add("status");
openapiFields.add("localizedStatus");
openapiFields.add("useLastCompletedJobQueries");
openapiFields.add("version");
// a set of required properties/fields (JSON key names)
openapiRequiredFields = new HashSet();
}
/**
* Validates the JSON Element and throws an exception if issues found
*
* @param jsonElement JSON Element
* @throws IOException if the JSON Element is invalid with respect to CreateBatchQueryJobResponse
*/
public static void validateJsonElement(JsonElement jsonElement) throws IOException {
if (jsonElement == null) {
if (!CreateBatchQueryJobResponse.openapiRequiredFields.isEmpty()) { // has required fields but JSON element is null
throw new IllegalArgumentException(String.format("The required field(s) %s in CreateBatchQueryJobResponse is not found in the empty JSON string", CreateBatchQueryJobResponse.openapiRequiredFields.toString()));
}
}
JsonObject jsonObj = jsonElement.getAsJsonObject();
if (jsonObj.get("batches") != null && !jsonObj.get("batches").isJsonNull()) {
JsonArray jsonArraybatches = jsonObj.getAsJsonArray("batches");
if (jsonArraybatches != null) {
// ensure the json data is an array
if (!jsonObj.get("batches").isJsonArray()) {
throw new IllegalArgumentException(String.format("Expected the field `batches` to be an array in the JSON string but got `%s`", jsonObj.get("batches").toString()));
}
// validate the optional field `batches` (array)
for (int i = 0; i < jsonArraybatches.size(); i++) {
CreateBatchQueryResponse.validateJsonElement(jsonArraybatches.get(i));
};
}
}
if ((jsonObj.get("errorCode") != null && !jsonObj.get("errorCode").isJsonNull()) && !jsonObj.get("errorCode").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `errorCode` to be a primitive type in the JSON string but got `%s`", jsonObj.get("errorCode").toString()));
}
if ((jsonObj.get("message") != null && !jsonObj.get("message").isJsonNull()) && !jsonObj.get("message").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `message` to be a primitive type in the JSON string but got `%s`", jsonObj.get("message").toString()));
}
if ((jsonObj.get("encrypted") != null && !jsonObj.get("encrypted").isJsonNull()) && !jsonObj.get("encrypted").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `encrypted` to be a primitive type in the JSON string but got `%s`", jsonObj.get("encrypted").toString()));
}
// validate the optional field `encrypted`
if (jsonObj.get("encrypted") != null && !jsonObj.get("encrypted").isJsonNull()) {
BatchQueryEncrypted.validateJsonElement(jsonObj.get("encrypted"));
}
if ((jsonObj.get("format") != null && !jsonObj.get("format").isJsonNull()) && !jsonObj.get("format").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `format` to be a primitive type in the JSON string but got `%s`", jsonObj.get("format").toString()));
}
// validate the optional field `format`
if (jsonObj.get("format") != null && !jsonObj.get("format").isJsonNull()) {
BatchQueryFormat.validateJsonElement(jsonObj.get("format"));
}
if ((jsonObj.get("id") != null && !jsonObj.get("id").isJsonNull()) && !jsonObj.get("id").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `id` to be a primitive type in the JSON string but got `%s`", jsonObj.get("id").toString()));
}
if ((jsonObj.get("name") != null && !jsonObj.get("name").isJsonNull()) && !jsonObj.get("name").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `name` to be a primitive type in the JSON string but got `%s`", jsonObj.get("name").toString()));
}
if ((jsonObj.get("notifyUrl") != null && !jsonObj.get("notifyUrl").isJsonNull()) && !jsonObj.get("notifyUrl").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `notifyUrl` to be a primitive type in the JSON string but got `%s`", jsonObj.get("notifyUrl").toString()));
}
if ((jsonObj.get("partner") != null && !jsonObj.get("partner").isJsonNull()) && !jsonObj.get("partner").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `partner` to be a primitive type in the JSON string but got `%s`", jsonObj.get("partner").toString()));
}
if ((jsonObj.get("project") != null && !jsonObj.get("project").isJsonNull()) && !jsonObj.get("project").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `project` to be a primitive type in the JSON string but got `%s`", jsonObj.get("project").toString()));
}
if ((jsonObj.get("status") != null && !jsonObj.get("status").isJsonNull()) && !jsonObj.get("status").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `status` to be a primitive type in the JSON string but got `%s`", jsonObj.get("status").toString()));
}
// validate the optional field `status`
if (jsonObj.get("status") != null && !jsonObj.get("status").isJsonNull()) {
BatchQueryStatus.validateJsonElement(jsonObj.get("status"));
}
if ((jsonObj.get("localizedStatus") != null && !jsonObj.get("localizedStatus").isJsonNull()) && !jsonObj.get("localizedStatus").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `localizedStatus` to be a primitive type in the JSON string but got `%s`", jsonObj.get("localizedStatus").toString()));
}
// validate the optional field `localizedStatus`
if (jsonObj.get("localizedStatus") != null && !jsonObj.get("localizedStatus").isJsonNull()) {
BatchQueryStatus.validateJsonElement(jsonObj.get("localizedStatus"));
}
}
public static class CustomTypeAdapterFactory implements TypeAdapterFactory {
@SuppressWarnings("unchecked")
@Override
public TypeAdapter create(Gson gson, TypeToken type) {
if (!CreateBatchQueryJobResponse.class.isAssignableFrom(type.getRawType())) {
return null; // this class only serializes 'CreateBatchQueryJobResponse' and its subtypes
}
final TypeAdapter elementAdapter = gson.getAdapter(JsonElement.class);
final TypeAdapter thisAdapter
= gson.getDelegateAdapter(this, TypeToken.get(CreateBatchQueryJobResponse.class));
return (TypeAdapter) new TypeAdapter() {
@Override
public void write(JsonWriter out, CreateBatchQueryJobResponse value) throws IOException {
JsonObject obj = thisAdapter.toJsonTree(value).getAsJsonObject();
obj.remove("additionalProperties");
// support null values
out.beginObject();
Iterator iterator = obj.entrySet().iterator();
while(iterator.hasNext()) {
Map.Entry e = (Map.Entry) iterator.next();
out.name((String)e.getKey());
elementAdapter.write(out, e.getValue());
}
// end
// serialize additional properties
if (value.getAdditionalProperties() != null) {
// support null values
boolean oldSerializeNulls = out.getSerializeNulls();
out.setSerializeNulls(true); //force serialize
// end
for (Map.Entry entry : value.getAdditionalProperties().entrySet()) {
if (entry.getValue() instanceof String)
obj.addProperty(entry.getKey(), (String) entry.getValue());
else if (entry.getValue() instanceof Number)
obj.addProperty(entry.getKey(), (Number) entry.getValue());
else if (entry.getValue() instanceof Boolean)
obj.addProperty(entry.getKey(), (Boolean) entry.getValue());
else if (entry.getValue() instanceof Character)
obj.addProperty(entry.getKey(), (Character) entry.getValue());
else if (entry.getValue() == null)
obj.add(entry.getKey(), null);
else {
JsonElement jsonElement = gson.toJsonTree(entry.getValue());
if (jsonElement.isJsonArray()) {
obj.add(entry.getKey(), jsonElement.getAsJsonArray());
} else {
obj.add(entry.getKey(), jsonElement.getAsJsonObject());
}
}
out.name((String)entry.getKey());
elementAdapter.write(out, obj.get(entry.getKey()));
}
out.setSerializeNulls(oldSerializeNulls); //restore
}
out.endObject();
}
@Override
public CreateBatchQueryJobResponse read(JsonReader in) throws IOException {
JsonElement jsonElement = elementAdapter.read(in);
validateJsonElement(jsonElement);
JsonObject jsonObj = jsonElement.getAsJsonObject();
// store additional fields in the deserialized instance
CreateBatchQueryJobResponse instance = thisAdapter.fromJsonTree(jsonObj);
for (Map.Entry entry : jsonObj.entrySet()) {
if (!openapiFields.contains(entry.getKey())) {
if (entry.getValue().isJsonPrimitive()) { // primitive type
if (entry.getValue().getAsJsonPrimitive().isString())
instance.putAdditionalProperty(entry.getKey(), entry.getValue().getAsString());
else if (entry.getValue().getAsJsonPrimitive().isNumber())
instance.putAdditionalProperty(entry.getKey(), entry.getValue().getAsNumber());
else if (entry.getValue().getAsJsonPrimitive().isBoolean())
instance.putAdditionalProperty(entry.getKey(), entry.getValue().getAsBoolean());
else
throw new IllegalArgumentException(String.format("The field `%s` has unknown primitive type. Value: %s", entry.getKey(), entry.getValue().toString()));
} else if (entry.getValue().isJsonArray()) {
instance.putAdditionalProperty(entry.getKey(), gson.fromJson(entry.getValue(), List.class));
} else { // JSON object
instance.putAdditionalProperty(entry.getKey(), gson.fromJson(entry.getValue(), HashMap.class));
}
}
}
return instance;
}
}.nullSafe();
}
}
/**
* Create an instance of CreateBatchQueryJobResponse given an JSON string
*
* @param jsonString JSON string
* @return An instance of CreateBatchQueryJobResponse
* @throws IOException if the JSON string is invalid with respect to CreateBatchQueryJobResponse
*/
public static CreateBatchQueryJobResponse fromJson(String jsonString) throws IOException {
return JSON.getGson().fromJson(jsonString, CreateBatchQueryJobResponse.class);
}
/**
* Convert an instance of CreateBatchQueryJobResponse to an JSON string
*
* @return JSON string
*/
public String toJson() {
return JSON.getGson().toJson(this);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy