Skip to content

Latest commit

 

History

History
1331 lines (913 loc) · 43.7 KB

CHANGELOG.md

File metadata and controls

1331 lines (913 loc) · 43.7 KB

@graphql-tools/wrap

10.0.5

Patch Changes

10.0.4

Patch Changes

  • 69181f6 Thanks @ardatan! - MapLeafValues: fallback to astFromValueUntyped if astFromValue fails

10.0.3

Patch Changes

  • #5963 8199416 Thanks @EmrysMyrddin! - Fix missing __typename field when it is already present but aliased.

  • Updated dependencies [baf3c28]:

    • @graphql-tools/utils@10.1.1

10.0.2

Patch Changes

10.0.1

Patch Changes

10.0.0

Major Changes

Patch Changes

  • Updated dependencies [8fba6cc1, 944a68e8, 944a68e8]:
    • @graphql-tools/delegate@10.0.0
    • @graphql-tools/schema@10.0.0
    • @graphql-tools/utils@10.0.0

9.4.2

Patch Changes

  • 1c95368a Thanks @ardatan! - Use ranged versions for dependencies

  • Updated dependencies [1c95368a]:

    • @graphql-tools/schema@9.0.18
    • @graphql-tools/delegate@9.0.31

9.4.1

Patch Changes

  • c8d5e0df Thanks @ardatan! - Fix GraphQL v14 support

  • Updated dependencies []:

    • @graphql-tools/delegate@9.0.30

9.4.0

Minor Changes

9.3.9

Patch Changes

  • Updated dependencies [f26392a6]:
    • @graphql-tools/delegate@9.0.29

9.3.8

Patch Changes

  • Updated dependencies []:
    • @graphql-tools/schema@9.0.17

9.3.7

Patch Changes

  • Updated dependencies [492220cb]:
    • @graphql-tools/delegate@9.0.28

9.3.6

Patch Changes

  • Updated dependencies [30bd4d0c]:
    • @graphql-tools/delegate@9.0.27

9.3.5

Patch Changes

  • #5023 85659bca Thanks @SimenB! - Only warn about deprecated introspectSchema once

  • Updated dependencies [b09ea282, b5c8f640]:

    • @graphql-tools/delegate@9.0.26
    • @graphql-tools/utils@9.2.1
    • @graphql-tools/schema@9.0.16

9.3.4

Patch Changes

  • Updated dependencies [a94217e9, 62d074be]:
    • @graphql-tools/utils@9.2.0
    • @graphql-tools/delegate@9.0.25
    • @graphql-tools/schema@9.0.15

9.3.3

Patch Changes

  • Updated dependencies [772b948a]:
    • @graphql-tools/delegate@9.0.24

9.3.2

Patch Changes

  • Updated dependencies []:
    • @graphql-tools/schema@9.0.14
    • @graphql-tools/delegate@9.0.23

9.3.1

Patch Changes

9.3.0

Minor Changes

  • #4960 499365aa Thanks @ardatan! - Deprecate `introspectSchema` in favor of the new `schemaFromExecutor`

Patch Changes

9.2.23

Patch Changes

  • Updated dependencies [13177794]:
    • @graphql-tools/delegate@9.0.21

9.2.22

Patch Changes

9.2.21

Patch Changes

9.2.20

Patch Changes

  • Updated dependencies [904fe770, 904fe770]:
    • @graphql-tools/utils@9.1.3
    • @graphql-tools/delegate@9.0.19
    • @graphql-tools/schema@9.0.12

9.2.19

Patch Changes

  • Updated dependencies [13c24883, b5e6459f]:
    • @graphql-tools/delegate@9.0.18
    • @graphql-tools/utils@9.1.2
    • @graphql-tools/schema@9.0.11

9.2.18

Patch Changes

9.2.17

Patch Changes

9.2.16

Patch Changes

9.2.15

Patch Changes

9.2.14

Patch Changes

  • df81034c Thanks @ardatan! - Replace internal values with the external ones while wrapping schemas

9.2.13

