This repository was archived by the owner on Feb 11, 2022. It is now read-only.
fix(deps): update dependency apollo-server-express to v3#953
Open
renovate[bot] wants to merge 1 commit intomasterfrom
Open
fix(deps): update dependency apollo-server-express to v3#953renovate[bot] wants to merge 1 commit intomasterfrom
renovate[bot] wants to merge 1 commit intomasterfrom
Conversation
45c8e7d to
9439a87
Compare
c8c3e78 to
ae8668f
Compare
0a1a354 to
f2da787
Compare
f2da787 to
41ee8fc
Compare
1cc6998 to
f75a0d5
Compare
f5f4c24 to
2374a74
Compare
2374a74 to
77fee1e
Compare
7cb0796 to
a7b6498
Compare
a7b6498 to
45c87d1
Compare
45c87d1 to
bfee4bc
Compare
bfee4bc to
fe3a198
Compare
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to subscribe to this conversation on GitHub.
Already have an account?
Sign in.
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:
2.25.2->3.5.0Release Notes
apollographql/apollo-server
v3.5.0Compare Source
graphql@16. (There is a very small backwards incompatibility:ApolloError.originalErrorcan no longer benull, matching the type ofGraphQLError.originalError. Useundefinedinstead. If this causes challenges, let us know and we can try to adapt.) PR #5857-
apollo-server-core: Fix build error when building with@rollup/plugin-commonjs. PR #5797apollo-server-plugin-response-cache: Add missing dependency onapollo-server-types(broken since v3.0.0). Issue #5804 PR #5816apollo-server-core: The default landing page plugins now takedocument,variables, andheadersarguments which fill in default values if you click through to Explorer. PR #5711apollo-server-core: Support for HTTP request batching can now be disabled by passingallowBatchedHttpRequests: falsetonew ApolloServer. PR #5778 Issue #5686v3.4.1Compare Source
apollo-server-core: Update default version of the GraphQL Playground React app loaded from the CDN to be@apollographql/graphql-playground-react@1.7.42. This patches an XSS vulnerability. Note that if you are pinning the Playground React app version in your app withnew ApolloServer({plugins: [ApolloServerPluginLandingPageGraphQLPlayground({version: 'some version'})]}), you will need to update the specified version to 1.7.42 or later to avoid this vulnerability. If you do not explicitly enable GraphQL Playground via theApolloServerPluginLandingPageGraphQLPlaygroundplugin, this vulnerability does not affect you. See advisory GHSA-qm7x-rc44-rrqw for more details.v3.4.0Compare Source
apollo-server-core: You can now specify your ownDocumentStore(aKeyValueStore<DocumentNode>) for Apollo Server's cache of parsed and validated GraphQL operation abstract syntax trees via the newdocumentStoreconstructor option. This replaces theexperimental_approximateDocumentStoreMiBoption. You can replacenew ApolloServer({experimental_approximateDocumentStoreMiB: approximateDocumentStoreMiB, ...moreOptions})with:apollo-server-core: For ease of testing, you can specify the node environment vianew ApolloServer({nodeEnv})in addition to via theNODE_ENVenvironment variable. The environment variable is now only read during server startup (and in some error cases) rather than on every request. PR #5657apollo-server-koa: The peer dependency onkoa(added in v3.0.0) should be a^range dependency rather than depending on exactly one version, and it should not be automatically increased when new versions ofkoaare released. PR #5759apollo-server-fastify: ExportApolloServerFastifyConfigandFastifyContextTypeScript types. PR #5743apollo-server-core: Only generate the schema hash once on startup rather than twice. PR #5757apollo-datasource-rest@3.3.0: When choosing whether or not to parse a response as JSON, treat anycontent-typeending in+jsonas JSON rather than justapplication/hal+json(in addition toapplication/json). PR #5737apollo-server: You can now configure the health check URL path with thehealthCheckPathconstructor option, or disable serving health checks by passingnullfor this option. (This option is specific to the batteries-includedapollo-serverpackage; if you're using a framework integration package and want to serve a health check at a different path, just use your web framework directly.) PR #5270 Issue #3577apollo-server-azure-functions: This package now supports health checks like all of the other supported Apollo Server packages; they are on by default and can be customized withdisableHealthCheckandonHealthCheck. [PR #5003](https://github.com/apollographql/apollo-server/pull/50033) Issue #4925v3.3.0Compare Source
apollo-server-core: Error handling when aserverWillStopcallback invoked byserver.stop()(orgateway.stop()) throws is now consistent: the original call toserver.stop()throws the error, and any concurrent and subsequent calls toserver.stop()throw the same error. Prior to Apollo Server v2.22.0, the original call threw the error and the behavior of concurrent and subsequent calls was undefined (in practice, it would call shutdown handlers a second time). Apollo Server v2.22.0 intended to put these semantics into place where all three kinds of calls would throw, but due to bugs, the original call would return without error and concurrent calls would hang. (Subsequent calls would correctly throw the error.) In addition, errors thrown by thedrainServerhook introduced in Apollo Server v3.2.0 are now handled in the same way. Issue #5649 PR #5653v3.2.0Compare Source
If you're using
apollo-server-expressor another framework integration, we highly recommend that you enable the new graceful shutdown feature after upgrading to 3.2.0. See the docs forApolloServerPluginDrainHttpServeror the basic usage for your integration of choice.apollo-server-core: Previously, only the batteries-includedapollo-serverpackage supported a graceful shutdown. Now the integrations support it as well, if you tell yourApolloServerwhich HTTP server to drain with the newApolloServerPluginDrainHttpServerplugin. This plugin implements a newdrainServerplugin hook. Forapollo-server-hapiyou can useApolloServerPluginStopHapiServerinstead. PR #5635apollo-server-core: Fixexperimental_approximateDocumentStoreMiBoption, which seems to have never worked before. PR #5629apollo-server-core: Only registerSIGINTandSIGTERMhandlers once the server successfully starts up; trying to callstopon a server that hasn't successfully started had undefined behavior. By default, don't register the handlers in serverless integrations, which don't have the same lifecycle as non-serverless integrations (eg, there's no explicitstartcall); you can still explicitly setstopOnTerminationSignalsto override this default. PR #5639v3.1.2Compare Source
apollo-server-core: Update versions of@graphql-tools/schemaand@graphql-tools/utilsfrom v7 to v8. While there is no change in behavior in these versions, a recently-released version of@graphql-tools/mockdepends on them, and so without this change, you tpyically end up with two copies of them installed.v3.1.1Compare Source
apollo-server-env: UpdateHeaders.values()type to match whatnode-fetchactually does and what the Fetch spec says it should be, and what@types/node-fetchfinally gets correct. PR #5537v3.1.0Compare Source
apollo-server-core: If a client does not provide a value or provides null for a variable declared to be non-null, this is now reported as an error with anextensions.codeofBAD_USER_INPUTrather thanINTERNAL_SERVER_ERROR. (This is similar to a change we made in v2.23.0 for variables that are sent as the wrong type.) PR #5508 Issue #5353apollo-server-core/apollo-server-plugin-base: Add support forschemaDidLoadOrUpdateevent hooks, to be specified by theserverWillStartevent hook. Plugins listening for this event will receive the API schema (and core schema for gateways) when the server's schema is initially loaded and when the server's schema is updated. For more information about this plugin event, see the plugin event reference documentation. PR #5187apollo-server-core: Add support for schema reporting when using Apollo Gateway. At the time of this package's release, Apollo Studio does not yet support schema reporting from gateways, so you should not use this feature yet for gateways (unless instructed otherwise by Apollo staff or by the Studio docs). If you do enable schema reporting for a gateway, the version of@apollo/gatewaymust be at least0.35.0, or elsestart()will error. PR #5187apollo-server-core: Support gateways without executors, to help with mocking gateways. Note that if you have a customGatewayInterfaceimplementation, Apollo Server will now honor theexecutorreturned fromloadand will ignore theexecutormethod on the gateway itself. See the PR for details. PR #5539apollo-server-plugin-response-cache,apollo-server-plugin-operation-registry: Change how the default export from the package is set up to fix errors with some build tools. PR #5542v3.0.2Compare Source
apollo-server-types: TypeScript typings forinfo.cacheControlare now added toGraphQLResolveInfoas part ofapollo-server-typesrather than a nested file inapollo-server-core, and the field now has a named type,ResolveInfoCacheControl. PR #5512apollo-server-micro: Like the other framework integrations, only serve landing pages from the GraphQL path (/graphqlby default, configurable via thepathoption tocreateHandler). PR #5516apollo-server-env: Remove polyfills ofObject.values,Object.entries, andutil.promisifywhich were only required for Node 6 support. RemoveValueOrPromiseandWithRequiredTypeScript types that are also provided byapollo-server-types. PR #5515v3.0.1Compare Source
apollo-server-core: The defaultmaxAge(which defaults to 0) for a field should only be applied if no dynamic cache control hint is set. Specifically, if you call the (new in 3.0.0) functioninfo.cacheControl.cacheHint.restrict({ maxAge: 60 }), it should setmaxAgeto 60 even if the default max age is lower. (This bug fix is the behavior that was intended for 3.0.0, and primarily affects the behavior of functions added in Apollo Server 3. This does mean that checkinginfo.cacheControl.cacheHintnow only shows explicitly-setmaxAgeand not the default, but this seems like it will be helpful since it lets you differentiate between the two similar circumstances.) PR #5492apollo-server-lambda: Fix TypeScript types forcontextfunction. (In 3.0.0, the TS types for thecontextfunction were accidentally inherited fromapollo-server-expressinstead of using the correct Lambda-specific types). PR #5481apollo-server-lambda,apollo-server-cloud-functions: Make the default URL path for handling GraphQL be/(ie, handle all requests). This is similar to how these packages work in Apollo Server 2. After this change,apollo-serverand the serverless integrations have a default URL path of/(or ignore the path entirely, in the case ofapollo-server-azure-functions), and the framework integrations have a default URL path of/graphql. This is a backwards-incompatible change from 3.0.1 but minimizes the changes from Apollo Server 2 (and this AS3 change was not intended or documented). PR #5497 Issue #5462v3.0.0Compare Source
BREAKING CHANGES
Apollo Server 3 contains quite a few breaking changes. Read our migration guide for more details on how to update your app.
Bumped dependencies
The minimum versions of these dependencies have been bumped to provide an improved foundation for the development of future features.
graphqllibrary prior to15.3.0.mocksoption of theApolloServerconstructor now uses@graphql-tools/mockv7 instead ofgraphql-toolsv4, which causes some breaking changes.Promises.resolversargument toaddMocksToSchema. Apollo Server does not support this option, but you can calladdMocksToSchemayourself and pass the result to theschemaoption of theApolloServerconstructor.Removed functionality
Certain undersupported and underused Apollo Server features have been removed in favor of current or future methods for achieving similar functionality. Many of these features can be manually re-enabled, as listed below.
Dropped built-in partial support for subscriptions via the
subscriptions-transport-wspackage.subscriptions-transport-wshas not been actively maintained.Dropped built-in support for file uploads via the
graphql-uploadpackage.Dropped support for the
graphql-extensionsAPI (e.g.,GraphQLExtensions,extensions) in favor of the Apollo Server plugins API.Dropped support for passing the
schemaDirectivesoption to theApolloServerconstructor.This option was passed directly to the
graphql-toolsfunctionmakeExecutableSchema. To continue using it, you can importmakeExecutableSchemafrom@graphql-tools/schemaand call it yourself:Note that
graphql-toolscalls this feature "legacy" schema directives, and you might want to consider the newerschemaTransformsoption instead.Removed the deprecated
ApolloServer.schemafield, which never worked with federated gateways.serverWillStartor registeronSchemaChangeon your gateway.apollo-datasource-rest: We no longer officially support overriding thebaseURLproperty with a getter, because TypeScript 4 does not allow you to do so.Removed the automatic addition of the
@cacheControldirective to schemas.@cacheControl, you can define it in your schema as shown in the docs.Removed the
tracingoption passed to theApolloServerconstructor. The correspondingapollo-tracingpackage has been deprecated and is no longer being published.This package implemented an inefficient JSON format for execution traces returned via the
tracingGraphQL response extension. This format was only consumed by the deprecatedengineproxyand GraphQL Playground.If you rely on this trace format, the old version of
apollo-tracingshould still work:Removed a redundant mechanism for applying extensions to an
ApolloError.error.extensions, and are not also available onerroritself.ForbiddenErrorandAuthenticationErrorconstructors now allow you to pass additional extensions.Removed the
cacheControloption passed to theApolloServerconstructor.Cache-ControlHTTP header. However, this is now implemented directly insideapollo-server-coreinstead of inside a separateapollo-cache-controlpackage (this package has been deprecated and is no longer being published).defaultMaxAgeis now done via the newly exportedApolloServerPluginCacheControlplugin, instead of as a top-level constructor option. This follows the same pattern as other built-in plugins like usage reporting.CacheHintandCacheScopetypes are now exported fromapollo-server-types. Theinfo.cacheControl.cacheHintobject now has additional methods (replace,restrict, andpolicyIfCacheable), and its fields update when those methods orsetCacheHintare called. These methods also exist onrequestContext.overallCachePolicy, which is always defined and which should not be overwritten (usereplaceinstead). There is also a new functioninfo.cacheControl.cacheHintFromTypeavailable.@cacheControldirectives on type extensions are no longer ignored. Fields returning union types are now treated similarly to fields returning object and interface types (@cacheControldirectives on the type are honored, the defaultmaxAgeis applied to them).@cacheControl(inheritMaxAge: true)when applied to a composite type or a field returning a composite type means that the defaultmaxAgeis not applied to that field (unless it is a root field).Due to conflicts with same/similar globals provided by
@types/supertest(which we use in our testing), some global TypeScript definitions have been removed fromapollo-server-envincluding that of, e.g.,fetch,RequestInfo,Headers,Request,Response,ResponseInit, and more. See the full list prior to removal here. Internally in the Apollo Server tests, for the time-being, we are relying on the same-named types from TypeScript'slib.dom.d.ts— e.g., itsRequestInfotype definition. For more details, see PR #5165.Top-level exports have changed. For example:
graphql-tools(includingmakeExecutableSchema) from all Apollo Server packages. To continue using them, installgraphql-toolsor one of its sub-packages yourself.Uploadscalar is no longer exported as part of dropping built-in support for file uploads.Stopped publishing the deprecated
apollo-server-testingpackage. This package is just a wrapper aroundserver.executeOperation, which you can use directly.apollo-server-caching: The test suite helper works differently, and theTestableKeyValueCacheinterface is removed.The
engineconstructor option,ENGINE_API_KEYenvironment variable, andENGINE_SCHEMA_TAGenvironment variables are no longer supported. Use theapolloconstructor option,APOLLO_KEYenvironment variable, andAPOLLO_GRAPH_VARIANTenvironment variable instead, as described in [theengineoption migration guide from v2.18)[https://www.apollographql.com/docs/apollo-server/v2/migration-engine-plugins/].When you supply an Apollo API key via the
APOLLO_KEYenvironment variable ornew ApolloServer({apollo: {key}}), Apollo Server 3 no longer parses the key to guess your Studio graph ID. You must specify it yourself, either via theAPOLLO_GRAPH_IDenvironment variable (ornew ApolloServer({apollo: {graphId}})), or as a graph ref along with the variant (e.g.,your-graph-id@your-graph-variant) in theAPOLLO_GRAPH_REFenvironment variable (ornew ApolloServer({apollo: {graphRef}})).Modified functionality
requestDidStart,didResolveOperation, etc.) are nowasync.async, and some were "sometimes-async" by returning aValueOrPromise.willResolveField, which remains synchronous. This method is called much more often than any other plugin method, and converting it toasyncmight affect performance.willResolveFieldmight become "sometimes-async" by returning aValueOrPromise.willSendResponseplugin lifecycle event after firingdidEncounterError.willSendResponse.executionDidStartevent can no longer return a function as an "end hook". The "end hook" for this event now must be provided as an async function property calledexecutionDidEndon an object.GraphQLServiceinterface toGatewayInterface.renderLandingPagehook that returns an HTML page to serve to browsers.ApolloServerPluginLandingPageProductionDefaultandApolloServerPluginLandingPageLocalDefault) are installed by default (the former whenNODE_ENVisproduction, the latter otherwise) with instructions on how to communicate with the server, links to Apollo Sandbox, etc.ApolloServerPluginLandingPageGraphQLPlaygroundplugin can be installed instead to continue to use GraphQL Playground instead. Theplaygroundoption provided to theApolloServerconstructor has been removed; to customize GraphQL Playground you can provide an argument to the new playground plugin. By default, no GraphQL Playground settings are overridden, including the endpoint, which now defaults towindow.location.href(with most query parameters removed). This means you typically don't have to manually configure the endpoint when using GraphQL Playground.ApolloServerPluginLandingPageDisabledplugin.defaultPlaygroundOptions,PlaygroundConfig, orPlaygroundRenderPageOptions.requestContext.response.http.statusnow affects successful GraphQL responses, not just errors.Changes to Node.js framework integrations
When using a non-serverless framework integration (Express, Fastify, Hapi, Koa, Micro, or Cloudflare), you now must call
await server.start()before attaching the server to your framework.apollo-serverlibrary or to serverless framework integrations.apollo-server-expressno longer officially supports using with theconnectframework.connectcompatibility code, and we do still test that it works withconnect. However, we reserve the right to break that compatibility without a major version bump of this package (we will certainly note in this changelog if we do so).apollo-server-lambda: This package is now implemented as a wrapper aroundapollo-server-express.createHandler's argument now has different options:expressGetMiddlewareOptions, which includes options likecorsand is passed through toapollo-server-express'sgetMiddlewareexpressAppFromMiddleware, which lets you customize HTTP processingAlso, the
contextfunction now receives anexpress: { req, res }option in addition toeventandcontextapollo-server-lambda: The handler returned bycreateHandlercan now only be called as an async function returning aPromise(it no longer optionally accepts a callback as the third argument).exports.handler = server.createHandler()will keep working without any changes).createHandlerwith a callback, you'll need to handle itsPromisereturn value instead.apollo-server-lambda: Improved support for running behind an Application Load Balancer (ALB).apollo-server-fastifyis now compatible with Fastify v3 instead of Fastify v2.apollo-server-hapiis now only tested with Hapi v20.1.2 and higher (the minimum version that supports Node 16).The non-serverless integrations now depend on their corresponding web frameworks via peer dependencies rather than direct dependencies.
All integrations that allow CORS headers to be customized now default to
access-control-allow-origin: *. This was already the case forapollo-server, Express, Fastify, and Hapi; it is now also the same for Koa (which previously reflected the request's origin), Lambda, Cloud Functions, and Azure Functions as well (which did not set CORS by default). Micro and CloudFlare do not have a built-in way of setting CORS headers.v2.25.3Compare Source
apollo-server-core: Update default version of the GraphQL Playground React app loaded from the CDN to be@apollographql/graphql-playground-react@1.7.42. This patches an XSS vulnerability. Note that if you are pinning the Playground React app version in your app withnew ApolloServer({playground: {version: 'some version'}}), you will need to update the specified version to 1.7.42 or later to avoid this vulnerability. If you disable GraphQL Playground withnew ApolloServer({playground: false}), this vulnerability does not affect you. See advisory GHSA-qm7x-rc44-rrqw for more details.Configuration
📅 Schedule: At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR is behind base branch, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
This PR has been generated by WhiteSource Renovate. View repository job log here.