com.zuora.model.OrderActionUpdateProduct 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.ChargeUpdate;
import com.zuora.model.RatePlanFeatureOverride;
import java.io.IOException;
import java.time.LocalDate;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
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;
/**
* A rate plan can be updated in a subscription through one order action; otherwise, an error occurs. - For a rate plan, the following fields are available: - `chargeUpdates` - `clearingExistingFeatures` - `customFields` - `externallyManagedPlanId` - `newRatePlanId` - `ratePlanId` - `specificUpdateDate` - `subscriptionProductFeatures` - `uniqueToken`
*/
@javax.annotation.Generated(value = "org.openapitools.codegen.languages.JavaClientCodegen", comments = "Generator version: 7.6.0")
public class OrderActionUpdateProduct {
public static final String SERIALIZED_NAME_CHARGE_UPDATES = "chargeUpdates";
@SerializedName(SERIALIZED_NAME_CHARGE_UPDATES)
private List chargeUpdates;
public static final String SERIALIZED_NAME_CLEARING_EXISTING_FEATURES = "clearingExistingFeatures";
@SerializedName(SERIALIZED_NAME_CLEARING_EXISTING_FEATURES)
private Boolean clearingExistingFeatures;
public static final String SERIALIZED_NAME_CUSTOM_FIELDS = "customFields";
@SerializedName(SERIALIZED_NAME_CUSTOM_FIELDS)
private Map customFields;
public static final String SERIALIZED_NAME_EXTERNALLY_MANAGED_PLAN_ID = "externallyManagedPlanId";
@SerializedName(SERIALIZED_NAME_EXTERNALLY_MANAGED_PLAN_ID)
private String externallyManagedPlanId;
public static final String SERIALIZED_NAME_NEW_RATE_PLAN_ID = "newRatePlanId";
@SerializedName(SERIALIZED_NAME_NEW_RATE_PLAN_ID)
private String newRatePlanId;
public static final String SERIALIZED_NAME_PRODUCT_RATE_PLAN_NUMBER = "productRatePlanNumber";
@SerializedName(SERIALIZED_NAME_PRODUCT_RATE_PLAN_NUMBER)
private String productRatePlanNumber;
public static final String SERIALIZED_NAME_PRODUCT_RATE_PLAN_ID = "productRatePlanId";
@SerializedName(SERIALIZED_NAME_PRODUCT_RATE_PLAN_ID)
private String productRatePlanId;
public static final String SERIALIZED_NAME_RATE_PLAN_ID = "ratePlanId";
@SerializedName(SERIALIZED_NAME_RATE_PLAN_ID)
private String ratePlanId;
public static final String SERIALIZED_NAME_SPECIFIC_UPDATE_DATE = "specificUpdateDate";
@SerializedName(SERIALIZED_NAME_SPECIFIC_UPDATE_DATE)
private LocalDate specificUpdateDate;
public static final String SERIALIZED_NAME_SUBSCRIPTION_PRODUCT_FEATURES = "subscriptionProductFeatures";
@SerializedName(SERIALIZED_NAME_SUBSCRIPTION_PRODUCT_FEATURES)
private List subscriptionProductFeatures;
public static final String SERIALIZED_NAME_SUBSCRIPTION_RATE_PLAN_NUMBER = "subscriptionRatePlanNumber";
@SerializedName(SERIALIZED_NAME_SUBSCRIPTION_RATE_PLAN_NUMBER)
private String subscriptionRatePlanNumber;
public static final String SERIALIZED_NAME_UNIQUE_TOKEN = "uniqueToken";
@SerializedName(SERIALIZED_NAME_UNIQUE_TOKEN)
private String uniqueToken;
public OrderActionUpdateProduct() {
}
public OrderActionUpdateProduct chargeUpdates(List chargeUpdates) {
this.chargeUpdates = chargeUpdates;
return this;
}
public OrderActionUpdateProduct addChargeUpdatesItem(ChargeUpdate chargeUpdatesItem) {
if (this.chargeUpdates == null) {
this.chargeUpdates = new ArrayList<>();
}
this.chargeUpdates.add(chargeUpdatesItem);
return this;
}
/**
* Array of the JSON objects containing the information for a charge update in the `updateProduct` type of order action.
* @return chargeUpdates
*/
@javax.annotation.Nullable
public List getChargeUpdates() {
return chargeUpdates;
}
public void setChargeUpdates(List chargeUpdates) {
this.chargeUpdates = chargeUpdates;
}
public OrderActionUpdateProduct clearingExistingFeatures(Boolean clearingExistingFeatures) {
this.clearingExistingFeatures = clearingExistingFeatures;
return this;
}
/**
* Specifies whether all features in the rate plan will be cleared.
* @return clearingExistingFeatures
*/
@javax.annotation.Nullable
public Boolean getClearingExistingFeatures() {
return clearingExistingFeatures;
}
public void setClearingExistingFeatures(Boolean clearingExistingFeatures) {
this.clearingExistingFeatures = clearingExistingFeatures;
}
public OrderActionUpdateProduct customFields(Map customFields) {
this.customFields = customFields;
return this;
}
public OrderActionUpdateProduct putCustomFieldsItem(String key, Object customFieldsItem) {
if (this.customFields == null) {
this.customFields = new HashMap<>();
}
this.customFields.put(key, customFieldsItem);
return this;
}
/**
* Container for custom fields of the Rate Plan object. The custom fields of the Rate Plan object are used when rate plans are subscribed.
* @return customFields
*/
@javax.annotation.Nullable
public Map getCustomFields() {
return customFields;
}
public void setCustomFields(Map customFields) {
this.customFields = customFields;
}
public OrderActionUpdateProduct externallyManagedPlanId(String externallyManagedPlanId) {
this.externallyManagedPlanId = externallyManagedPlanId;
return this;
}
/**
* Indicates the unique identifier for the rate plan purchased on a third-party store. This field is used to represent a subscription rate plan created through third-party stores.
* @return externallyManagedPlanId
*/
@javax.annotation.Nullable
public String getExternallyManagedPlanId() {
return externallyManagedPlanId;
}
public void setExternallyManagedPlanId(String externallyManagedPlanId) {
this.externallyManagedPlanId = externallyManagedPlanId;
}
public OrderActionUpdateProduct newRatePlanId(String newRatePlanId) {
this.newRatePlanId = newRatePlanId;
return this;
}
/**
* Internal identifier of the updated rate plan in the new subscription version.
* @return newRatePlanId
*/
@javax.annotation.Nullable
public String getNewRatePlanId() {
return newRatePlanId;
}
public void setNewRatePlanId(String newRatePlanId) {
this.newRatePlanId = newRatePlanId;
}
public OrderActionUpdateProduct productRatePlanNumber(String productRatePlanNumber) {
this.productRatePlanNumber = productRatePlanNumber;
return this;
}
/**
* Number of a product rate plan for this subscription.
* @return productRatePlanNumber
*/
@javax.annotation.Nullable
public String getProductRatePlanNumber() {
return productRatePlanNumber;
}
public void setProductRatePlanNumber(String productRatePlanNumber) {
this.productRatePlanNumber = productRatePlanNumber;
}
public OrderActionUpdateProduct productRatePlanId(String productRatePlanId) {
this.productRatePlanId = productRatePlanId;
return this;
}
/**
* ID of a product rate plan for this subscription.
* @return productRatePlanId
*/
@javax.annotation.Nullable
public String getProductRatePlanId() {
return productRatePlanId;
}
public void setProductRatePlanId(String productRatePlanId) {
this.productRatePlanId = productRatePlanId;
}
public OrderActionUpdateProduct ratePlanId(String ratePlanId) {
this.ratePlanId = ratePlanId;
return this;
}
/**
* Internal identifier of the rate plan that was updated. It can be the latest version or any history version id.
* @return ratePlanId
*/
@javax.annotation.Nullable
public String getRatePlanId() {
return ratePlanId;
}
public void setRatePlanId(String ratePlanId) {
this.ratePlanId = ratePlanId;
}
public OrderActionUpdateProduct specificUpdateDate(LocalDate specificUpdateDate) {
this.specificUpdateDate = specificUpdateDate;
return this;
}
/**
* The date when the Update Product order action takes effect. This field is only applicable if there is already a future-dated Update Product order action on the subscription. The format of the date is yyyy-mm-dd. See [Update a Product on Subscription with Future-dated Updates](https://knowledgecenter.zuora.com/BC_Subscription_Management/Orders/AC_Orders_Tutorials/C_Update_a_Product_in_a_Subscription/Update_a_Product_on_Subscription_with_Future-dated_Updates) for more information about this feature.
* @return specificUpdateDate
*/
@javax.annotation.Nullable
public LocalDate getSpecificUpdateDate() {
return specificUpdateDate;
}
public void setSpecificUpdateDate(LocalDate specificUpdateDate) {
this.specificUpdateDate = specificUpdateDate;
}
public OrderActionUpdateProduct subscriptionProductFeatures(List subscriptionProductFeatures) {
this.subscriptionProductFeatures = subscriptionProductFeatures;
return this;
}
public OrderActionUpdateProduct addSubscriptionProductFeaturesItem(RatePlanFeatureOverride subscriptionProductFeaturesItem) {
if (this.subscriptionProductFeatures == null) {
this.subscriptionProductFeatures = new ArrayList<>();
}
this.subscriptionProductFeatures.add(subscriptionProductFeaturesItem);
return this;
}
/**
* List of features associated with the rate plan. The system compares the `subscriptionProductFeatures` and `featureId` fields in the request with the counterpart fields in a rate plan. The comparison results are as follows: * If there is no `subscriptionProductFeatures` field or the field is empty, features in the rate plan remain unchanged. But if the `clearingExistingFeatures` field is additionally set to true, all features in the rate plan are cleared. * If the `subscriptionProductFeatures` field contains the `featureId` nested fields, as well as the optional `description` and `customFields` nested fields, the features indicated by the featureId nested fields in the request overwrite all features in the rate plan.
* @return subscriptionProductFeatures
*/
@javax.annotation.Nullable
public List getSubscriptionProductFeatures() {
return subscriptionProductFeatures;
}
public void setSubscriptionProductFeatures(List subscriptionProductFeatures) {
this.subscriptionProductFeatures = subscriptionProductFeatures;
}
public OrderActionUpdateProduct subscriptionRatePlanNumber(String subscriptionRatePlanNumber) {
this.subscriptionRatePlanNumber = subscriptionRatePlanNumber;
return this;
}
/**
* Number of a rate plan for this subscription.
* @return subscriptionRatePlanNumber
*/
@javax.annotation.Nullable
public String getSubscriptionRatePlanNumber() {
return subscriptionRatePlanNumber;
}
public void setSubscriptionRatePlanNumber(String subscriptionRatePlanNumber) {
this.subscriptionRatePlanNumber = subscriptionRatePlanNumber;
}
public OrderActionUpdateProduct uniqueToken(String uniqueToken) {
this.uniqueToken = uniqueToken;
return this;
}
/**
* A unique string to represent the rate plan in the order. The unique token is used to perform multiple actions against a newly added rate plan. For example, if you want to add and update a product in the same order, assign a unique token to the newly added rate plan and use that token in future order actions.
* @return uniqueToken
*/
@javax.annotation.Nullable
public String getUniqueToken() {
return uniqueToken;
}
public void setUniqueToken(String uniqueToken) {
this.uniqueToken = uniqueToken;
}
/**
* 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 OrderActionUpdateProduct instance itself
*/
public OrderActionUpdateProduct 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;
}
OrderActionUpdateProduct orderActionUpdateProduct = (OrderActionUpdateProduct) o;
return Objects.equals(this.chargeUpdates, orderActionUpdateProduct.chargeUpdates) &&
Objects.equals(this.clearingExistingFeatures, orderActionUpdateProduct.clearingExistingFeatures) &&
Objects.equals(this.customFields, orderActionUpdateProduct.customFields) &&
Objects.equals(this.externallyManagedPlanId, orderActionUpdateProduct.externallyManagedPlanId) &&
Objects.equals(this.newRatePlanId, orderActionUpdateProduct.newRatePlanId) &&
Objects.equals(this.productRatePlanNumber, orderActionUpdateProduct.productRatePlanNumber) &&
Objects.equals(this.productRatePlanId, orderActionUpdateProduct.productRatePlanId) &&
Objects.equals(this.ratePlanId, orderActionUpdateProduct.ratePlanId) &&
Objects.equals(this.specificUpdateDate, orderActionUpdateProduct.specificUpdateDate) &&
Objects.equals(this.subscriptionProductFeatures, orderActionUpdateProduct.subscriptionProductFeatures) &&
Objects.equals(this.subscriptionRatePlanNumber, orderActionUpdateProduct.subscriptionRatePlanNumber) &&
Objects.equals(this.uniqueToken, orderActionUpdateProduct.uniqueToken)&&
Objects.equals(this.additionalProperties, orderActionUpdateProduct.additionalProperties);
}
@Override
public int hashCode() {
return Objects.hash(chargeUpdates, clearingExistingFeatures, customFields, externallyManagedPlanId, newRatePlanId, productRatePlanNumber, productRatePlanId, ratePlanId, specificUpdateDate, subscriptionProductFeatures, subscriptionRatePlanNumber, uniqueToken, additionalProperties);
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("class OrderActionUpdateProduct {\n");
sb.append(" chargeUpdates: ").append(toIndentedString(chargeUpdates)).append("\n");
sb.append(" clearingExistingFeatures: ").append(toIndentedString(clearingExistingFeatures)).append("\n");
sb.append(" customFields: ").append(toIndentedString(customFields)).append("\n");
sb.append(" externallyManagedPlanId: ").append(toIndentedString(externallyManagedPlanId)).append("\n");
sb.append(" newRatePlanId: ").append(toIndentedString(newRatePlanId)).append("\n");
sb.append(" productRatePlanNumber: ").append(toIndentedString(productRatePlanNumber)).append("\n");
sb.append(" productRatePlanId: ").append(toIndentedString(productRatePlanId)).append("\n");
sb.append(" ratePlanId: ").append(toIndentedString(ratePlanId)).append("\n");
sb.append(" specificUpdateDate: ").append(toIndentedString(specificUpdateDate)).append("\n");
sb.append(" subscriptionProductFeatures: ").append(toIndentedString(subscriptionProductFeatures)).append("\n");
sb.append(" subscriptionRatePlanNumber: ").append(toIndentedString(subscriptionRatePlanNumber)).append("\n");
sb.append(" uniqueToken: ").append(toIndentedString(uniqueToken)).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("chargeUpdates");
openapiFields.add("clearingExistingFeatures");
openapiFields.add("customFields");
openapiFields.add("externallyManagedPlanId");
openapiFields.add("newRatePlanId");
openapiFields.add("productRatePlanNumber");
openapiFields.add("productRatePlanId");
openapiFields.add("ratePlanId");
openapiFields.add("specificUpdateDate");
openapiFields.add("subscriptionProductFeatures");
openapiFields.add("subscriptionRatePlanNumber");
openapiFields.add("uniqueToken");
// 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 OrderActionUpdateProduct
*/
public static void validateJsonElement(JsonElement jsonElement) throws IOException {
if (jsonElement == null) {
if (!OrderActionUpdateProduct.openapiRequiredFields.isEmpty()) { // has required fields but JSON element is null
throw new IllegalArgumentException(String.format("The required field(s) %s in OrderActionUpdateProduct is not found in the empty JSON string", OrderActionUpdateProduct.openapiRequiredFields.toString()));
}
}
JsonObject jsonObj = jsonElement.getAsJsonObject();
if (jsonObj.get("chargeUpdates") != null && !jsonObj.get("chargeUpdates").isJsonNull()) {
JsonArray jsonArraychargeUpdates = jsonObj.getAsJsonArray("chargeUpdates");
if (jsonArraychargeUpdates != null) {
// ensure the json data is an array
if (!jsonObj.get("chargeUpdates").isJsonArray()) {
throw new IllegalArgumentException(String.format("Expected the field `chargeUpdates` to be an array in the JSON string but got `%s`", jsonObj.get("chargeUpdates").toString()));
}
// validate the optional field `chargeUpdates` (array)
for (int i = 0; i < jsonArraychargeUpdates.size(); i++) {
ChargeUpdate.validateJsonElement(jsonArraychargeUpdates.get(i));
};
}
}
if ((jsonObj.get("externallyManagedPlanId") != null && !jsonObj.get("externallyManagedPlanId").isJsonNull()) && !jsonObj.get("externallyManagedPlanId").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `externallyManagedPlanId` to be a primitive type in the JSON string but got `%s`", jsonObj.get("externallyManagedPlanId").toString()));
}
if ((jsonObj.get("newRatePlanId") != null && !jsonObj.get("newRatePlanId").isJsonNull()) && !jsonObj.get("newRatePlanId").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `newRatePlanId` to be a primitive type in the JSON string but got `%s`", jsonObj.get("newRatePlanId").toString()));
}
if ((jsonObj.get("productRatePlanNumber") != null && !jsonObj.get("productRatePlanNumber").isJsonNull()) && !jsonObj.get("productRatePlanNumber").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `productRatePlanNumber` to be a primitive type in the JSON string but got `%s`", jsonObj.get("productRatePlanNumber").toString()));
}
if ((jsonObj.get("productRatePlanId") != null && !jsonObj.get("productRatePlanId").isJsonNull()) && !jsonObj.get("productRatePlanId").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `productRatePlanId` to be a primitive type in the JSON string but got `%s`", jsonObj.get("productRatePlanId").toString()));
}
if ((jsonObj.get("ratePlanId") != null && !jsonObj.get("ratePlanId").isJsonNull()) && !jsonObj.get("ratePlanId").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `ratePlanId` to be a primitive type in the JSON string but got `%s`", jsonObj.get("ratePlanId").toString()));
}
if (jsonObj.get("subscriptionProductFeatures") != null && !jsonObj.get("subscriptionProductFeatures").isJsonNull()) {
JsonArray jsonArraysubscriptionProductFeatures = jsonObj.getAsJsonArray("subscriptionProductFeatures");
if (jsonArraysubscriptionProductFeatures != null) {
// ensure the json data is an array
if (!jsonObj.get("subscriptionProductFeatures").isJsonArray()) {
throw new IllegalArgumentException(String.format("Expected the field `subscriptionProductFeatures` to be an array in the JSON string but got `%s`", jsonObj.get("subscriptionProductFeatures").toString()));
}
// validate the optional field `subscriptionProductFeatures` (array)
for (int i = 0; i < jsonArraysubscriptionProductFeatures.size(); i++) {
RatePlanFeatureOverride.validateJsonElement(jsonArraysubscriptionProductFeatures.get(i));
};
}
}
if ((jsonObj.get("subscriptionRatePlanNumber") != null && !jsonObj.get("subscriptionRatePlanNumber").isJsonNull()) && !jsonObj.get("subscriptionRatePlanNumber").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `subscriptionRatePlanNumber` to be a primitive type in the JSON string but got `%s`", jsonObj.get("subscriptionRatePlanNumber").toString()));
}
if ((jsonObj.get("uniqueToken") != null && !jsonObj.get("uniqueToken").isJsonNull()) && !jsonObj.get("uniqueToken").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `uniqueToken` to be a primitive type in the JSON string but got `%s`", jsonObj.get("uniqueToken").toString()));
}
}
public static class CustomTypeAdapterFactory implements TypeAdapterFactory {
@SuppressWarnings("unchecked")
@Override
public TypeAdapter create(Gson gson, TypeToken type) {
if (!OrderActionUpdateProduct.class.isAssignableFrom(type.getRawType())) {
return null; // this class only serializes 'OrderActionUpdateProduct' and its subtypes
}
final TypeAdapter elementAdapter = gson.getAdapter(JsonElement.class);
final TypeAdapter thisAdapter
= gson.getDelegateAdapter(this, TypeToken.get(OrderActionUpdateProduct.class));
return (TypeAdapter) new TypeAdapter() {
@Override
public void write(JsonWriter out, OrderActionUpdateProduct 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 OrderActionUpdateProduct read(JsonReader in) throws IOException {
JsonElement jsonElement = elementAdapter.read(in);
validateJsonElement(jsonElement);
JsonObject jsonObj = jsonElement.getAsJsonObject();
// store additional fields in the deserialized instance
OrderActionUpdateProduct 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 OrderActionUpdateProduct given an JSON string
*
* @param jsonString JSON string
* @return An instance of OrderActionUpdateProduct
* @throws IOException if the JSON string is invalid with respect to OrderActionUpdateProduct
*/
public static OrderActionUpdateProduct fromJson(String jsonString) throws IOException {
return JSON.getGson().fromJson(jsonString, OrderActionUpdateProduct.class);
}
/**
* Convert an instance of OrderActionUpdateProduct to an JSON string
*
* @return JSON string
*/
public String toJson() {
return JSON.getGson().toJson(this);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy