Class LegacyCoercingInputInterceptor
- java.lang.Object
-
- graphql.execution.values.legacycoercing.LegacyCoercingInputInterceptor
-
- All Implemented Interfaces:
InputInterceptor
public class LegacyCoercingInputInterceptor extends java.lang.Object implements InputInterceptor
-
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description java.lang.Object
intercept(@Nullable java.lang.Object input, @NotNull GraphQLInputType graphQLType, @NotNull GraphQLContext graphqlContext, @NotNull java.util.Locale locale)
This is called with a value that is to be presented to theValuesResolver
code.static LegacyCoercingInputInterceptor
migratesValues()
This will change legacy values as it encounters them to something acceptable to the more strict coercion rules.static LegacyCoercingInputInterceptor
migratesValues(java.util.function.BiConsumer<java.lang.Object,GraphQLInputType> observerCallback)
This will change legacy values as it encounters them to something acceptable to the more strict coercion rules.static LegacyCoercingInputInterceptor
observesValues(java.util.function.BiConsumer<java.lang.Object,GraphQLInputType> observerCallback)
This will ONLY observe legacy values and invoke the callback when it gets one.
-
-
-
Method Detail
-
observesValues
public static LegacyCoercingInputInterceptor observesValues(java.util.function.BiConsumer<java.lang.Object,GraphQLInputType> observerCallback)
This will ONLY observe legacy values and invoke the callback when it gets one. you can use this to enumerate how many legacy values are hitting you graphql implementation- Parameters:
observerCallback
- a callback allowing you to observe a legacy scalar value- Returns:
- an InputInterceptor that only observes values
-
migratesValues
public static LegacyCoercingInputInterceptor migratesValues()
This will change legacy values as it encounters them to something acceptable to the more strict coercion rules.- Returns:
- an InputInterceptor that migrates values to a more strict value
-
migratesValues
public static LegacyCoercingInputInterceptor migratesValues(java.util.function.BiConsumer<java.lang.Object,GraphQLInputType> observerCallback)
This will change legacy values as it encounters them to something acceptable to the more strict coercion rules. The observer callback will be invoked if it detects a legacy value that it will change.- Parameters:
observerCallback
- a callback allowing you to observe a legacy scalar value before it is migrated- Returns:
- an InputInterceptor that both observes values and migrates them to a more strict value
-
intercept
public java.lang.Object intercept(@Nullable @Nullable java.lang.Object input, @NotNull @NotNull GraphQLInputType graphQLType, @NotNull @NotNull GraphQLContext graphqlContext, @NotNull @NotNull java.util.Locale locale)
Description copied from interface:InputInterceptor
This is called with a value that is to be presented to theValuesResolver
code. The values may be scalars, enums and complex input types.- Specified by:
intercept
in interfaceInputInterceptor
- Parameters:
input
- the input value that can be nullgraphQLType
- the input typegraphqlContext
- the graphql context in playlocale
- the locale in play- Returns:
- a value that may differ from the original value
-
-