Patch Changes

  • Updated dependencies [7411a5e7]:
    • @graphql-tools/utils@9.1.1
    • @graphql-tools/delegate@9.0.17
    • @graphql-tools/schema@9.0.10

9.2.12

Patch Changes

  • Updated dependencies []:
    • @graphql-tools/delegate@9.0.16

9.2.11

Patch Changes

  • #4825 1270b75a Thanks @NullScope! - Fixed __typename being added more than once in TransformCompositeFields

  • Updated dependencies [c0639dd0]:

    • @graphql-tools/utils@9.1.0
    • @graphql-tools/delegate@9.0.15
    • @graphql-tools/schema@9.0.9

9.2.10

Patch Changes

  • #4823 a58cd6d3 Thanks @ardatan! - Fix the bug when an optional argument's value is not provided with MapLeafValues transform

9.2.9

Patch Changes

  • Updated dependencies [d83b1960]:
    • @graphql-tools/utils@9.0.1
    • @graphql-tools/delegate@9.0.14
    • @graphql-tools/schema@9.0.8

9.2.8

Patch Changes

  • Updated dependencies []:
    • @graphql-tools/delegate@9.0.13

9.2.7

Patch Changes

  • Updated dependencies []:
    • @graphql-tools/delegate@9.0.12

9.2.6

Patch Changes

9.2.5

Patch Changes

  • c1d01f3d Thanks @ardatan! - Do not transform request if there is no value transformed during the schema transformation

  • Updated dependencies [f7daf777]:

    • @graphql-tools/utils@8.13.1
    • @graphql-tools/delegate@9.0.10
    • @graphql-tools/schema@9.0.6

9.2.4

Patch Changes

9.2.3

Patch Changes

  • Updated dependencies [0402894d]:
    • @graphql-tools/delegate@9.0.8

9.2.2

Patch Changes

  • Updated dependencies [00c4a1a4]:
    • @graphql-tools/delegate@9.0.7

9.2.1

Patch Changes

9.2.0

Minor Changes

  • #4706 43c736bd Thanks @ardatan! - RenameTypes: do not rename type if the new name already exists in the schema

Patch Changes

  • Updated dependencies [43c736bd]:
    • @graphql-tools/utils@8.12.0
    • @graphql-tools/delegate@9.0.6
    • @graphql-tools/schema@9.0.4

9.1.0

Minor Changes

9.0.6

Patch Changes

  • Updated dependencies [71cb4fae, 403ed450]:
    • @graphql-tools/utils@8.11.0
    • @graphql-tools/delegate@9.0.5
    • @graphql-tools/schema@9.0.3

9.0.5

Patch Changes

  • #4676 4e4fac0a Thanks @NullScope! - Fix transforming/renaming Wrapped GraphQL Arguments

  • Updated dependencies [4fe3d9c0]:

    • @graphql-tools/utils@8.10.1
    • @graphql-tools/delegate@9.0.4
    • @graphql-tools/schema@9.0.2

9.0.4

Patch Changes

9.0.3

Patch Changes

9.0.2

Patch Changes

  • #4648 29ee7542 Thanks @ardatan! - Do not call Transform.transformSchema more than once

  • Updated dependencies [29ee7542]:

    • @graphql-tools/delegate@9.0.2

9.0.1

Patch Changes

  • Updated dependencies [2609d71f]:
    • @graphql-tools/utils@8.10.0
    • @graphql-tools/schema@9.0.1
    • @graphql-tools/delegate@9.0.1

9.0.0

Major Changes

  • #4566 d8dc67aa Thanks @ardatan! - ## Breaking changes

    Schema generation optimization by removing transfomedSchema parameter

    Previously we were applying the transforms multiple times. We needed to introduced some breaking changes to improve the initial wrapped/stitched schema generation performance;

    • Transform.transformSchema no longer accepts transformedSchema which can easily be created with applySchemaTransforms(schema, subschemaConfig) instead.
    • Proxying resolver factory function that is passed as createProxyingResolver to SubschemaConfig no longer takes transformedSchema which can easily be created with applySchemaTransforms(schema, subschemaConfig) instead.

    stitchSchemas doesn't take nested arrays of subschemas

    stitchSchemas no longer accepts an array of arrays of subschema configuration objects. Instead, it accepts an array of subschema configuration objects or schema objects directly.

    stitchSchemas no longer prunes the schema with pruningOptions

    You can use pruneSchema from @graphql-tools/utils to prune the schema instead.

    stitchSchemas no longer respect "@computed" directive if stitchingDirectivesTransformer isn't applied

    Also @graphql-tools/stitch no longer exports computedDirectiveTransformer and defaultSubschemaConfigTransforms. Instead, use @graphql-tools/stitching-directives package for @computed directive. Learn more about setting it up

    computedFields has been removed from the merged type configuration

    MergeTypeConfig.computedFields setting has been removed in favor of new computed field configuration written as:

    merge: {
      MyType: {
        fields: {
          myComputedField: {
            selectionSet: '{ weight }',
            computed: true,
          }
        }
      }
    }

    A field-level selectionSet specifies field dependencies while the computed setting structures the field in a way that assures it is always selected with this data provided. The selectionSet is intentionally generic to support possible future uses. This new pattern organizes all field-level configuration (including canonical) into a single structure.

Patch Changes

  • #4624 e3167edc Thanks @n1ru4l! - Fix CommonJS TypeScript resolution with moduleResolution node16 or nodenext

  • Updated dependencies [8cc8721f, e3167edc, d8dc67aa]:

    • @graphql-tools/schema@9.0.0
    • @graphql-tools/delegate@9.0.0
    • @graphql-tools/utils@8.9.1

8.5.1

Patch Changes

  • Updated dependencies [2a3b45e3]
    • @graphql-tools/utils@8.9.0
    • @graphql-tools/delegate@8.8.1
    • @graphql-tools/schema@8.5.1

8.5.0

Minor Changes

  • d76a299c: Support TypeScript module resolution.

Patch Changes

  • Updated dependencies [a0abbbcd]
  • Updated dependencies [d76a299c]
    • @graphql-tools/utils@8.8.0
    • @graphql-tools/delegate@8.8.0
    • @graphql-tools/schema@8.5.0

8.4.21

Patch Changes

  • Updated dependencies [6df204de]
  • Updated dependencies [4914970b]
    • @graphql-tools/delegate@8.7.12
    • @graphql-tools/schema@8.4.0
    • @graphql-tools/utils@8.7.0

8.4.20

Patch Changes

  • 041c5ba1: Use caret range for the tslib dependency
  • Updated dependencies [041c5ba1]
    • @graphql-tools/delegate@8.7.11
    • @graphql-tools/schema@8.3.14
    • @graphql-tools/utils@8.6.13

8.4.19

Patch Changes

  • 7c3b2797: fix(wrap): wrapped types and fields should be non null
  • Updated dependencies [da7ad43b]
    • @graphql-tools/utils@8.6.12
    • @graphql-tools/delegate@8.7.10
    • @graphql-tools/schema@8.3.13

8.4.18

Patch Changes

  • Updated dependencies [c0762ee3]
    • @graphql-tools/utils@8.6.11
    • @graphql-tools/delegate@8.7.9
    • @graphql-tools/schema@8.3.12

8.4.17

Patch Changes

  • Updated dependencies [0fc510cb]
    • @graphql-tools/utils@8.6.10
    • @graphql-tools/delegate@8.7.8
    • @graphql-tools/schema@8.3.11

8.4.16

Patch Changes

  • Updated dependencies [31a33e2b]
    • @graphql-tools/utils@8.6.9
    • @graphql-tools/delegate@8.7.7
    • @graphql-tools/schema@8.3.10

8.4.15

Patch Changes

  • Updated dependencies [26e4b464]
    • @graphql-tools/delegate@8.7.6

8.4.14

Patch Changes

  • Updated dependencies [cb238877]
    • @graphql-tools/utils@8.6.8
    • @graphql-tools/delegate@8.7.5
    • @graphql-tools/schema@8.3.9

8.4.13

Patch Changes

  • 0bbb1769: Refine generic typings using extends X when appropriate

    Typescript 4.7 has stricter requirements around generics which is explained well in the related PR: microsoft/TypeScript#48366

    These changes resolve the errors that these packages will face when attempting to upgrade to TS 4.7 (still in beta at the time of writing this). Landing these changes now will allow other TS libraries which depend on these packages to experiment with TS 4.7 in the meantime.

  • Updated dependencies [0bbb1769]

    • @graphql-tools/delegate@8.7.4
    • @graphql-tools/utils@8.6.7
    • @graphql-tools/schema@8.3.8

8.4.12

Patch Changes

  • Updated dependencies [fe9402af]
    • @graphql-tools/delegate@8.7.3

8.4.11

Patch Changes

  • Updated dependencies [904c0847]
    • @graphql-tools/utils@8.6.6
    • @graphql-tools/delegate@8.7.2
    • @graphql-tools/schema@8.3.7

8.4.10

Patch Changes

  • Updated dependencies [722abad7]
    • @graphql-tools/schema@8.3.6
    • @graphql-tools/delegate@8.7.1

8.4.9

Patch Changes

  • Updated dependencies [d8fd6b94]
    • @graphql-tools/delegate@8.7.0

8.4.8

Patch Changes

  • Updated dependencies [be2c02d7]
    • @graphql-tools/utils@8.6.5
    • @graphql-tools/delegate@8.6.1
    • @graphql-tools/schema@8.3.5

8.4.7

Patch Changes

  • Updated dependencies [c40e801f]
  • Updated dependencies [d36d530b]
    • @graphql-tools/delegate@8.6.0
    • @graphql-tools/utils@8.6.4
    • @graphql-tools/schema@8.3.4

8.4.6

Patch Changes

  • 0c0c6857: fix - align versions
  • Updated dependencies [0c0c6857]
    • @graphql-tools/delegate@8.5.4
    • @graphql-tools/schema@8.3.3

8.4.5

Patch Changes

  • 3da3d66c: fix - align versions
  • Updated dependencies [3da3d66c]
    • @graphql-tools/utils@8.6.3

8.4.4

Patch Changes

  • c84840cd: fix(url-loader): get dynamic endpoint value correctly

8.4.3

Patch Changes

  • 304da972: feat(wrap): RenameObjectFieldArguments transform

8.4.2

Patch Changes

  • 18341363: feat(visitResult): ignore if field not present in visited object
  • Updated dependencies [18341363]
    • @graphql-tools/delegate@8.5.1
    • @graphql-tools/schema@8.3.2
    • @graphql-tools/utils@8.6.2

8.4.1

Patch Changes

  • 639c1133: fix(wrap): return if transformed field node isn't in the schema

8.4.0

Minor Changes

  • 081b97e8: Add better type support for stitchSchemas using subschema transformations

Patch Changes

  • Updated dependencies [081b97e8]
    • @graphql-tools/delegate@8.5.0

8.3.3

Patch Changes

  • 5642b20e: fix(wrap): fix input type transformation

8.3.2

Patch Changes

  • 960e178a: fix: isAsyncIterable should check if it is an object with iterator factory function
  • Updated dependencies [960e178a]
  • Updated dependencies [947a3fe0]
    • @graphql-tools/delegate@8.4.2
    • @graphql-tools/utils@8.5.3

8.3.1

Patch Changes

  • 981eef80: enhance: remove isPromise and cleanup file-upload handling
  • 4bfb3428: enhance: use ^ for tslib dependency
  • Updated dependencies [4bfb3428]
    • @graphql-tools/delegate@8.4.1
    • @graphql-tools/schema@8.3.1
    • @graphql-tools/utils@8.5.1

8.3.0

Minor Changes

  • ad04dc79: enhance: make operationType optional

Patch Changes

  • Updated dependencies [ad04dc79]
    • @graphql-tools/delegate@8.4.0
    • @graphql-tools/utils@8.5.0

8.2.0

Minor Changes

  • 149afddb: fix: getting ready for GraphQL v16

Patch Changes

  • Updated dependencies [149afddb]
    • @graphql-tools/delegate@8.3.0
    • @graphql-tools/schema@8.3.0
    • @graphql-tools/utils@8.4.0

8.1.1

Patch Changes

  • d88a85a4: fix(wrap): fixing variables missing on wrap/MapLeafValues transform

8.1.0

Minor Changes

  • c5b0719c: feat: GraphQL v16 support

Patch Changes

  • Updated dependencies [c5b0719c]
  • Updated dependencies [c5b0719c]
  • Updated dependencies [c5b0719c]
  • Updated dependencies [c5b0719c]
  • Updated dependencies [c5b0719c]
    • @graphql-tools/delegate@8.2.0
    • @graphql-tools/utils@8.2.0
    • @graphql-tools/schema@8.2.0

8.0.13

Patch Changes

  • e50852e6: use version ranges instead of a fixed version for the graphql-tools package versions
  • Updated dependencies [631b11bd]
  • Updated dependencies [e50852e6]
    • @graphql-tools/delegate@8.1.0
    • @graphql-tools/schema@8.1.2

8.0.12

Patch Changes

  • Updated dependencies [2c807ddb]
    • @graphql-tools/utils@8.1.1
    • @graphql-tools/delegate@8.0.10
    • @graphql-tools/schema@8.1.1

8.0.11

Patch Changes

  • Updated dependencies [9a13357c]
    • @graphql-tools/delegate@8.0.9

8.0.10

Patch Changes

  • Updated dependencies [b9684631]
  • Updated dependencies [9ede806a]
  • Updated dependencies [67691b78]
    • @graphql-tools/utils@8.1.0
    • @graphql-tools/schema@8.1.0
    • @graphql-tools/delegate@8.0.8

8.0.9

Patch Changes

  • a7dee807: fix(wrap): handle non nullable input variables correctly

8.0.8

Patch Changes

  • 343e697e: Fix TransformQuery for path longer than 1

8.0.7

Patch Changes

  • Updated dependencies [d47dcf42]
    • @graphql-tools/delegate@8.0.7

8.0.6

Patch Changes

  • Updated dependencies [ded29f3d]
    • @graphql-tools/delegate@8.0.6

8.0.5

Patch Changes

  • Updated dependencies [7fdef335]
    • @graphql-tools/delegate@8.0.5

8.0.4

Patch Changes

  • Updated dependencies [04830049]
    • @graphql-tools/utils@8.0.2
    • @graphql-tools/delegate@8.0.4
    • @graphql-tools/schema@8.0.2

8.0.3

Patch Changes

  • Updated dependencies [b823dbaf]
    • @graphql-tools/utils@8.0.1
    • @graphql-tools/delegate@8.0.3
    • @graphql-tools/schema@8.0.1

8.0.2

Patch Changes

  • Updated dependencies [d93945fa]
    • @graphql-tools/delegate@8.0.2

8.0.1

Patch Changes

  • c36defbe: fix(delegate): fix ESM import
  • Updated dependencies [c36defbe]
    • @graphql-tools/delegate@8.0.1

8.0.0

Major Changes

  • 7d3e3006: BREAKING CHANGE

    • makeRemoteExecutableSchema has been removed.
  • dae6dc7b: refactor: ExecutionParams type replaced by Request type

    rootValue property is now a part of the Request type.

    When delegating with delegateToSchema, rootValue can be set multiple ways:

    • when using a custom executor, the custom executor can utilize a rootValue in whichever custom way it specifies.
    • when using the default executor (execute/subscribe from graphql-js): -- rootValue can be passed to delegateToSchema via a named option -- rootValue can be included within a subschemaConfig -- otherwise, rootValue is inferred from the originating schema

    When using wrapSchema/stitchSchemas, a subschemaConfig can specify the createProxyingResolver function which can pass whatever rootValue it wants to delegateToSchema as above.

  • c42e811d: BREAKING CHANGES;

    • Rename Request to ExecutionRequest
    • Add required operationType: OperationTypeNode field in ExecutionRequest
    • Add context in createRequest and createRequestInfo instead of delegateToSchema

    It doesn't rely on info.operation.operationType to allow the user to call an operation from different root type. And it doesn't call getOperationAST again and again to get operation type from the document/operation because we have it in Request and ExecutionParams https://github.com/ardatan/graphql-tools/pull/3166/files#diff-d4824895ea613dcc1f710c3ac82e952fe0ca12391b671f70d9f2d90d5656fdceR38

    Improvements;

    • Memoize defaultExecutor for a single GraphQLSchema so allow getBatchingExecutor to memoize batchingExecutor correctly.
    • And there is no different defaultExecutor is created for subscription and other operation types. Only one executor is used.

    Batch executor is memoized by executor reference but createDefaultExecutor didn't memoize the default executor so this memoization wasn't working correctly on batch-execute side. https://github.com/ardatan/graphql-tools/blob/remove-info-executor/packages/batch-execute/src/getBatchingExecutor.ts#L9

  • 7d3e3006: BREAKING CHANGE

    • Now it uses the native AggregateError implementation. The major difference is the individual errors are kept under errors property instead of the object itself with Symbol.iterator.
    // From;
    for (const error of aggregateError)
    // To;
    for (const error of aggregateError.errors)
  • c0ca3190: BREAKING CHANGE

    • Remove unnecessary introspectSchemaSync, introspectSchema already handles sync execution
  • 74581cf3: fix(getDirectives): preserve order around repeatable directives

    BREAKING CHANGE: getDirectives now always return an array of individual DirectiveAnnotation objects consisting of name and args properties.

    New useful function getDirective returns an array of objects representing any args for each use of a single directive (returning the empty object {} when a directive is used without arguments).

    Note: The getDirective function returns an array even when the specified directive is non-repeatable. This is because one use of this function is to throw an error if more than one directive annotation is used for a non repeatable directive!

    When specifying directives in extensions, one can use either the old or new format.

  • c0ca3190: BREAKING CHANGE

    • Remove Subscriber and use only Executor
      • Now Executor can receive AsyncIterable and subscriptions will also be handled by Executor. This is a future-proof change for defer, stream and live queries

Patch Changes

  • Updated dependencies [af9a78de]
  • Updated dependencies [7d3e3006]
  • Updated dependencies [9c26b847]
  • Updated dependencies [7d3e3006]
  • Updated dependencies [d53e3be5]
  • Updated dependencies [7d3e3006]
  • Updated dependencies [dae6dc7b]
  • Updated dependencies [6877b913]
  • Updated dependencies [7d3e3006]
  • Updated dependencies [c42e811d]
  • Updated dependencies [7d3e3006]
  • Updated dependencies [8c8d4fc0]
  • Updated dependencies [7d3e3006]
  • Updated dependencies [7d3e3006]
  • Updated dependencies [aa43054d]
  • Updated dependencies [7d3e3006]
  • Updated dependencies [74581cf3]
  • Updated dependencies [c0ca3190]
  • Updated dependencies [7d3e3006]
  • Updated dependencies [982c8f53]
  • Updated dependencies [7d3e3006]
  • Updated dependencies [7d3e3006]
  • Updated dependencies [7d3e3006]
    • @graphql-tools/utils@8.0.0
    • @graphql-tools/delegate@8.0.0
    • @graphql-tools/schema@8.0.0

7.0.8

Patch Changes

  • 22a9f3da: fix(deps): follow package conventions on when to pin
  • Updated dependencies [22a9f3da]
    • @graphql-tools/delegate@7.1.5
    • @graphql-tools/schema@7.1.5

7.0.7

Patch Changes

  • 36f19ddb: fix(TransformQuery): pass delegation context to query and result transformers for required flexibility
  • Updated dependencies [dbdb78e0]
    • @graphql-tools/utils@7.8.1

7.0.6

Patch Changes

  • 61da3e82: use value-or-promise to streamline working with sync values or async promises
  • Updated dependencies [61da3e82]
    • @graphql-tools/delegate@7.1.4
    • @graphql-tools/schema@7.1.4

7.0.5

Patch Changes

  • 270046a1: fix(TransformInputObjectFields): transform variables #2353
  • Updated dependencies [270046a1]
    • @graphql-tools/utils@7.2.1

7.0.4

Patch Changes

  • 4240a959: enhance(wrap): use introspectSchema for both sync and async executors
  • Updated dependencies [4240a959]
    • @graphql-tools/utils@7.1.4

7.0.3

Patch Changes

  • 21da6904: fix release
  • Updated dependencies [21da6904]
    • @graphql-tools/schema@7.1.2
    • @graphql-tools/utils@7.1.2

7.0.2

Patch Changes

7.0.1

Patch Changes

  • 51e387c3: transformedSchema argument within transformSchema method of transforms should be optional. The HoistField transform incorrectly set it to non-optional, breaking Typescript builds -- presumably when used with strict compilation.

7.0.0

Major Changes

  • be1a1575: ## Breaking Changes:

    Schema Generation and Decoration API (@graphql-tools/schema)

    • Resolver validation options should now be set to error, warn or ignore rather than true or false. In previous versions, some of the validators caused errors to be thrown, while some issued warnings. This changes brings consistency to validator behavior.

    • The allowResolversNotInSchema has been renamed to requireResolversToMatchSchema, to harmonize the naming convention of all the validators. The default setting of requireResolversToMatchSchema is error, matching the previous behavior.

    Schema Delegation (delegateToSchema & @graphql-tools/delegate)

    • The delegateToSchema return value has matured and been formalized as an ExternalObject, in which all errors are integrated into the GraphQL response, preserving their initial path. Those advanced users accessing the result directly will note the change in error handling. This also allows for the deprecation of unnecessary helper functions including slicedError, getErrors, getErrorsByPathSegment functions. Only external errors with missing or invalid paths must still be preserved by annotating the remote object with special properties. The new getUnpathedErrors function is therefore necessary for retrieving only these errors. Note also the new annotateExternalObject and mergeExternalObjects functions, as well as the renaming of handleResult to resolveExternalValue.

    • Transform types and the applySchemaTransforms are now relocated to the delegate package; applyRequestTransforms/applyResultTransforms functions have been deprecated, however, as this functionality has been replaced since v6 by the Transformer abstraction.

    • The transformRequest/transformResult methods are now provided additional delegationContext and transformationContext arguments -- these were introduced in v6, but previously optional.

    • The transformSchema method may wish to create additional delegating resolvers and so it is now provided the subschemaConfig and final (non-executable) transformedSchema parameters. As in v6, the transformSchema is kicked off once to produce the non-executable version, and then, if a wrapping schema is being generated, proxying resolvers are created with access to the (non-executable) initial result. In v7, the individual transformSchema methods also get access to the result of the first run, if necessary, they can create additional wrapping schema proxying resolvers.

    • applySchemaTransforms parameters have been updated to match and support the transformSchema parameters above.

    Remote Schemas & Wrapping (wrapSchema, makeRemoteExecutableSchema, and @graphql-tools/wrap)

    • wrapSchema and generateProxyingResolvers now only take a single options argument with named properties of type SubschemaConfig. The previously possible shorthand version with first argument consisting of a GraphQLSchema and second argument representing the transforms should be reworked as a SubschemaConfig object.

    • Similarly, the ICreateProxyingResolverOptions interface that provides the options for the createProxyingResolver property of SubschemaConfig options has been adjusted. The schema property previously could be set to a GraphQLSchema or a SubschemaConfig object. This property has been removed in favor of a subschemaConfig property that will always be a SubschemaConfig object. The transforms property has been removed; transforms should be included within the SubschemaConfig object.`

    • The format of the wrapping schema has solidified. All non-root fields are expected to use identical resolvers, either defaultMergedResolver or a custom equivalent, with root fields doing the hard work of proxying. Support for custom merged resolvers throught createMergedResolver has been deprecated, as custom merging resolvers conflicts when using stitching's type merging, where resolvers are expected to be identical across subschemas.

    • The WrapFields transform's wrappingResolver option has been removed, as this complicates multiple wrapping layers, as well as planned functionality to wrap subscription root fields in potentially multiple layers, as the wrapping resolvers may be different in different layers. Modifying resolvers can still be performed by use of an additional transform such as TransformRootFields or TransformObjectFields.

    • The ExtendSchema transform has been removed, as it is conceptually simpler just to use stitchSchemas with one subschema.

    • The ReplaceFieldsWithFragment, AddFragmentsByField, AddSelectionSetsByField, and AddMergedTypeSelectionSets transforms has been removed, as they are superseded by the AddSelectionSets and VisitSelectionSets transforms. The AddSelectionSets purposely takes parsed SDL rather than strings, to nudge end users to parse these strings at build time (when possible), rather than at runtime. Parsing of selection set strings can be performed using the parseSelectionSet function from @graphql-tools/utils.

    Schema Stitching (stitchSchemas & @graphql-tools/stitch)

    • stitchSchemas's mergeTypes option is now true by default! This causes the onTypeConflict option to be ignored by default. To use onTypeConflict to select a specific type instead of simply merging, simply set mergeTypes to false.

    • schemas argument has been deprecated, use subschemas, typeDefs, or types, depending on what you are stitching.

    • When using batch delegation in type merging, the argsFromKeys function is now set only via the argsFromKeys property. Previously, if argsFromKeys was absent, it could be read from args.

    • Support for fragment hints has been removed in favor of selection set hints.

    • stitchSchemas now processes all GraphQLSchema and SubschemaConfig subschema input into new Subschema objects, handling schema config directives such aso@computed as well as generating the final transformed schema, stored as the transformedSchema property, if transforms are used. Signatures of the onTypeConflict, fieldConfigMerger, and inputFieldConfigMerger have been updated to include metadata related to the original and transformed subschemas. Note the property name change for onTypeConflict from schema to subschema.

    Mocking (addMocksToSchema and @graphql-tools/mock)

    • Mocks returning objects with fields set as functions are now operating according to upstream graphql-js convention, i.e. these functions take three arguments, args, context, and info with parent available as this rather than as the first argument.

    Other Utilities (@graphql-tools/utils)

    • filterSchema's fieldFilter will now filter all fields across Object, Interface, and Input types. For the previous Object-only behavior, switch to the objectFieldFilter option.
    • Unused fieldNodes utility functions have been removed.
    • Unused typeContainsSelectionSet function has been removed, and typesContainSelectionSet has been moved to the stitch package.
    • Unnecessary Operation type has been removed in favor of OperationTypeNode from upstream graphql-js.
    • As above, applySchemaTransforms/applyRequestTransforms/applyResultTransforms have been removed from the utils package, as they are implemented elsewhere or no longer necessary.

    Related Issues

    • proxy all the errors: #1047, #1641
    • better error handling for merges #2016, #2062
    • fix typings #1614
    • disable implicit schema pruning #1817
    • mocks not working for functions #1807

Patch Changes

  • Updated dependencies [be1a1575]
    • @graphql-tools/delegate@7.0.0
    • @graphql-tools/schema@7.0.0
    • @graphql-tools/utils@7.0.0

6.2.4

Patch Changes

  • 32c3c4f8: enhance(HoistFields): allow arguments
  • 533d6d53: Bump all packages to allow adjustments
  • Updated dependencies [32c3c4f8]
  • Updated dependencies [32c3c4f8]
  • Updated dependencies [533d6d53]
    • @graphql-tools/utils@6.2.4
    • @graphql-tools/delegate@6.2.4
    • @graphql-tools/schema@6.2.4