com.netflix.graphql.dgs.internal.InputObjectMapper.kt Maven / Gradle / Ivy
/*
* Copyright 2022 Netflix, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.netflix.graphql.dgs.internal
import kotlin.reflect.KClass
/**
* SPI intended for other frameworks/libraries that need to customize how input objects are mapped.
* Not intended to be used by most users.
*
* A custom mapper might call the DefaultInputObjectMapper, passing itself to the DefaultInputObjectMapper constructor.
* The DefaultInputObjectMapper will invoke the custom mapper each time it goes a level deeper into a nested object structure.
* This makes it possible to have a custom mapper that still mostly relies on the default one.
* Be careful to not create an infinite recursion calling back and forward though!
*
* Kotlin and Java objects are converted differently. This is to deal with things like data classes.
* The input to the map methods is a map of values that are already converted by scalars.
* The input IS NOT JSON. Attempting to use a JSON mapper to converting these values will result in incorrect scalar values.
*/
interface InputObjectMapper {
/**
* Convert a map of input values to a Kotlin object. This must support Kotlin constructs such as data classes, and is typically handled differently from Java.
* @param inputMap The fields for an input object represented as a Map. This can be a nested map if nested types are used. Note that the values in this map are already converted by the scalars representing these types.
* @param targetClass The class to convert to.
* @return The converted object
*/
fun mapToKotlinObject(inputMap: Map, targetClass: KClass): T
/**
* Convert a map of input values to a Java object.
* @param inputMap The fields for an input object represented as a Map. This can be a nested map if nested types are used. Note that the values in this map are already converted by the scalars representing these types.
* @param targetClass The class to convert to.
* @return The converted object
*/
fun mapToJavaObject(inputMap: Map, targetClass: Class): T
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy