graphql.schema.PropertyDataFetcher Maven / Gradle / Ivy
package graphql.schema;
import graphql.Assert;
import graphql.PublicApi;
import java.util.function.Function;
import java.util.function.Supplier;
/**
* This is the default data fetcher used in graphql-java, and it will examine
* maps, records 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.
*
* 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 `getPropertyName()` or `isPropertyName()`
* - Find any getter method named `getPropertyName()` or `isPropertyName()` and call method.setAccessible(true)
* - Find a public field named `propertyName`
* - Find any field named `propertyName` and call field.setAccessible(true)
* - Find a public Record like method named `propertyName()`
* - 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 LightDataFetcher {
private final String propertyName;
private final Function
© 2015 - 2025 Weber Informatics LLC | Privacy Policy