Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*
* The Jira Cloud platform REST API
* Jira Cloud platform REST API documentation
*
* The version of the OpenAPI document: 1001.0.0-SNAPSHOT
* 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 software.tnb.jira.validation.generated.model;
import java.util.Objects;
import java.util.Arrays;
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 io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import software.tnb.jira.validation.generated.model.FunctionOperand;
import software.tnb.jira.validation.generated.model.KeywordOperand;
import software.tnb.jira.validation.generated.model.ValueOperand;
import javax.ws.rs.core.GenericType;
import java.io.IOException;
import java.lang.reflect.Type;
import java.util.logging.Level;
import java.util.logging.Logger;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashSet;
import java.util.HashMap;
import java.util.Map;
import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
import com.google.gson.JsonParseException;
import com.google.gson.TypeAdapter;
import com.google.gson.TypeAdapterFactory;
import com.google.gson.reflect.TypeToken;
import com.google.gson.JsonPrimitive;
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.google.gson.JsonDeserializationContext;
import com.google.gson.JsonDeserializer;
import com.google.gson.JsonSerializationContext;
import com.google.gson.JsonSerializer;
import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
import com.google.gson.JsonParseException;
import software.tnb.jira.validation.generated.JSON;
@javax.annotation.Generated(value = "org.openapitools.codegen.languages.JavaClientCodegen", date = "2023-01-25T14:34:21.312863Z[Etc/UTC]")
public class JqlQueryUnitaryOperand extends AbstractOpenApiSchema {
private static final Logger log = Logger.getLogger(JqlQueryUnitaryOperand.class.getName());
public static class CustomTypeAdapterFactory implements TypeAdapterFactory {
@SuppressWarnings("unchecked")
@Override
public TypeAdapter create(Gson gson, TypeToken type) {
if (!JqlQueryUnitaryOperand.class.isAssignableFrom(type.getRawType())) {
return null; // this class only serializes 'JqlQueryUnitaryOperand' and its subtypes
}
final TypeAdapter elementAdapter = gson.getAdapter(JsonElement.class);
final TypeAdapter adapterFunctionOperand = gson.getDelegateAdapter(this, TypeToken.get(FunctionOperand.class));
final TypeAdapter adapterKeywordOperand = gson.getDelegateAdapter(this, TypeToken.get(KeywordOperand.class));
final TypeAdapter adapterValueOperand = gson.getDelegateAdapter(this, TypeToken.get(ValueOperand.class));
return (TypeAdapter) new TypeAdapter() {
@Override
public void write(JsonWriter out, JqlQueryUnitaryOperand value) throws IOException {
if (value == null || value.getActualInstance() == null) {
elementAdapter.write(out, null);
return;
}
// check if the actual instance is of the type `FunctionOperand`
if (value.getActualInstance() instanceof FunctionOperand) {
JsonObject obj = adapterFunctionOperand.toJsonTree((FunctionOperand)value.getActualInstance()).getAsJsonObject();
elementAdapter.write(out, obj);
return;
}
// check if the actual instance is of the type `KeywordOperand`
if (value.getActualInstance() instanceof KeywordOperand) {
JsonObject obj = adapterKeywordOperand.toJsonTree((KeywordOperand)value.getActualInstance()).getAsJsonObject();
elementAdapter.write(out, obj);
return;
}
// check if the actual instance is of the type `ValueOperand`
if (value.getActualInstance() instanceof ValueOperand) {
JsonObject obj = adapterValueOperand.toJsonTree((ValueOperand)value.getActualInstance()).getAsJsonObject();
elementAdapter.write(out, obj);
return;
}
throw new IOException("Failed to serialize as the type doesn't match anyOf schemas: FunctionOperand, KeywordOperand, ValueOperand");
}
@Override
public JqlQueryUnitaryOperand read(JsonReader in) throws IOException {
Object deserialized = null;
JsonObject jsonObject = elementAdapter.read(in).getAsJsonObject();
// deserialize FunctionOperand
try {
// validate the JSON object to see if any exception is thrown
FunctionOperand.validateJsonObject(jsonObject);
log.log(Level.FINER, "Input data matches schema 'FunctionOperand'");
JqlQueryUnitaryOperand ret = new JqlQueryUnitaryOperand();
ret.setActualInstance(adapterFunctionOperand.fromJsonTree(jsonObject));
return ret;
} catch (Exception e) {
// deserialization failed, continue
log.log(Level.FINER, "Input data does not match schema 'FunctionOperand'", e);
}
// deserialize KeywordOperand
try {
// validate the JSON object to see if any exception is thrown
KeywordOperand.validateJsonObject(jsonObject);
log.log(Level.FINER, "Input data matches schema 'KeywordOperand'");
JqlQueryUnitaryOperand ret = new JqlQueryUnitaryOperand();
ret.setActualInstance(adapterKeywordOperand.fromJsonTree(jsonObject));
return ret;
} catch (Exception e) {
// deserialization failed, continue
log.log(Level.FINER, "Input data does not match schema 'KeywordOperand'", e);
}
// deserialize ValueOperand
try {
// validate the JSON object to see if any exception is thrown
ValueOperand.validateJsonObject(jsonObject);
log.log(Level.FINER, "Input data matches schema 'ValueOperand'");
JqlQueryUnitaryOperand ret = new JqlQueryUnitaryOperand();
ret.setActualInstance(adapterValueOperand.fromJsonTree(jsonObject));
return ret;
} catch (Exception e) {
// deserialization failed, continue
log.log(Level.FINER, "Input data does not match schema 'ValueOperand'", e);
}
throw new IOException(String.format("Failed deserialization for JqlQueryUnitaryOperand: no class matched. JSON: %s", jsonObject.toString()));
}
}.nullSafe();
}
}
// store a list of schema names defined in anyOf
public static final Map schemas = new HashMap();
public JqlQueryUnitaryOperand() {
super("anyOf", Boolean.FALSE);
}
public JqlQueryUnitaryOperand(FunctionOperand o) {
super("anyOf", Boolean.FALSE);
setActualInstance(o);
}
public JqlQueryUnitaryOperand(KeywordOperand o) {
super("anyOf", Boolean.FALSE);
setActualInstance(o);
}
public JqlQueryUnitaryOperand(ValueOperand o) {
super("anyOf", Boolean.FALSE);
setActualInstance(o);
}
static {
schemas.put("FunctionOperand", new GenericType() {
});
schemas.put("KeywordOperand", new GenericType() {
});
schemas.put("ValueOperand", new GenericType() {
});
}
@Override
public Map getSchemas() {
return JqlQueryUnitaryOperand.schemas;
}
/**
* Set the instance that matches the anyOf child schema, check
* the instance parameter is valid against the anyOf child schemas:
* FunctionOperand, KeywordOperand, ValueOperand
*
* It could be an instance of the 'anyOf' schemas.
* The anyOf child schemas may themselves be a composed schema (allOf, anyOf, anyOf).
*/
@Override
public void setActualInstance(Object instance) {
if (instance instanceof FunctionOperand) {
super.setActualInstance(instance);
return;
}
if (instance instanceof KeywordOperand) {
super.setActualInstance(instance);
return;
}
if (instance instanceof ValueOperand) {
super.setActualInstance(instance);
return;
}
throw new RuntimeException("Invalid instance type. Must be FunctionOperand, KeywordOperand, ValueOperand");
}
/**
* Get the actual instance, which can be the following:
* FunctionOperand, KeywordOperand, ValueOperand
*
* @return The actual instance (FunctionOperand, KeywordOperand, ValueOperand)
*/
@Override
public Object getActualInstance() {
return super.getActualInstance();
}
/**
* Get the actual instance of `FunctionOperand`. If the actual instance is not `FunctionOperand`,
* the ClassCastException will be thrown.
*
* @return The actual instance of `FunctionOperand`
* @throws ClassCastException if the instance is not `FunctionOperand`
*/
public FunctionOperand getFunctionOperand() throws ClassCastException {
return (FunctionOperand)super.getActualInstance();
}
/**
* Get the actual instance of `KeywordOperand`. If the actual instance is not `KeywordOperand`,
* the ClassCastException will be thrown.
*
* @return The actual instance of `KeywordOperand`
* @throws ClassCastException if the instance is not `KeywordOperand`
*/
public KeywordOperand getKeywordOperand() throws ClassCastException {
return (KeywordOperand)super.getActualInstance();
}
/**
* Get the actual instance of `ValueOperand`. If the actual instance is not `ValueOperand`,
* the ClassCastException will be thrown.
*
* @return The actual instance of `ValueOperand`
* @throws ClassCastException if the instance is not `ValueOperand`
*/
public ValueOperand getValueOperand() throws ClassCastException {
return (ValueOperand)super.getActualInstance();
}
/**
* 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 JqlQueryUnitaryOperand
*/
public static void validateJsonObject(JsonObject jsonObj) throws IOException {
// validate anyOf schemas one by one
int validCount = 0;
// validate the json string with FunctionOperand
try {
FunctionOperand.validateJsonObject(jsonObj);
return; // return earlier as at least one schema is valid with respect to the Json object
//validCount++;
} catch (Exception e) {
// continue to the next one
}
// validate the json string with KeywordOperand
try {
KeywordOperand.validateJsonObject(jsonObj);
return; // return earlier as at least one schema is valid with respect to the Json object
//validCount++;
} catch (Exception e) {
// continue to the next one
}
// validate the json string with ValueOperand
try {
ValueOperand.validateJsonObject(jsonObj);
return; // return earlier as at least one schema is valid with respect to the Json object
//validCount++;
} catch (Exception e) {
// continue to the next one
}
if (validCount == 0) {
throw new IOException(String.format("The JSON string is invalid for JqlQueryUnitaryOperand with anyOf schemas: FunctionOperand, KeywordOperand, ValueOperand. JSON: %s", jsonObj.toString()));
}
}
/**
* Create an instance of JqlQueryUnitaryOperand given an JSON string
*
* @param jsonString JSON string
* @return An instance of JqlQueryUnitaryOperand
* @throws IOException if the JSON string is invalid with respect to JqlQueryUnitaryOperand
*/
public static JqlQueryUnitaryOperand fromJson(String jsonString) throws IOException {
return JSON.getGson().fromJson(jsonString, JqlQueryUnitaryOperand.class);
}
/**
* Convert an instance of JqlQueryUnitaryOperand to an JSON string
*
* @return JSON string
*/
public String toJson() {
return JSON.getGson().toJson(this);
}
}