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

main.com.netflix.graphql.dgs.reactive.DgsReactiveQueryExecutor Maven / Gradle / Ivy

There is a newer version: 10.0.1
Show newest version
/*
 * Copyright 2021 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.reactive;

import com.jayway.jsonpath.DocumentContext;
import com.jayway.jsonpath.TypeRef;
import graphql.ExecutionResult;
import org.intellij.lang.annotations.Language;
import org.springframework.http.HttpHeaders;
import org.springframework.web.reactive.function.server.ServerRequest;
import reactor.core.publisher.Mono;

import java.util.Collections;
import java.util.Map;

/**
 * Represents the core query executing capability of the framework.
 * This is the reactive version of the interface, using {@link Mono} for its results.
 * See {@link com.netflix.graphql.dgs.DgsQueryExecutor} for the blocking version of this interface.
 * Use this interface to easily execute GraphQL queries, without using the HTTP endpoint.
 * This is meant to be used in tests, and is also used internally in the framework.
 * 

* The executeAnd* methods use the JsonPath library library to easily get specific fields out of a nested Json structure. * The {@link #executeAndGetDocumentContext(String)} method sets up a DocumentContext, which can then be reused to get multiple fields. * * @see Query Execution Testing docs */ public interface DgsReactiveQueryExecutor { /** * @param query The query string * @return Returns a GraphQL {@link ExecutionResult}. This includes data and errors. */ default Mono execute(@Language("GraphQL") String query) { return execute(query, null, null, null, null, null); } /** * @param query The query string * @param variables A map of variables * @return Returns a GraphQL {@link ExecutionResult}. This includes data and errors. * @see Query Variables */ default Mono execute(@Language("GraphQL") String query, Map variables) { return execute(query, variables, null, null, null, null); } /** * @param query The query string * @param variables A map of variables * @param operationName The operation name * @return Returns a GraphQL {@link ExecutionResult}. This includes data and errors. * @see Query Variables * @see Operation name */ default Mono execute(@Language("GraphQL") String query, Map variables, String operationName) { return execute(query, variables, null, null, operationName, null); } /** * @param query The query string * @param variables A map of variables * @param extensions A map representing GraphQL extensions. This is made available in the * {@link com.netflix.graphql.dgs.internal.DgsRequestData} object on * {@link com.netflix.graphql.dgs.context.DgsContext}. * @param headers Request headers represented as a Spring Framework {@link HttpHeaders} * @return Returns a GraphQL {@link ExecutionResult}. This includes data and errors. * @see Query Variables */ default Mono execute(@Language("GraphQL") String query, Map variables, Map extensions, HttpHeaders headers) { return execute(query, variables, extensions, headers, null, null); } /** * Executes a GraphQL query. This method is used internally by all other methods in this interface. * * @param query The query string * @param variables A map of variables * @param extensions A map representing GraphQL extensions. This is made available in the {@link com.netflix.graphql.dgs.internal.DgsRequestData} * object on {@link com.netflix.graphql.dgs.context.DgsContext}. * @param headers Request headers represented as a Spring Framework {@link HttpHeaders} * @param operationName Operation name * @param serverRequest A Spring {@link ServerRequest} giving access to request details. * @return Returns a GraphQL {@link ExecutionResult}. This includes data and errors. * @see Query Variables * @see Operation name */ Mono execute(@Language("GraphQL") String query, Map variables, Map extensions, HttpHeaders headers, String operationName, ServerRequest serverRequest); /** * Executes a GraphQL query, parses the returned data, and uses a Json Path to extract specific elements out of the data. * The method is generic, and tries to cast the result into the type you specify. * This does NOT work on Lists. Use {@link #executeAndExtractJsonPathAsObject(String, String, TypeRef)} instead. *

* This only works for primitive types and map representations. * Use {@link #executeAndExtractJsonPathAsObject(String, String, Class)} for complex types and lists. * * @param query Query string * @param jsonPath JsonPath expression. * @param The type of primitive or map representation that should be returned. * @return A Mono that might contain the resolved type. * @see JsonPath syntax docs */ default Mono executeAndExtractJsonPath(@Language("GraphQL") String query, @Language("JSONPath") String jsonPath) { return executeAndExtractJsonPath(query, jsonPath, Collections.emptyMap(), null); } /** * Executes a GraphQL query, parses the returned data, and uses a Json Path to extract specific elements out of the data. * The method is generic, and tries to cast the result into the type you specify. * This does NOT work on Lists. Use {@link #executeAndExtractJsonPathAsObject(String, String, TypeRef)}instead. *

* This only works for primitive types and map representations. * Use {@link #executeAndExtractJsonPathAsObject(String, String, Class)} for complex types and lists.* * * @param query Query string * @param jsonPath JsonPath expression. * @param variables A Map of variables * @param serverRequest A Spring {@link ServerRequest} giving access to request details. * * @param The type of primitive or map representation that should be returned. * @return A Mono that might contain the resolved type. * @see Query Variables * @see JsonPath syntax docs */ Mono executeAndExtractJsonPath(@Language("GraphQL") String query, @Language("JSONPath") String jsonPath, Map variables, ServerRequest serverRequest); /** * Executes a GraphQL query, parses the returned data, and uses a Json Path to extract specific elements out of the data. * The method is generic, and tries to cast the result into the type you specify. * This does NOT work on Lists. Use {@link #executeAndExtractJsonPathAsObject(String, String, TypeRef)}instead. *

* This only works for primitive types and map representations. * Use {@link #executeAndExtractJsonPathAsObject(String, String, Class)} for complex types and lists.* * * @param query Query string * @param jsonPath JsonPath expression. * @param variables A Map of variables * @param The type of primitive or map representation that should be returned. * @return A Mono that might contain the resolved type. * @see Query Variables * @see JsonPath syntax docs */ default Mono executeAndExtractJsonPath(@Language("GraphQL") String query, @Language("JSONPath") String jsonPath, Map variables) { return executeAndExtractJsonPath(query, jsonPath, variables, null); } /** * Executes a GraphQL query, parses the returned data, and uses a Json Path to extract specific elements out of the data. * The method is generic, and tries to cast the result into the type you specify. * This does NOT work on Lists. Use {@link #executeAndExtractJsonPathAsObject(String, String, TypeRef)}instead. *

* This only works for primitive types and map representations. * Use {@link #executeAndExtractJsonPathAsObject(String, String, Class)} for complex types and lists.* * * @param query Query string * @param jsonPath JsonPath expression. * @param serverRequest A Spring {@link ServerRequest} giving access to request details. * @param The type of primitive or map representation that should be returned. * @return A Mono that might contain the resolved type. * @see Query Variables * @see JsonPath syntax docs */ default Mono executeAndExtractJsonPath(@Language("GraphQL") String query, @Language("JSONPath") String jsonPath, ServerRequest serverRequest) { return executeAndExtractJsonPath(query, jsonPath, null, serverRequest ); } /** * Executes a GraphQL query, parses the returned data, and return a {@link DocumentContext}. * A {@link DocumentContext} can be used to extract multiple values using JsonPath, without re-executing the query. * * @param query GraphQL query string * @return {@link DocumentContext} is a JsonPath type used to extract values from. */ default Mono executeAndGetDocumentContext(@Language("GraphQL") String query) { return executeAndGetDocumentContext(query, Collections.emptyMap()); } /** * Executes a GraphQL query, parses the returned data, and return a {@link DocumentContext}. * A {@link DocumentContext} can be used to extract multiple values using JsonPath, without re-executing the query. * * @param query GraphQL query string * @param variables A Map of variables * @return {@link DocumentContext} is a JsonPath type used to extract values from. * @see Query Variables */ Mono executeAndGetDocumentContext(@Language("GraphQL") String query, Map variables); /** * Executes a GraphQL query, parses the returned data, extracts a value using JsonPath, and converts that value into the given type. * Be aware that this method can't guarantee type safety. * * @param query GraphQL query string * @param jsonPath JsonPath expression. * @param clazz The type to convert the extracted value to. * @param The type that the extracted value should be converted to. * @return The extracted value from the result, converted to type T * @see JsonPath syntax docs */ default Mono executeAndExtractJsonPathAsObject(@Language("GraphQL") String query, @Language("JSONPath") String jsonPath, Class clazz) { return executeAndExtractJsonPathAsObject(query, jsonPath, Collections.emptyMap(), clazz); } /** * Executes a GraphQL query, parses the returned data, extracts a value using JsonPath, and converts that value into the given type. * Be aware that this method can't guarantee type safety. * * @param query GraphQL query string * @param jsonPath JsonPath expression. * @param variables A Map of variables * @param clazz The type to convert the extracted value to. * @param The type that the extracted value should be converted to. * @return The extracted value from the result, converted to type T * @see JsonPath syntax docs * @see Query Variables */ Mono executeAndExtractJsonPathAsObject(@Language("GraphQL") String query, @Language("JSONPath") String jsonPath, Map variables, Class clazz); /** * Executes a GraphQL query, parses the returned data, extracts a value using JsonPath, and converts that value into the given type. * Uses a {@link TypeRef} to specify the expected type, which is useful for Lists and Maps. * Be aware that this method can't guarantee type safety. * * @param query Query string * @param jsonPath JsonPath expression. * @param typeRef A JsonPath [TypeRef] representing the expected result type. * @param The type that the extracted value should be converted to. * @return The extracted value from the result, converted to type T * @see JsonPath syntax docs * @see Using TypeRef */ default Mono executeAndExtractJsonPathAsObject(@Language("GraphQL") String query, @Language("JSONPath") String jsonPath, TypeRef typeRef) { return executeAndExtractJsonPathAsObject(query, jsonPath, Collections.emptyMap(), typeRef); } /** * Executes a GraphQL query, parses the returned data, extracts a value using JsonPath, and converts that value into the given type. * Uses a {@link TypeRef} to specify the expected type, which is useful for Lists and Maps. * Be aware that this method can't guarantee type safety. * * @param query Query string * @param jsonPath JsonPath expression. * @param variables A Map of variables * @param typeRef A JsonPath {@link TypeRef} representing the expected result type. * @param The type that the extracted value should be converted to. * @return The extracted value from the result, converted to type T * @see JsonPath syntax docs * @see Query Variables * @see Using TypeRef */ Mono executeAndExtractJsonPathAsObject(@Language("GraphQL") String query, @Language("JSONPath") String jsonPath, Map variables, TypeRef typeRef); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy