graphql.schema.PropertyDataFetcher Maven / Gradle / Ivy
package graphql.schema;
import graphql.Assert;
import graphql.GraphQLException;
import graphql.PublicApi;
import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.lang.reflect.Modifier;
import java.util.Arrays;
import java.util.Map;
import java.util.Optional;
import java.util.function.Function;
import static graphql.Scalars.GraphQLBoolean;
/**
* This is the default data fetcher used in graphql-java. It will examine
* maps and POJO java beans for values that match the desired name, typically the field name
* or it will use a provided function to obtain values.
* maps and POJO java beans for values that match the desired name.
*
* It uses the following strategies
*
* - If the source is null, return null
* - If the source is a Map, return map.get(propertyName)
* - If a function is provided, it is used
* - Find a public JavaBean getter method named `propertyName`
* - Find any getter method named `propertyName` and call method.setAccessible(true)
* - Find a public field named `propertyName`
* - Find any field named `propertyName` and call field.setAccessible(true)
* - If this cant find anything, then null is returned
*
*
* You can write your own data fetchers to get data from some other backing system
* if you need highly customised behaviour.
*
* @see graphql.schema.DataFetcher
*/
@PublicApi
public class PropertyDataFetcher implements DataFetcher {
private final String propertyName;
private final Function
© 2015 - 2025 Weber Informatics LLC | Privacy Policy