New developments should not use the graphql Maven goal or generateCode Gradle task. Instead, they should use the new generateClientCode and generateServerCode goals/tasks. Whether the application uses the graphql, the generateClientCode or the generateServerCode goal/task, it should use the parameters below, to be compliant with default values of the 2.0 version:
- generateBatchLoaderEnvironment: true (server only)
- generateDeprecatedRequestResponse: false (client only)
- separateUtilityClasses: true (both client and server mode)
- skipGenerationIfSchemaHasNotChanged: true (both client and server mode)
Client mode:
- The queries, mutations and subscriptions now accept GraphQL aliases, like specified in GraphQL spec
- Once the request is executed, The alias value can be retrieved with the
Object getAliasValue(String: aliasname)
method that has been added to every generated objects and interfaces. This method returns the alias value, parsed into the relevant Java Object.
- Once the request is executed, The alias value can be retrieved with the
- The default
QueryExecutor
provided by the plugin is now a Spring bean. If you want to override it, you should not mark your ownQueryExecutor
with the@Primary
annotation, to ignore the default one.
New goal/task added:
- generatePojo: This goal allows to only generate the Java classes and interfaces that match the provided GraphQL schema.
Server mode:
- Workaround to build a project with Gradle 7 without the gradle wrapper (this commit prevents a strange error during the build)
Internal:
- The plugin now uses slf4j as the logging frontend framework, as do Gradle and Maven (since maven 3.1). This means that, when using Maven, the minimum release version is the 3.1 version.
Both mode:
- Upgrade of com.google.guava, to version 30.1.1-jre, to remove a vulnerability
- Upgrade of Spring boot from 2.4.0 to 2.4.4
- Upgrade of Spring framework from 5.3.0 to 5.3.5
- Upgrade of Spring security from 5.4.1 to 5.4.5
- Upgrade of graphql-java-extended-scalars version from 1.0.1 to 16.0.1
- Upgrade of commons-io from 2.6 to 2.8.0
- Upgrade of dozer-core from 6.5.0 to 6.5.2
- Upgrade of h2 from 1.4.199 to 1.4.200
Client mode:
- Issue #65: When using requests with the parameters in the request (no GraphQL Variables and no Bind Parameter), the request is properly encoded when these parameters are or contain strings
- Dependency order changed in the graphql-java-client-dependencies module, to make sure the right spring's dependencies are used (this could prevent a Spring app to start)
- Removed the use of the
reactor.core.publisher.Sinks
class, to restore compatibility for those who uses an older version of Spring Boot
Both mode:
- Upgrade of com.google.guava, to remove a vulnerability
Client mode:
- Request with GraphQL variable are now accepted. Of course, this works only with full requests. You can find more information on GraphQL Variables in the GraphQL spec.
- Subscription can now be executed as full request. They were previously limited to partial requests.
Custom templates:
- The following templates have been updated : client_DirectiveRegistryInitializer.vm.java, client_GraphQLRequest.vm.java, client_jackson_deserializers.vm.java, client_query_mutation_executor.vm.java, client_subscription_executor.vm.java, client_subscription_type.vm.java, server_GraphQLDataFetchers.vm.java
- These updates are due to:
- The
GraphQLInputParameters
has been updated, to now embed all the GraphQL information (prerequisite for GraphQL variable) - The list level is now better managed (not just a boolean, but the real depth when there are lists of lists)
- The input parameters now typed with an enum, not just a boolean for mandatory/optional.
- The
- The client_query_target_type.vm.java was not used and has been removed.
Both mode:
- Custom Templates can now be defined as a resource in the current project (no need to embed them in a jar prior to use them). See the CustomTemplates-client pom file as a sample for that.
Client mode:
- The extensions field on the root of the GraphQL server response can be retrieved by using Full Queries. More information on the Client page about request execution
- Issue #55 : the extensions field of the GraphQL errors is now properly managed. It's possible to receive any GraphQL valid response for this field. And the
Error
class has now the proper getters to manage it (including deserialization of the extensions map values in any Java classes) - Issue #65: It's now possible to provide a full query that contains all GraphQL parameters (without runtime parameters). More info in the Client FAQ
Server mode:
- The Query/Mutation/Subscription are now available on the same URL (/graphql by default). This is the standard GraphQL behavior, but it was tricky to build, due to a Java limitation.
Client mode:
- Issue #53: custom scalars would not be properly managed when they are a parameter of a query, mutation or subscription.
Server mode:
- It's now possible to override the type wiring, thanks to the new
GraphQLWiring
class. - It's now possible to override the DataFetcher definitions, by overriding
GraphQLDataFetchers
. This allows, for instance, to change the DataLoader behavior. - [Internal] The
GraphQLProvider
class has been removed. The Spring beans it created are now created by theGraphQLServerMain
class. The type wiring has been moved in the newGraphQLWiring
class. This allows an easier overriding of the generated type wiring.
Both mode:
- Corrected a multithreading issue with the provided custom scalars GraphQLScalarTypeDate and GraphQLScalarTypeDateTime
Server mode:
- Issue #72: The subscription notifications would not be properly sent when more than one client subscribed to a subscription.
Client mode:
- The GraphQL server response could not be deserialized, when it contains the (non standard) extensions entry
Both modes (client and server):
- Added the skipGenerationIfSchemaHasNotChanged parameter. It's in beta version. It prevents code and resource generation, of the schema file(s) are older than these generated sources or resources. It's default value is false in 1.x releases.
- When the addRelayConnections parameter is true, the XxxConnection types of the fields marked with @RelayConnection are now non mandatory.
- The comments read in the provided schema are reported into the generated code and the generated GraphQL schemas.
Server mode:
- The graphql-java version has been upgraded to 16.2 (the latest version at this time)
- The generated code would not allow the specific implementation to override the GraphQLInvocation Spring Bean
Both modes (client and server):
- Correction for the addRelayConnections: the Node interface was not properly copied to all implementing subtypes and subinterfaces
Server mode:
- The server won't start when the graphql-java-runtime dependency is in the classpath (that is when the copyRuntimeSources plugin parameter is set to false)
- When a DataFetcher has a BatchLoader, two datafetchers would be wired, instead of just one. This is internal to the generated code, and has no impact on the "user's" code.
- The cache of the DataLoader is now managed for per request.
- When the addRelayConnections plugin parameter is set to true, the generateServerCode task/goal (and graphql task/goal when in server mode) copies the generated schema file in the /classes folder, so that the graphql-java engine has a proper access to it, at runtime.
Both modes (client and server):
- Added support for OAuth 2
- Removed all dependencies to log4j
- [internal] The GraphqlUtils class has been moved into the com.graphql_java_generator.util package
Client mode:
- The client can now be a Spring Boot app (and that's now the recommended way to build a GraphQL app). see the plugin web site for more info on this
- The subscription management has been updated. ==> Spring reactive WebSocketClient ==> The SubscriptionClient interface has a new method: WebSocketSession getSession(), which allows to retrieve the Spring reactive WebSocketSession.
Server mode:
- Corrected a regression in 1.11.2, due to generateBatchLoaderEnvironment plugin parameter (see issue #64)
server mode:
- The generated code would not compile for fields with parameters (when the field's type is an entity with an id)
- Add of the generateBatchLoaderEnvironment parameter. When in server mode, it allows the batch loader to retrieve the context, for instance the field parameters associated to this id.
Both modes (client and server):
- Upgrade of spring boot from 2.3.3 to 2.4.0
- Issue 54: The generated code would not compile for subscriptions that return a list
Gradle plugin:
- The plugin is now compatible with a JDK/JRE 8 (it previously needed java 13)
Both modes (client and server):
- Changes in goal(maven)/task(gradle) names, to make them clear and homogeneous between the gradle and the maven plugin:
- The graphql maven goal (and graphqlGenerateCode gradle task) are deprecated, but they will be maintained in future 2.x versions
- The goal(maven)/task(gradle) are now:
- generateClientCode : generates the Java code on client side, to access a GraphQL server, based on its GraphQL schema. It is the same as the deprecated graphql maven goal (or graphqlGenerateCode gradle task), with the mode parameter removed (it is internally forced to client).
- generateServerCode : generates the Java code on server side, to access a GraphQL server, based on its GraphQL schema. It is the same as the deprecated graphql maven goal (or graphqlGenerateCode gradle task), with the mode parameter removed (it is forced to server).
- generateGraphQLSchema : new, see below
- graphql (maven) / _graphqlGenerateCode (gradle) : deprecated and maintained. It's the same as the new generateClientCode and generateServerCode goals/tasks, with the mode plugin parameter that allows to choose between the client or the server mode.
- New generateGraphQLSchema goal/task that allows to generate the GraphQL schema file. It's interesting when:
- There are several GraphQL schema files in input (for instance with the extends GraphQL capability)
- The addRelayConnections is used, that adds the Node interface, and the Edge and Connection types to the schema.
Client Mode (generateClientCode):
- Corrected issue 50: could not work with nested arrays (for instance [[Float]])
- Corrected issue 51: error with argument being a list of ID ([ID])
Both modes (client and server):
- Upgrade of graphql-java from v14.0 to v15.0
- The main improvement for this is: the plugin now accepts interfaces that implement one or more interfaces
- Attributes of input types that are enum are now properly managed
Server mode:
- The generated code would not compile if a GraphQL interface is defined, but not used, in the given GraphQL schema
Both modes (client and server):
- The GraphQL schema can now be split into separate files, including one file containing GraphQL extend keyword on the other file's objects
- Add of the merge goal/task: it generates a GraphQL schema file, based on the source GraphQL schemas. It can be used to merge several GraphQL schema files into one file, or to reformat the schema files.
Client mode:
- Fixes #46: Strings not properly escaped for JSON
Both modes (client and server):
- The generated code was not compatible with Java 8 (only with Java 9 and above)
Both modes (client and server):
- Corrected issue #43: GraphQL Float was mapped to Float, instead of Double
Client mode:
- a XxxxExecutor class is now generated for each query, mutation and subscription types, for better separation of GraphQL objects and utility classes . They contains the methods to prepare and execute the queries/mutations/subscriptions that were in the query/mutation/subscription classes. These the query/mutation/subscription classes are still generated, but their use to prepare and execute the queries/mutations/subscriptions is now deprecated.
- In other word: existing code CAN remain as is. It'll continue to work.
- New code SHOULD use the XxxExecutor classes.
- Add of the generateDeprecatedRequestResponse. Default value is true, which makes it transparent for existing code. If set to false, the XxxResponse classes are not generated (where Xxx is the GraphQL name for the query, mutation and subscription objects), nor the Xxxx classes in the util subpackage (only if separateUtilityClasses is true). If generated, these classes are marked as Deprecated, and should not be used any more.
- Solved issue #44: no more need to add an extension bloc in the build pom's bloc, to make the plugin work.
- Named Fragments would not work if seperateUtilityClass was false
Server mode:
- Added the scanBasePackages plugin parameter. It allows to create our Spring Beans, including the DataFetchersDelegateXxx implementation in another place than a subpackage of the package define in the packageName plugin parameter
- Corrected a dependency issue (for server implemented from the code generated by the plugin)
Both modes (client and server):
- The plugin now manages subscription
- For custom templates: the QUERY_MUTATION_SUBSCRIPTION template has been split into two templates, QUERY_MUTATION and SUBSCRIPTION
Server mode:
- In some cases, the DataFetcherDelegate now have another DataFetcher that must be implemented
- Some server templates rename, to respect java standards. An underscore has been added to these templates name: BATCH_LOADER_DELEGATE, BATCH_LOADER_DELEGATE_IMPL, DATA_FETCHER and DATA_FETCHER_DELEGATE
Both modes (client and server):
- Default value for input parameters (fields and directives) that are null, array or an object are now properly managed.
- Plugin parameter copyGraphQLJavaSources renamed to copyRuntimeSources
- New Plugin parameter separateUtilityClasses: it allows to separate the generated utility classes (including GraphQLRequest, query/mutation/subscription) in a subfolder. This avoids collision in the generated code, between utility classes and the classes directly generated from the GraphQL schema.
Client mode:
- Thanks to the separateUtilityClasses plugin parameter, the plugin can generate the code for the shopify and github GraphQL schema (needs some additional tests: tester need here...)
Both modes (client and server):
- Added a templates plugin parameter, that allows to override the default templates. This allows the developper to control exactly what code is generated by the developer.
- Added a copyGraphQLJavaSources that allows to control whether the runtime code is embedded in the generated (previous behavior, set as the default behavior), or not. ==> copyGraphQLJavaSources renamed to copyRuntimeSources in 1.7.0 version
- Removed the unused java annotation GraphQLCustomScalar
- Solved issue #35: argument for directive could not be CustomScalar, Boolean, Int, Float or enum (enum are still not valid on the server side of this plugin, due to a graphql-java 14.0 limitation, see graphql-java/graphql-java#1844 for more details)
Client mode:
- Added GraphQL fragment capability. Query/mutation/subscription can now contain Fragment(s) and inline Fragment(s), including directives on fragments.
- Added support for GraphQL Union
- The client code has been highly simplified :
- The Builder support is now limited to the withQueryResponseDef(String query) method.
- The support for the withField(), withSubObject() (...) methods has been removed
- The __IntrospectionQuery class is no more generated: the __schema and __type queries has been added to the GraphQL schema's query, as defined in the GraphQL spec. A default query is added if no query was defined in the GraphQL schema.
- The client code should now use the GraphQLRequest that is now generated along with the GraphQL java classes.
- A GraphQLConfiguration class has been added. The generated query/mutation/subscription classes create an instance of this class, so there is no impact on existing code. But this class must be used to configure the GraphQLRequest.
- Please check the behavior of your full queries: the mutation keyword is now mandatory for mutations, as specified in the GraphQL specification. The query keyword remains optional.
- Please the client mode doc for more information.
Both modes (client and server):
- GraphQL Directives are now managed
- GraphQL types can implement multiple interfaces
- Upgrade of graphql-java from v13.0 to v14.0
Client mode:
- Directives can be added in the query, on query and fields (fragment is for a next release, coming soon)
- The query/subscription/mutation classes have now a collection of exec methods, which allows to execute several queries/mutations/subscriptions in one server call. This allows to add directive on the queries/mutations/subscriptions. Please the client mode doc for more information.
- Added a queryName/mutationName/subscriptionName that accept bind parameters, for each query/mutation/subscription. Please have a look at the allGraphQLCases client tests, in the org.allGraphQLCases.FullQueriesDirectIT class
- interfaces are properly deserialized, thanks to GraphQL introspection. (caution: code impact. Previously, for each interface, the plugin would generated a concrete class that doesn't exist in the GraphQL schema. This is not the case any more, and only GraphQL types are now generated
- The __typename is added to the list of scalar fields, for every request GraphQL nonscalar type. This allow to properly deserialize interfaces and unions.
Both modes (client and server):
- The plugin is compatible again with java 8
- The provided Date and DateTime scalars are now provided as a static field (instead of the class itself), due to a graphql-java change)
Client mode:
- Can now invoke GraphQL introspection queries (it was already the case on server side, thanks to graphql-java)
Both modes (client and server):
- Input parameters are now managed for scalar fields (custom or not)
- Removed the dependency to log4j, replaced by slf4j
- the GraphQL schema may now use java keywords (if the GraphQL schema uses identifiers that are java keywords, these identifiers are prefixed by an underscore in the generated code)
Client mode:
- Added a constructor in the generated query/mutation/subscription with a preconfigured Jersey client instance to support customization of the rest request
Both modes (client and server):
- The project now compiles up to JDK 13 (the generated code is still compatible with java 8 and higher)
- Unknown GraphQL concept are now ignored (instead of blocking the plugin work by throwing an error)
Both modes (client and server):
- Custom Scalars are now properly managed. You can provide your own Custom Scalars, or used the ones defined by graphql-java
- Fixed issue 8: Problem when using Boolean Type with property prefix "is"
Both modes (client and server):
- Corrected a bad dependency version, which prevents the released plugin to work
- Input object types are now accepted
- [CAUTION, code impact] All GraphQL exceptions have been moved into the com.graphql_java_generator.exception package
Client mode:
- Connection to https is made simpler (just declare the https URL)
- Input parameters are properly managed for queries, mutations and regular GraphQL type's field. It's possible to prepare query with Bind variables, like in JPA
- Only for request prepared by the Builder: simplification and change in the way to construct ObjectResponse objects
- Exception GraphQLExecutionException renamed to GraphQLRequestExecutionException
Server mode:
- XxxDataFetchersDelegate interfaces renamed as DataFetchersDelegateXxxx (code is easier to read, as the DataFetchersDelegates are grouped together in the classes list)
- Input parameters are accepted for queries, mutations and object's field.
- Add of the generateJPAAnnotation plugin parameter (default to false)