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

io.ebean.text.json.JsonContext Maven / Gradle / Ivy

There is a newer version: 15.8.0
Show newest version
package io.ebean.text.json;

import com.fasterxml.jackson.core.JsonGenerator;
import com.fasterxml.jackson.core.JsonParser;
import io.ebean.FetchPath;
import io.ebean.plugin.BeanType;

import java.io.IOException;
import java.io.Reader;
import java.io.Writer;
import java.lang.reflect.Type;
import java.util.List;

/**
 * Converts objects to and from JSON format.
 */
public interface JsonContext {

  /**
   * Convert json string input into a Bean of a specific type.
   *
   * @throws JsonIOException When IOException occurs
   */
   T toBean(Class rootType, String json) throws JsonIOException;

  /**
   * Convert json string input into a Bean of a specific type additionally using JsonReadOptions.
   *
   * @throws JsonIOException When IOException occurs
   */
   T toBean(Class rootType, String json, JsonReadOptions options) throws JsonIOException;

  /**
   * Convert json reader input into a Bean of a specific type.
   *
   * @throws JsonIOException When IOException occurs
   */
   T toBean(Class rootType, Reader json) throws JsonIOException;

  /**
   * Convert json reader input into a Bean of a specific type additionally using JsonReadOptions.
   *
   * @throws JsonIOException When IOException occurs
   */
   T toBean(Class rootType, Reader json, JsonReadOptions options) throws JsonIOException;

  /**
   * Convert json parser input into a Bean of a specific type.
   *
   * @throws JsonIOException When IOException occurs
   */
   T toBean(Class cls, JsonParser parser) throws JsonIOException;

  /**
   * Convert json parser input into a Bean of a specific type additionally using JsonReadOptions..
   *
   * @throws JsonIOException When IOException occurs
   */
   T toBean(Class cls, JsonParser parser, JsonReadOptions options) throws JsonIOException;

