Skip to content

Releases: ExpediaGroup/graphql-component

v2.1.7

24 Jun 20:53
Compare
Choose a tag to compare

[FIXED] - Explicitly removed wrapping of the federation __resolveReference() resolver which was preventing __resolveReference() from running when using graphql-component to build federated schemas in seperate graphql services.

v2.1.6

02 Mar 02:54
Compare
Choose a tag to compare
  • [FIXED] - A bug with graphql-component being used in a federated schema was brought to our attention and was attributed to the non-root type field resolver wrapping performed to help prevent double execution of resolvers with local delegation. Effectively, the resolver wrapping functionality was causing a null value to be returned (by attempting to return a value from the root arg) when the wrapper should have been calling through to the actual resolver. To fix this, separate wrapper functions are used for fields that begin with __ (such as __resolveType()) versus "normal" non-root type fields. These separated wrapper functions look for similar but slightly different conditions to determine whether to "short circuit" an already computed result which ensures that the wrapper functions are short circuiting or calling through to the actual resolver in the desired situations.

v2.1.5

22 Jan 20:52
Compare
Choose a tag to compare
  • [FIXED] - delegateToComponent()'s second parameter is an options object that supports an args key for passing arguments to the target GraphQL operation via JavaScript from the calling resolver. Previously, if you attempted to pass an array (wrapping any form of JavaScript scalar) a type coersion error would surface. delegateToComponent's options.args parameter now supports passing Array like arguments as expected.

v2.1.4

13 Nov 00:57
Compare
Choose a tag to compare
  • [REVERT] - reverting both fixes in 2.1.2. The change made to unify exclusions and return pre-computed results from non-root resolvers resulted in non-root resolvers not executing when they should have. Being able to exclude non-root resolvers (not their types) is a valid work around in certain situations.

v2.1.3

10 Nov 16:09
Compare
Choose a tag to compare
  • [FIXED] - modified automatic pruning mechanism during delegation to use parent types/parent type fields instead of getFieldDef()

v2.1.2

04 Nov 19:37
Compare
Choose a tag to compare
  • [FIXED] - non-root resolvers being executed twice in certain delegate situations
  • [FIXED] - resolver exclusion now works identical to type exclusion. Only root types (Query, Mutation, Subscription) and/or fields on root types can be excluded, which was not the case for resolver functions prior to this fix.

v2.1.1

30 Oct 19:33
Compare
Choose a tag to compare
  • update @apollo/federation to ^0.20.4

v2.1.0

29 Oct 23:12
Compare
Choose a tag to compare
  • [FEATURE] delegateToComponent() - automatically prune fields from the delegated document selection set that are not defined in the schema (component) being delegated to. This will reduced potential down stream errors as well as ensures no unintended fields are forwarded and all fields forwarded can be resolved by the schema be delegated to. This feature addresses some edge cases around variable forwarding that were not addressed in prior patch releases 2.0.4 and 2.0.5.

v2.0.5

27 Oct 19:03
Compare
Choose a tag to compare
  • Reinstated variable passing to the sub-document created by delegateToComponent(). All variable values will be forwarded to the delegated operation, but only the variable definitions for input types or types that are in the target schema will be forwarded. This prevents errors in certain delegate situations while also allowing valid resolution of args passed as variables.

v2.0.4

21 Oct 23:45
Compare
Choose a tag to compare
  • Fixed the error path on errors surfaced through delegateToComponent() calls such that error path takes into account the already traversed path and exclusions
  • Variables from an outer operation are no longer forwarded to the sub operation created by delegateToComponent() this is to avoid passing along variables for types that dont exist in the schema being delegated to.