Update Apollo GraphQL packages (major) #161
Open
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This PR contains the following updates:
^0.29.0
->^2.0.0
^2.25.3
->^3.0.0
^2.6.3
->^3.0.0
Release Notes
apollographql/federation
v2.4.0
Compare Source
Minor Changes
This change introduces a configurable query plan cache. This option allows (#2385)
developers to provide their own query plan cache like so:
The current default implementation is effectively as follows:
TypeScript users should implement the
QueryPlanCache
type which is nowexported by
@apollo/query-planner
:Adds debug/testing query planner options (
debug.bypassPlannerForSingleSubgraph
) to bypass the query planning (#2441)process for federated supergraph having only a single subgraph. The option is disabled by default, is not recommended
for production, and is not supported (it may be removed later). It is meant for debugging/testing purposes.
Patch Changes
Refactor the internal implementation of selection sets used by the query planner to decrease the code complexity and (#2387)
improve query plan generation performance in many cases.
Optimises query plan generation for parts of queries that can statically be known to not cross across subgraphs (#2449)
Updated dependencies [
260c357c
,7bc0f8e8
,d4426ff9
,a9385bdb
,1a555d98
,ade7ceb8
,09382e74
,cab383b2
]:v2.3.5
Compare Source
Patch Changes
09382e74
]:v2.3.4
Compare Source
Patch Changes
Handle defaulted variables correctly during post-processing. (#2443)
Users who tried to use built-in conditional directives (skip/include) with defaulted variables and no variable provided would encounter an error thrown by operation post-processing saying that the variables weren't provided. The defaulted values went unaccounted for, so the operation would validate but then fail an assertion while resolving the conditional.
With this change, defaulted variable values are now collected and provided to post-processing (with defaults being overwritten by variables that are actually provided).
Updated dependencies [
6e2d24b5
]:v2.3.3
Compare Source
Patch Changes
Update @apollo/utils.logger typings dependency (#2269)
Exposes, for each subgraph request, the path in the overall gateway operation at which that subgraph request gets inserted. This path is now available as the pathInIncomingRequest field in the arguments of RemoteGraphQLDataSource.willSendRequest and RemoteGraphQLDataSource.didReceiveResponse. (#2384)
Previously the
queryPlanStoreKey
was a hash of the query concatenated with an unhashedoperationName
if it was present. This resulted in variable length cache keys that could become unnecessarily long, occupying additional space in the query plan cache. (#2310)This change incorporates the
operationName
into the hash itself (ifoperationName
is present).Update @apollo/utils.createhash package, which drops support for node 12 (#2266)
Update @apollo/utils.isnodelike package, which dropped support for node 12 (#2268)
Update @apollo/utils.fetcher package, which drops support for node 12 (#2267)
Updated dependencies [
71a07f30
]:v2.3.2
Compare Source
Patch Changes
Move gateway post-processing errors from
errors
intoextensions.valueCompletion
of the response (#2380)[https://github.com/apollographql/federation/pull/2335](https://togithub.com/apollographql/federation/pull/2335)5]\(PR #2335) introduced a breaking change that broke existing usages with respect to nullability and gateway error handling. In response to [https://github.com/apollographql/federation/issues/2374](https://togithub.com/apollographql/federation/issues/2374)4]\(Issue #2374), we are reverting the breaking portion of this change by continuing to swallow post processing errors as the gateway did prior to v2.3.0. Instead, those errors will now be included on the
extensions.valueCompletion
object in the response object.Gateway v2.3.0 and v2.3.1 are both affected by this change in behavior.
Updated dependencies []:
v2.3.1
Compare Source
Patch Changes
Capture non-ftv1 error information in metrics data. This (#2242)
error information allows the inline trace plugin to correctly
aggregate stats about errors (where no federated trace data
is available) and stop reporting incomplete traces which
are missing unavailable error information.
This PR is a precursor to apollographql/apollo-server#7136
Fix issue where the query planner was incorrectly not querying
__typename
in a subgraph fetch when@interfaceObject
is involved (#2366)Updated dependencies [
7e2ca46f
,eb5a8bc0
]:This CHANGELOG pertains only to Apollo Federation packages in the 2.x range. The Federation v0.x equivalent for this package can be found here on the
version-0.x
branch of this repo.v2.3.0
Compare Source
@shareable
field when@external
is on a type in a fed1 schema (one without@link
) PR #2343.@interfaceObject
queries due to missing "input rewrites" PR #2346.v2.2.3
Compare Source
v2.2.2
Compare Source
v2.2.1
Compare Source
v2.2.0
Compare Source
default), but users that have custom code making use of
GraphQLDataSourceProcessOptions.document
will now need to explicitly set
GatewayConfig.queryPlannerConfig.exposeDocumentNodeInFetchNode
.@shareable
on interface fields. The@shareable
directive is aboutcontrolling if multiple subgraphs can resolve a particular field, and as interface field are never directly resolved
(it's their implementation that are), having
@shareable
on interface fields is not completely meaningful andwas never meant to be supported. If an existing subgraph does have a
@shareable
on an interface field, thiswill now be rejected, but the
@shareable
can simply and safely be removed since it previously was ignored.@shareable
to be repeatable so it can be allowed on both a type definition and its extensions PR #2175.__
PR #2237.v2.1.4
Compare Source
@defer
/@stream
definitions of supergraph are not included in the API schema PR #2212.@override
PR #2181.v2.1.3
Compare Source
v2.1.2
Compare Source
@requires
PR #2120.__typename
PR #2137.v2.1.1
Compare Source
v2.1.0
Compare Source
RemoteGraphQLDataSource.errorFromResponse
now returns aGraphQLError
(as defined bygraphql
) rather than anApolloError
(as defined byapollo-server-errors
). PR #2028RemoteGraphQLDataSource.errorFromResponse
manually and expect its return value to be a particular subclass ofGraphQLError
, or if you expect the error received bydidEncounterError
to be a particular subclass ofGraphQLError
, then this change may affect you. We recommend checkingerror.extensions.code
instead.LocalGraphQLDataSource
class no longer supports the undocumented__resolveObject
Apollo Server feature. PR #2007__resolveObject
feature withLocalGraphQLDataSource
, it will no longer work. If this affects you, file an issue and we can help you find a workaround.@require
#1873.executeQueryPlan
method, which is technicallyexported by the gateway. Most users of the gateway should not call this method directly (which is exported mainly
for testing purposes in the first place) and will thus be unaffected, but if you do call this method directly, you
will have to pass the new argument when upgrading. See the method documentation for details.
fields
of@key
,@provides
and@requires
PR #1975.@key
,@provides
or@requires
were parsed butnot honored in any way. As this change reject such applications (at composition time), it could theoretically
require to remove some existing (ignored) directive applications within a
@key
,@provides
or@requires
.@defer
) PR #2093.@require
fetch were not previously fetched PR #2075.graphql
to^16.5.0
to useGraphQLErrorOptions
PR #2060@apollo/utils.fetcher
to support aborting a request. This is a type-only change, and will not impact the underlying runtime. PR #2017.GraphQLDataSource.process
, are defined using types from the@apollo/server-gateway-interface
package instead of fromapollo-server-types
andapollo-server-core
. This is intended to be fully backwards-compatible; please file an issue if this leads to TypeScript compilation issues. PR #2044@link
when using@composeDirective
PR #2046@composeDirective
directive to specify directives that should be merged to the supergraph during composition PR #1996.fetcher
s should now accept aRequest
object which has asignal: AbortSignal
property https://fetch.spec.whatwg.org/#requestinit for request timeout purposes. PR #2017DEFAULT_UPLINK_ENDPOINTS
to static member ofUplinkSupergraphManager
PR #1977.node-fetch
as a runtime dependency PR #1970.v2.0.5
Compare Source
v2.0.4
Compare Source
extend schema
PR #1875.v2.0.3
Compare Source
printSubgraphSchema
method, ensuring it can be read back by composition andbuildSubgraphSchema
PR #1831.@requires
and conditional queries (@include
/@skip
) 1835.v2.0.2
Compare Source
getDefaultFetcher
function. This function returned the defaultfetch
implementation used to talk to Uplink (which is distinct from the defaultfetch
implementation used byRemoteGraphQLDataSource
to talk to subgraphs). It was the fetcher frommake-fetch-happen
v8 with some preset configuration relating to caching and request headers. However, the caching configuration was not actually being used when talking to Uplink (as we talk to Uplink over POST requests, and the Uplink protocol has an application-level mechanism for avoiding unnecessary large responses), and the request headers were already being provided explicitly by the Uplink client code. Since this release is also upgradingmake-fetch-happen
, it is impossible to promise that there would be no behavior change at all to the fetcher returned frommake-fetch-happen
, and as none of the preset configuration is actually relevant to the internal use ofgetDefaultFetcher
(which now just usesmake-fetch-happens
without extra configuration), we have removed the function. If you were using this function, you can replaceconst fetcher = getDefaultFetcher()
withimport fetcher from 'make-fetch-happen'
. PR #1805fetch
implementation used by default byUplinkFetcher
andRemoteGraphQLDataSource
is now imported frommake-fetch-happen
v10 instead of v8. The fetcher used byRemoteGraphQLDataSource
no longer limits the number of simultaneous requests per subgraph (or specifically, per host/port pair) to 15 by default; instead, there is no limit. (If you want to restore the previous behavior, installmake-fetch-happen
, importfetcher
from it, and passnew RemoteGraphQLDataSource({ fetcher: fetcher.defaults(maxSockets: 15)}))
in yourbuildService
option.) Note that if you invoke thefetcher
yourself in aRemoteGraphQLDataSource
subclass, you should ensure that you pass "plain" objects rather thanHeaders
orRequest
objects, as the newer version has slightly different logic about how to recognizeHeaders
andRequest
objects. We have adjusted the TypeScript types forfetcher
so that only these "plain" objects (which result in consistent behavior across all fetcher implementations) are permitted. PR #1805Schema.clone
when directive application happens before definition PR #1785@require
impacts the plans of followup queries PR #1783.@require
handling in query planning PR #1732__resolveReference
resolvers on toextensions
PR #1746@apollo/utils
packages forcreateSHA
andisNodeLike
PR #1765v2.0.1
Compare Source
for: SECURITY
in the core/link directive application in the supergraph for@inaccessible
PR #1715v2.0.0
Compare Source
v0.54.1
Compare Source
v0.52.1
Compare Source
v0.52.0
Compare Source
v0.51.0
Compare Source
v0.50.2
Compare Source
v0.50.1
Compare Source
v0.50.0
Compare Source
v0.49.0
Compare Source
v0.48.3
Compare Source
v0.48.1
Compare Source
v0.48.0
Compare Source
v0.47.0
Compare Source
v0.46.0
Compare Source
v0.45.1
Compare Source
v0.45.0
Compare Source
v0.44.1
Compare Source
v0.44.0
Compare Source
v0.43.1
Compare Source
v0.43.0
Compare Source
v0.42.3
Compare Source
v0.42.2
Compare Source
v0.42.1
Compare Source
v0.42.0
Compare Source
v0.41.0
Compare Source
v0.40.0
Compare Source
v0.39.0
Compare Source
v0.38.2
Compare Source
v0.38.1
Compare Source
v0.38.0
Compare Source
v0.37.0
Compare Source
v0.36.0
Compare Source
v0.35.1
Compare Source
v0.35.0
Compare Source
v0.34.0
Compare Source
v0.33.0
Compare Source
v0.32.0
Compare Source
v0.31.1
Compare Source
v0.31.0
Compare Source
v0.30.0
Compare Source
v0.29.1
Compare Source
apollographql/apollo-server
v3.12.0
Compare Source
v3.11.1
Compare Source
v3.11.0
Compare Source
v3.10.4
Compare Source
v3.10.3
Compare Source
v3.10.2
Compare Source
v3.10.1
Compare Source
v3.10.0
Compare Source
v3.9.0
Compare Source
v3.8.2
Compare Source
v3.8.1
Compare Source
v3.8.0
Compare Source
v3.7.0
Compare Source
v3.6.8
Compare Source
v3.6.7
Compare Source
v3.6.6
Compare Source
v3.6.5
Compare Source
v3.6.4
Compare Source
v3.6.3
Compare Source
v3.6.2
Compare Source
v3.6.1
Compare Source
v3.6.0
Compare Source
v3.5.0
Compare Source
v3.4.1
Compare Source
v3.4.0
Compare Source
v3.3.0
Compare Source
v3.2.0
Compare Source
v3.1.2
Compare Source
v3.1.1
Compare Source
v3.1.0
Compare Source
v3.0.2
Compare Source
v3.0.1
Compare Source
v3.0.0
Compare Source
v2.26.1
Compare Source
v2.26.0
Compare Source
v2.25.4
Compare Source
Configuration
📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
👻 Immortal: This PR will be recreated if closed unmerged. Get config help if that's undesired.
This PR has been generated by Mend Renovate. View repository job log here.