  /**
   * Read json parser input into a given Bean. 
* Note: This is a kind of "update". Only properties in the json will be modified. Embedded Lists and Maps will become new * instances, so the object identity will not be preserved here. * * @throws JsonIOException When IOException occurs */ void toBean(T target, JsonParser parser) throws JsonIOException; /** * Read json parser input into a given Bean additionally using JsonReadOptions.
* See {@link #toBean(Class, JsonParser)} for details modified. * * @throws JsonIOException When IOException occurs */ void toBean(T target, JsonParser parser, JsonReadOptions options) throws JsonIOException; /** * Read json reader input into a given Bean.
* See {@link #toBean(Class, JsonParser)} for details * * @throws JsonIOException When IOException occurs */ void toBean(T target, Reader json) throws JsonIOException; /** * Read json reader input into a given Bean additionally using JsonReadOptions.
* See {@link #toBean(Class, JsonParser)} for details modified. * * @throws JsonIOException When IOException occurs */ void toBean(T target, Reader json, JsonReadOptions options) throws JsonIOException; /** * Read json string input into a given Bean.
* See {@link #toBean(Class, JsonParser)} for details * * @throws JsonIOException When IOException occurs */ void toBean(T target, String json) throws JsonIOException; /** * Read json string input into a given Bean additionally using JsonReadOptions.
* See {@link #toBean(Class, JsonParser)} for details * * @throws JsonIOException When IOException occurs */ void toBean(T target, String json, JsonReadOptions options) throws JsonIOException; /** * Create and return a new bean reading for the bean type given the JSON options and source. *

* Note that JsonOption provides an option for setting a persistence context and also enabling further lazy loading. Further lazy * loading requires a persistence context so if that is set on then a persistence context is created if there is not one set. */ JsonBeanReader createBeanReader(Class cls, JsonParser parser, JsonReadOptions options) throws JsonIOException; /** * Create and return a new bean reading for the bean type given the JSON options and source. *

* Note that JsonOption provides an option for setting a persistence context and also enabling * further lazy loading. Further lazy loading requires a persistence context so if that is set * on then a persistence context is created if there is not one set. */ JsonBeanReader createBeanReader(BeanType beanType, JsonParser parser, JsonReadOptions options) throws JsonIOException; /** * Convert json string input into a list of beans of a specific type. * * @throws JsonIOException When IOException occurs */ List toList(Class rootType, String json) throws JsonIOException; /** * Convert json string input into a list of beans of a specific type additionally using JsonReadOptions. * * @throws JsonIOException When IOException occurs */ List toList(Class rootType, String json, JsonReadOptions options) throws JsonIOException; /** * Convert json reader input into a list of beans of a specific type. * * @throws JsonIOException When IOException occurs */ List toList(Class rootType, Reader json) throws JsonIOException; /** * Convert json reader input into a list of beans of a specific type additionally using JsonReadOptions. * * @throws JsonIOException When IOException occurs */ List toList(Class rootType, Reader json, JsonReadOptions options) throws JsonIOException; /** * Convert json parser input into a list of beans of a specific type. * * @throws JsonIOException When IOException occurs */ List toList(Class cls, JsonParser json) throws JsonIOException; /** * Convert json parser input into a list of beans of a specific type additionally using JsonReadOptions. * * @throws JsonIOException When IOException occurs */ List toList(Class cls, JsonParser json, JsonReadOptions options) throws JsonIOException; /** * Use the genericType to determine if this should be converted into a List or * bean. * * @throws JsonIOException When IOException occurs */ Object toObject(Type genericType, Reader json) throws JsonIOException; /** * Use the genericType to determine if this should be converted into a List or * bean. * * @throws JsonIOException When IOException occurs */ Object toObject(Type genericType, String json) throws JsonIOException; /** * Use the genericType to determine if this should be converted into a List or * bean. * * @throws JsonIOException When IOException occurs */ Object toObject(Type genericType, JsonParser jsonParser) throws JsonIOException; /** * Return the bean or collection as JSON string. * * @throws JsonIOException When IOException occurs */ String toJson(Object value) throws JsonIOException; /** * Return the bean or collection as JSON string in pretty format. * * @throws JsonIOException When IOException occurs */ String toJsonPretty(Object value) throws JsonIOException; /** * Write the bean or collection in JSON format to the writer. * * @throws JsonIOException When IOException occurs */ void toJson(Object value, Writer writer) throws JsonIOException; /** * Write the bean or collection to the JsonGenerator. * * @throws JsonIOException When IOException occurs */ void toJson(Object value, JsonGenerator generator) throws JsonIOException; /** * Return the bean or collection as JSON string using FetchPath. * * @throws JsonIOException When IOException occurs */ String toJson(Object value, FetchPath fetchPath) throws JsonIOException; /** * Write the bean or collection as json to the writer using the FetchPath. */ void toJson(Object value, Writer writer, FetchPath fetchPath) throws JsonIOException; /** * Write the bean or collection to the JsonGenerator using the FetchPath. */ void toJson(Object value, JsonGenerator generator, FetchPath fetchPath) throws JsonIOException; /** * Deprecated in favour of using PathProperties by itself. * Write json to the JsonGenerator using the JsonWriteOptions. */ void toJson(Object value, JsonGenerator generator, JsonWriteOptions options) throws JsonIOException; /** * Deprecated in favour of using PathProperties by itself. * With additional options. * * @throws JsonIOException When IOException occurs */ void toJson(Object value, Writer writer, JsonWriteOptions options) throws JsonIOException; /** * Deprecated in favour of using PathProperties by itself. * Convert a bean or collection to json string. * * @throws JsonIOException When IOException occurs */ String toJson(Object value, JsonWriteOptions options) throws JsonIOException; /** * Return true if the type is known as an Entity bean or a List Set or * Map of entity beans. */ boolean isSupportedType(Type genericType); /** * Create and return a new JsonGenerator for the given writer. * * @throws JsonIOException When IOException occurs */ JsonGenerator createGenerator(Writer writer) throws JsonIOException; /** * Create and return a new JsonParser for the given reader. * * @throws JsonIOException When IOException occurs */ JsonParser createParser(Reader reader) throws JsonIOException; /** * Write a scalar types known to Ebean to Jackson. *

* Ebean has built in support for java8 and Joda types as well as the other * standard JDK types like URI, URL, UUID etc. This is a fast simple way to * write any of those types to Jackson. *

*/ void writeScalar(JsonGenerator generator, Object scalarValue) throws IOException; }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy