All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.cashfree.pg.model.CFOrderMeta Maven / Gradle / Ivy

There is a newer version: 2.1.7
Show newest version
/*
 * New Payment Gateway APIs
 * No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator)
 *
 * The version of the OpenAPI document: 2022-01-01
 * 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.cashfree.pg.model;


import com.cashfree.pg.JSON;
import com.google.gson.Gson;
import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
import com.google.gson.TypeAdapter;
import com.google.gson.TypeAdapterFactory;
import com.google.gson.annotations.SerializedName;
import com.google.gson.reflect.TypeToken;
import com.google.gson.stream.JsonReader;
import com.google.gson.stream.JsonWriter;
import java.io.IOException;
import java.util.HashSet;
import java.util.Map.Entry;
import java.util.Objects;
import java.util.Set;

/** CFOrderMeta */
@javax.annotation.Generated(
        value = "org.openapitools.codegen.languages.JavaClientCodegen",
        date = "2023-03-16T14:01:52.135917+05:30[Asia/Kolkata]")
public class CFOrderMeta {
    public static final String SERIALIZED_NAME_RETURN_URL = "return_url";

    @SerializedName(SERIALIZED_NAME_RETURN_URL)
    private String returnUrl;

    public static final String SERIALIZED_NAME_NOTIFY_URL = "notify_url";

    @SerializedName(SERIALIZED_NAME_NOTIFY_URL)
    private String notifyUrl;

    public static final String SERIALIZED_NAME_PAYMENT_METHODS = "payment_methods";

    @SerializedName(SERIALIZED_NAME_PAYMENT_METHODS)
    private String paymentMethods;

    public CFOrderMeta() {}

    public CFOrderMeta returnUrl(String returnUrl) {

        this.returnUrl = returnUrl;
        return this;
    }

    /**
     * The URL to which user will be redirected to after the payment on bank OTP page. Maximum
     * length: 250.
     *
     * @return returnUrl
     */
    @javax.annotation.Nullable
    public String getReturnUrl() {
        return returnUrl;
    }

    public void setReturnUrl(String returnUrl) {
        this.returnUrl = returnUrl;
    }

    public CFOrderMeta notifyUrl(String notifyUrl) {

        this.notifyUrl = notifyUrl;
        return this;
    }

    /**
     * Notification URL for server-server communication. Useful when user's connection drops
     * while re-directing. NotifyUrl should be an https URL. Maximum length: 250.
     *
     * @return notifyUrl
     */
    @javax.annotation.Nullable
    public String getNotifyUrl() {
        return notifyUrl;
    }

    public void setNotifyUrl(String notifyUrl) {
        this.notifyUrl = notifyUrl;
    }

    public CFOrderMeta paymentMethods(String paymentMethods) {

        this.paymentMethods = paymentMethods;
        return this;
    }

    /**
     * Allowed payment modes for this order. Pass comma-separated values among following options -
     * \"cc\", \"dc\", \"ccc\", \"ppc\", \"nb\",
     * \"upi\", \"paypal\", \"app\". Leave it blank to show all
     * available payment methods
     *
     * @return paymentMethods
     */
    @javax.annotation.Nullable
    public String getPaymentMethods() {
        return paymentMethods;
    }

    public void setPaymentMethods(String paymentMethods) {
        this.paymentMethods = paymentMethods;
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) {
            return true;
        }
        if (o == null || getClass() != o.getClass()) {
            return false;
        }
        CFOrderMeta cfOrderMeta = (CFOrderMeta) o;
        return Objects.equals(this.returnUrl, cfOrderMeta.returnUrl)
                && Objects.equals(this.notifyUrl, cfOrderMeta.notifyUrl)
                && Objects.equals(this.paymentMethods, cfOrderMeta.paymentMethods);
    }

    @Override
    public int hashCode() {
        return Objects.hash(returnUrl, notifyUrl, paymentMethods);
    }

    @Override
    public String toString() {
        StringBuilder sb = new StringBuilder();
        sb.append("class CFOrderMeta {\n");
        sb.append("    returnUrl: ").append(toIndentedString(returnUrl)).append("\n");
        sb.append("    notifyUrl: ").append(toIndentedString(notifyUrl)).append("\n");
        sb.append("    paymentMethods: ").append(toIndentedString(paymentMethods)).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("return_url");
        openapiFields.add("notify_url");
        openapiFields.add("payment_methods");

        // a set of required properties/fields (JSON key names)
        openapiRequiredFields = new HashSet();
    }

    /**
     * Validates the JSON Object and throws an exception if issues found
     *
     * @param jsonObj JSON Object
     * @throws IOException if the JSON Object is invalid with respect to CFOrderMeta
     */
    public static void validateJsonObject(JsonObject jsonObj) throws IOException {
        if (jsonObj == null) {
            if (!CFOrderMeta.openapiRequiredFields
                    .isEmpty()) { // has required fields but JSON object is null
                throw new IllegalArgumentException(
                        String.format(
                                "The required field(s) %s in CFOrderMeta is not found in the empty"
                                        + " JSON string",
                                CFOrderMeta.openapiRequiredFields.toString()));
            }
        }

        Set> entries = jsonObj.entrySet();
        // check to see if the JSON string contains additional fields
        for (Entry entry : entries) {
            if (!CFOrderMeta.openapiFields.contains(entry.getKey())) {
                throw new IllegalArgumentException(
                        String.format(
                                "The field `%s` in the JSON string is not defined in the"
                                        + " `CFOrderMeta` properties. JSON: %s",
                                entry.getKey(), jsonObj.toString()));
            }
        }
        if ((jsonObj.get("return_url") != null && !jsonObj.get("return_url").isJsonNull())
                && !jsonObj.get("return_url").isJsonPrimitive()) {
            throw new IllegalArgumentException(
                    String.format(
                            "Expected the field `return_url` to be a primitive type in the JSON"
                                    + " string but got `%s`",
                            jsonObj.get("return_url").toString()));
        }
        if ((jsonObj.get("notify_url") != null && !jsonObj.get("notify_url").isJsonNull())
                && !jsonObj.get("notify_url").isJsonPrimitive()) {
            throw new IllegalArgumentException(
                    String.format(
                            "Expected the field `notify_url` to be a primitive type in the JSON"
                                    + " string but got `%s`",
                            jsonObj.get("notify_url").toString()));
        }
        if ((jsonObj.get("payment_methods") != null && !jsonObj.get("payment_methods").isJsonNull())
                && !jsonObj.get("payment_methods").isJsonPrimitive()) {
            throw new IllegalArgumentException(
                    String.format(
                            "Expected the field `payment_methods` to be a primitive type in the"
                                    + " JSON string but got `%s`",
                            jsonObj.get("payment_methods").toString()));
        }
    }

    public static class CustomTypeAdapterFactory implements TypeAdapterFactory {
        @SuppressWarnings("unchecked")
        @Override
        public  TypeAdapter create(Gson gson, TypeToken type) {
            if (!CFOrderMeta.class.isAssignableFrom(type.getRawType())) {
                return null; // this class only serializes 'CFOrderMeta' and its subtypes
            }
            final TypeAdapter elementAdapter = gson.getAdapter(JsonElement.class);
            final TypeAdapter thisAdapter =
                    gson.getDelegateAdapter(this, TypeToken.get(CFOrderMeta.class));

            return (TypeAdapter)
                    new TypeAdapter() {
                        @Override
                        public void write(JsonWriter out, CFOrderMeta value) throws IOException {
                            JsonObject obj = thisAdapter.toJsonTree(value).getAsJsonObject();
                            elementAdapter.write(out, obj);
                        }

                        @Override
                        public CFOrderMeta read(JsonReader in) throws IOException {
                            JsonObject jsonObj = elementAdapter.read(in).getAsJsonObject();
                            validateJsonObject(jsonObj);
                            return thisAdapter.fromJsonTree(jsonObj);
                        }
                    }.nullSafe();
        }
    }

    /**
     * Create an instance of CFOrderMeta given an JSON string
     *
     * @param jsonString JSON string
     * @return An instance of CFOrderMeta
     * @throws IOException if the JSON string is invalid with respect to CFOrderMeta
     */
    public static CFOrderMeta fromJson(String jsonString) throws IOException {
        return JSON.getGson().fromJson(jsonString, CFOrderMeta.class);
    }

    /**
     * Convert an instance of CFOrderMeta to an JSON string
     *
     * @return JSON string
     */
    public String toJson() {
        return JSON.getGson().toJson(this);
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy