com.zuora.model.CreateOrderUpdateProduct 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.CreateOrderChargeUpdate;
import com.zuora.model.CreateOrderRatePlanFeatureOverride;
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. - For a rate plan, the following fields are available: - `chargeUpdates` - `clearingExistingFeatures` - `customFields` - `externalCatalogPlanId` - `ratePlanId` - `productRatePlanNumber` - `subscriptionRatePlanNumber` - `uniqueToken` - `specificUpdateDate` - `subscriptionProductFeatures` - `uniqueToken`
*/
@javax.annotation.Generated(value = "org.openapitools.codegen.languages.JavaClientCodegen", comments = "Generator version: 7.6.0")
public class CreateOrderUpdateProduct {
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_EXTERNAL_CATALOG_PLAN_ID = "externalCatalogPlanId";
@SerializedName(SERIALIZED_NAME_EXTERNAL_CATALOG_PLAN_ID)
private String externalCatalogPlanId;
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_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 static final String SERIALIZED_NAME_IS_ADDING_SUBSET_CHARGES = "isAddingSubsetCharges";
@SerializedName(SERIALIZED_NAME_IS_ADDING_SUBSET_CHARGES)
private Boolean isAddingSubsetCharges;
public CreateOrderUpdateProduct() {
}
public CreateOrderUpdateProduct chargeUpdates(List chargeUpdates) {
this.chargeUpdates = chargeUpdates;
return this;
}
public CreateOrderUpdateProduct addChargeUpdatesItem(CreateOrderChargeUpdate 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 CreateOrderUpdateProduct 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 CreateOrderUpdateProduct customFields(Map customFields) {
this.customFields = customFields;
return this;
}
public CreateOrderUpdateProduct 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 CreateOrderUpdateProduct externalCatalogPlanId(String externalCatalogPlanId) {
this.externalCatalogPlanId = externalCatalogPlanId;
return this;
}
/**
* An external ID of the rate plan to be updated. You can use this field to specify an existing rate plan in your subscription. The value of the `externalCatalogPlanId` field must match one of the values that are predefined in the `externallyManagedPlanIds` field on a product rate plan. However, if there are multiple rate plans with the same `productRatePlanId` value existing in the subscription, you must use the `ratePlanId` field to update the rate plan. The `externalCatalogPlanId` field cannot be used to distinguish multiple rate plans in this case. **Note:** If both `externalCatalogPlanId` and `ratePlanId` are provided. They must point to the same product rate plan. Otherwise, the request would fail.
* @return externalCatalogPlanId
*/
@javax.annotation.Nullable
public String getExternalCatalogPlanId() {
return externalCatalogPlanId;
}
public void setExternalCatalogPlanId(String externalCatalogPlanId) {
this.externalCatalogPlanId = externalCatalogPlanId;
}
public CreateOrderUpdateProduct 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 CreateOrderUpdateProduct ratePlanId(String ratePlanId) {
this.ratePlanId = ratePlanId;
return this;
}
/**
* The id of the rate plan to be 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 CreateOrderUpdateProduct 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 CreateOrderUpdateProduct subscriptionProductFeatures(List subscriptionProductFeatures) {
this.subscriptionProductFeatures = subscriptionProductFeatures;
return this;
}
public CreateOrderUpdateProduct addSubscriptionProductFeaturesItem(CreateOrderRatePlanFeatureOverride 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 CreateOrderUpdateProduct 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 CreateOrderUpdateProduct 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;
}
public CreateOrderUpdateProduct isAddingSubsetCharges(Boolean isAddingSubsetCharges) {
this.isAddingSubsetCharges = isAddingSubsetCharges;
return this;
}
/**
* Specifies whether to add subset charges to the subscription. **Note:** This field is available when the EnableAddingSubsetCharges permission is enabled.
* @return isAddingSubsetCharges
*/
@javax.annotation.Nullable
public Boolean getIsAddingSubsetCharges() {
return isAddingSubsetCharges;
}
public void setIsAddingSubsetCharges(Boolean isAddingSubsetCharges) {
this.isAddingSubsetCharges = isAddingSubsetCharges;
}
/**
* 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 CreateOrderUpdateProduct instance itself
*/
public CreateOrderUpdateProduct 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;
}
CreateOrderUpdateProduct createOrderUpdateProduct = (CreateOrderUpdateProduct) o;
return Objects.equals(this.chargeUpdates, createOrderUpdateProduct.chargeUpdates) &&
Objects.equals(this.clearingExistingFeatures, createOrderUpdateProduct.clearingExistingFeatures) &&
Objects.equals(this.customFields, createOrderUpdateProduct.customFields) &&
Objects.equals(this.externalCatalogPlanId, createOrderUpdateProduct.externalCatalogPlanId) &&
Objects.equals(this.productRatePlanNumber, createOrderUpdateProduct.productRatePlanNumber) &&
Objects.equals(this.ratePlanId, createOrderUpdateProduct.ratePlanId) &&
Objects.equals(this.specificUpdateDate, createOrderUpdateProduct.specificUpdateDate) &&
Objects.equals(this.subscriptionProductFeatures, createOrderUpdateProduct.subscriptionProductFeatures) &&
Objects.equals(this.subscriptionRatePlanNumber, createOrderUpdateProduct.subscriptionRatePlanNumber) &&
Objects.equals(this.uniqueToken, createOrderUpdateProduct.uniqueToken) &&
Objects.equals(this.isAddingSubsetCharges, createOrderUpdateProduct.isAddingSubsetCharges)&&
Objects.equals(this.additionalProperties, createOrderUpdateProduct.additionalProperties);
}
@Override
public int hashCode() {
return Objects.hash(chargeUpdates, clearingExistingFeatures, customFields, externalCatalogPlanId, productRatePlanNumber, ratePlanId, specificUpdateDate, subscriptionProductFeatures, subscriptionRatePlanNumber, uniqueToken, isAddingSubsetCharges, additionalProperties);
}
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("class CreateOrderUpdateProduct {\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(" externalCatalogPlanId: ").append(toIndentedString(externalCatalogPlanId)).append("\n");
sb.append(" productRatePlanNumber: ").append(toIndentedString(productRatePlanNumber)).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(" isAddingSubsetCharges: ").append(toIndentedString(isAddingSubsetCharges)).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("externalCatalogPlanId");
openapiFields.add("productRatePlanNumber");
openapiFields.add("ratePlanId");
openapiFields.add("specificUpdateDate");
openapiFields.add("subscriptionProductFeatures");
openapiFields.add("subscriptionRatePlanNumber");
openapiFields.add("uniqueToken");
openapiFields.add("isAddingSubsetCharges");
// 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 CreateOrderUpdateProduct
*/
public static void validateJsonElement(JsonElement jsonElement) throws IOException {
if (jsonElement == null) {
if (!CreateOrderUpdateProduct.openapiRequiredFields.isEmpty()) { // has required fields but JSON element is null
throw new IllegalArgumentException(String.format("The required field(s) %s in CreateOrderUpdateProduct is not found in the empty JSON string", CreateOrderUpdateProduct.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++) {
CreateOrderChargeUpdate.validateJsonElement(jsonArraychargeUpdates.get(i));
};
}
}
if ((jsonObj.get("externalCatalogPlanId") != null && !jsonObj.get("externalCatalogPlanId").isJsonNull()) && !jsonObj.get("externalCatalogPlanId").isJsonPrimitive()) {
throw new IllegalArgumentException(String.format("Expected the field `externalCatalogPlanId` to be a primitive type in the JSON string but got `%s`", jsonObj.get("externalCatalogPlanId").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("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++) {
CreateOrderRatePlanFeatureOverride.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 (!CreateOrderUpdateProduct.class.isAssignableFrom(type.getRawType())) {
return null; // this class only serializes 'CreateOrderUpdateProduct' and its subtypes
}
final TypeAdapter elementAdapter = gson.getAdapter(JsonElement.class);
final TypeAdapter thisAdapter
= gson.getDelegateAdapter(this, TypeToken.get(CreateOrderUpdateProduct.class));
return (TypeAdapter) new TypeAdapter() {
@Override
public void write(JsonWriter out, CreateOrderUpdateProduct 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 CreateOrderUpdateProduct read(JsonReader in) throws IOException {
JsonElement jsonElement = elementAdapter.read(in);
validateJsonElement(jsonElement);
JsonObject jsonObj = jsonElement.getAsJsonObject();
// store additional fields in the deserialized instance
CreateOrderUpdateProduct 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 CreateOrderUpdateProduct given an JSON string
*
* @param jsonString JSON string
* @return An instance of CreateOrderUpdateProduct
* @throws IOException if the JSON string is invalid with respect to CreateOrderUpdateProduct
*/
public static CreateOrderUpdateProduct fromJson(String jsonString) throws IOException {
return JSON.getGson().fromJson(jsonString, CreateOrderUpdateProduct.class);
}
/**
* Convert an instance of CreateOrderUpdateProduct to an JSON string
*
* @return JSON string
*/
public String toJson() {
return JSON.getGson().toJson(this);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy